X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/7317196f547cf8c5e0ec87d1526322c305faba30..dcdd0bd36ae76c154d12ffb2f3759cef15d4c8a9:/sdk/python/tests/test_collections.py diff --git a/sdk/python/tests/test_collections.py b/sdk/python/tests/test_collections.py index de01006741..66f062c167 100644 --- a/sdk/python/tests/test_collections.py +++ b/sdk/python/tests/test_collections.py @@ -952,10 +952,49 @@ class NewCollectionTestCase(unittest.TestCase, CollectionTestMixin): self.assertIs(c.find("./nonexistant.txt"), None) self.assertIs(c.find("./nonexistantsubdir/nonexistant.txt"), None) + def test_escaped_paths_dont_get_unescaped_on_manifest(self): + # Dir & file names are literally '\056' (escaped form: \134056) + manifest = './\\134056\\040Test d41d8cd98f00b204e9800998ecf8427e+0 0:0:\\134056\n' + c = Collection(manifest) + self.assertEqual(c.portable_manifest_text(), manifest) + + def test_other_special_chars_on_file_token(self): + cases = [ + ('\\000', '\0'), + ('\\011', '\t'), + ('\\012', '\n'), + ('\\072', ':'), + ('\\134400', '\\400'), + ] + for encoded, decoded in cases: + manifest = '. d41d8cd98f00b204e9800998ecf8427e+0 0:0:some%sfile.txt\n' % encoded + c = Collection(manifest) + self.assertEqual(c.portable_manifest_text(), manifest) + self.assertIn('some%sfile.txt' % decoded, c.keys()) + + def test_escaped_paths_do_get_unescaped_on_listing(self): + # Dir & file names are literally '\056' (escaped form: \134056) + manifest = './\\134056\\040Test d41d8cd98f00b204e9800998ecf8427e+0 0:0:\\134056\n' + c = Collection(manifest) + self.assertIn('\\056 Test', c.keys()) + self.assertIn('\\056', c['\\056 Test'].keys()) + + def test_make_empty_dir_with_escaped_chars(self): + c = Collection() + c.mkdirs('./Empty\\056Dir') + self.assertEqual(c.portable_manifest_text(), + './Empty\\134056Dir d41d8cd98f00b204e9800998ecf8427e+0 0:0:\\056\n') + + def test_make_empty_dir_with_spaces(self): + c = Collection() + c.mkdirs('./foo bar/baz waz') + self.assertEqual(c.portable_manifest_text(), + './foo\\040bar/baz\\040waz d41d8cd98f00b204e9800998ecf8427e+0 0:0:\\056\n') + def test_remove_in_subdir(self): c = Collection('. 781e5e245d69b566979b86e28d23f2c7+10 0:10:count1.txt\n./foo 781e5e245d69b566979b86e28d23f2c7+10 0:10:count2.txt\n') c.remove("foo/count2.txt") - self.assertEqual(". 781e5e245d69b566979b86e28d23f2c7+10 0:10:count1.txt\n", c.portable_manifest_text()) + self.assertEqual(". 781e5e245d69b566979b86e28d23f2c7+10 0:10:count1.txt\n./foo d41d8cd98f00b204e9800998ecf8427e+0 0:0:\\056\n", c.portable_manifest_text()) def test_remove_empty_subdir(self): c = Collection('. 781e5e245d69b566979b86e28d23f2c7+10 0:10:count1.txt\n./foo 781e5e245d69b566979b86e28d23f2c7+10 0:10:count2.txt\n')