X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/71c4fdc3352ad5ca34c2f260fe43fa1150868a04..43cfd4220fea2ba6632bbb82e4d1779c68d827fc:/sdk/ruby/test/test_keep_manifest.rb diff --git a/sdk/ruby/test/test_keep_manifest.rb b/sdk/ruby/test/test_keep_manifest.rb index f1f1a530ce..7689d5016f 100644 --- a/sdk/ruby/test/test_keep_manifest.rb +++ b/sdk/ruby/test/test_keep_manifest.rb @@ -208,4 +208,75 @@ class ManifestTest < Minitest::Test assert !file_name.empty?, "empty file_name in #{name} fixture" end end + + def test_collection_with_dirs_in_filenames + manifest = Keep::Manifest.new(MANIFEST_WITH_DIRS_IN_FILENAMES) + + seen = Hash.new { |this, key| this[key] = [] } + + manifest.files.each do |stream, basename, size| + refute(seen[stream].include?(basename), "each_file repeated #{stream}/#{basename}") + assert_equal(3, size, "wrong size for #{stream}/#{basename}") + seen[stream] << basename + end + + assert_equal(%w(. ./dir1 ./dir1/dir2), seen.keys) + + seen.each_pair do |stream, basenames| + assert_equal(%w(file1), basenames.sort, "wrong file list for #{stream}") + end + end + + def test_multilevel_collection_with_dirs_in_filenames + manifest = Keep::Manifest.new(MULTILEVEL_MANIFEST_WITH_DIRS_IN_FILENAMES) + + seen = Hash.new { |this, key| this[key] = [] } + expected_sizes = {'.' => 3, './dir1' => 6, './dir1/dir2' => 11} + + manifest.files.each do |stream, basename, size| + refute(seen[stream].include?(basename), "each_file repeated #{stream}/#{basename}") + assert_equal(expected_sizes[stream], size, "wrong size for #{stream}/#{basename}") + seen[stream] << basename + end + + assert_equal(%w(. ./dir1 ./dir1/dir2), seen.keys) + + seen.each_pair do |stream, basenames| + assert_equal(%w(file1), basenames.sort, "wrong file list for #{stream}") + end + end + + [[false, nil], + [false, '+0'], + [false, 'd41d8cd98f00b204e9800998ecf8427'], + [false, 'd41d8cd98f00b204e9800998ecf8427+0'], + [false, 'd41d8cd98f00b204e9800998ecf8427e0'], + [false, 'd41d8cd98f00b204e9800998ecf8427e0+0'], + [false, 'd41d8cd98f00b204e9800998ecf8427e+0 '], + [false, "d41d8cd98f00b204e9800998ecf8427e+0\n"], + [false, ' d41d8cd98f00b204e9800998ecf8427e+0'], + [false, 'd41d8cd98f00b204e9800998ecf8427e+K+0'], + [false, 'd41d8cd98f00b204e9800998ecf8427e+0+0'], + [false, 'd41d8cd98f00b204e9800998ecf8427e++'], + [false, 'd41d8cd98f00b204e9800998ecf8427e+0+K+'], + [false, 'd41d8cd98f00b204e9800998ecf8427e+0++K'], + [false, 'd41d8cd98f00b204e9800998ecf8427e+0+K++'], + [false, 'd41d8cd98f00b204e9800998ecf8427e+0+K++Z'], + [true, 'd41d8cd98f00b204e9800998ecf8427e', nil,nil,nil], + [true, 'd41d8cd98f00b204e9800998ecf8427e+0', '+0','0',nil], + [true, 'd41d8cd98f00b204e9800998ecf8427e+0+Fizz+Buzz','+0','0','+Fizz+Buzz'], + [true, 'd41d8cd98f00b204e9800998ecf8427e+Fizz+Buzz', nil,nil,'+Fizz+Buzz'], + [true, 'd41d8cd98f00b204e9800998ecf8427e+0+Z', '+0','0','+Z'], + [true, 'd41d8cd98f00b204e9800998ecf8427e+Z', nil,nil,'+Z'], + ].each do |ok, locator, match2, match3, match4| + define_method "test_LOCATOR_REGEXP_on_#{locator.inspect}" do + match = Keep::Locator::LOCATOR_REGEXP.match locator + assert_equal ok, !!match + if ok + assert_equal match2, match[2] + assert_equal match3, match[3] + assert_equal match4, match[4] + end + end + end end