mirror of
https://github.com/tahoe-lafs/tahoe-lafs.git
synced 2025-01-16 01:40:12 +00:00
tahoe cp: ignore trailing slash on source arguments
This avoids an error case where an empty child name resulted in a duplicate mkdir. It adds a precondition check to guard against empty child names, and some test cases. It also cleans up a funny redundancy noticed earlier (refs ticket:2329).
This commit is contained in:
parent
97fd19407d
commit
ca23c4fa23
@ -151,6 +151,7 @@ class LocalDirectoryTarget:
|
|||||||
|
|
||||||
def get_child_target(self, name):
|
def get_child_target(self, name):
|
||||||
precondition(isinstance(name, unicode), name)
|
precondition(isinstance(name, unicode), name)
|
||||||
|
precondition(len(name), name) # don't want ""
|
||||||
if self.children is None:
|
if self.children is None:
|
||||||
self.populate(recurse=False)
|
self.populate(recurse=False)
|
||||||
if name in self.children:
|
if name in self.children:
|
||||||
@ -637,6 +638,8 @@ class Copier:
|
|||||||
url = self.nodeurl + "uri/%s" % urllib.quote(rootcap)
|
url = self.nodeurl + "uri/%s" % urllib.quote(rootcap)
|
||||||
name = None
|
name = None
|
||||||
if path:
|
if path:
|
||||||
|
if path.endswith("/"):
|
||||||
|
path = path[:-1]
|
||||||
url += "/" + escape_path(path)
|
url += "/" + escape_path(path)
|
||||||
last_slash = path.rfind(u"/")
|
last_slash = path.rfind(u"/")
|
||||||
name = path
|
name = path
|
||||||
@ -659,13 +662,6 @@ class Copier:
|
|||||||
writecap = to_str(d.get("rw_uri"))
|
writecap = to_str(d.get("rw_uri"))
|
||||||
readcap = to_str(d.get("ro_uri"))
|
readcap = to_str(d.get("ro_uri"))
|
||||||
mutable = d.get("mutable", False) # older nodes don't provide it
|
mutable = d.get("mutable", False) # older nodes don't provide it
|
||||||
|
|
||||||
last_slash = source_spec.rfind(u"/")
|
|
||||||
if last_slash != -1:
|
|
||||||
# TODO: this looks funny and redundant with the 'name'
|
|
||||||
# assignment above. cf #2329
|
|
||||||
name = source_spec[last_slash+1:]
|
|
||||||
|
|
||||||
t = TahoeFileSource(self.nodeurl, mutable, writecap, readcap, name)
|
t = TahoeFileSource(self.nodeurl, mutable, writecap, readcap, name)
|
||||||
return t
|
return t
|
||||||
|
|
||||||
|
@ -658,7 +658,9 @@ starting copy, 2 files, 1 directories
|
|||||||
|
|
||||||
# these test cases come from ticket #2329 comment 40
|
# these test cases come from ticket #2329 comment 40
|
||||||
# trailing slash on target *directory* should not matter, test both
|
# trailing slash on target *directory* should not matter, test both
|
||||||
# trailing slash on files should cause error
|
# trailing slash on target files should cause error
|
||||||
|
# trailing slash on source directory should not matter, test a few
|
||||||
|
# ignore trailing slash on source file, that's easiest
|
||||||
|
|
||||||
COPYOUT_TESTCASES = """
|
COPYOUT_TESTCASES = """
|
||||||
cp $FILECAP to/existing-file : to/existing-file
|
cp $FILECAP to/existing-file : to/existing-file
|
||||||
@ -680,16 +682,22 @@ cp $FILECAP $DIRCAP to/existing-file/ : E4-NEED-R
|
|||||||
cp -r $FILECAP $DIRCAP to/existing-file/ : E7-BADSLASH
|
cp -r $FILECAP $DIRCAP to/existing-file/ : E7-BADSLASH
|
||||||
|
|
||||||
# single source to a (present) target directory
|
# single source to a (present) target directory
|
||||||
cp $FILECAP to : E2-DESTNAME
|
cp $FILECAP to : E2-DESTNAME
|
||||||
cp -r $FILECAP to : E2-DESTNAME
|
cp -r $FILECAP to : E2-DESTNAME
|
||||||
cp $DIRCAP/file to : to/file
|
cp $DIRCAP/file to : to/file
|
||||||
cp -r $DIRCAP/file to : to/file
|
cp -r $DIRCAP/file to : to/file
|
||||||
cp $PARENTCAP/dir to : E4-NEED-R
|
# these two should behave like the two above: ignore trailing slash
|
||||||
cp -r $PARENTCAP/dir to : to/dir/file
|
cp $DIRCAP/file/ to : to/file
|
||||||
cp $DIRCAP to : E4-NEED-R
|
cp -r $DIRCAP/file/ to : to/file
|
||||||
cp -r $DIRCAP to : to/file
|
cp $PARENTCAP/dir to : E4-NEED-R
|
||||||
cp $DIRALIAS to : E4-NEED-R
|
cp -r $PARENTCAP/dir to : to/dir/file
|
||||||
cp -r $DIRALIAS to : to/file
|
# these two should ignore the trailing source slash too
|
||||||
|
cp $PARENTCAP/dir/ to : E4-NEED-R
|
||||||
|
cp -r $PARENTCAP/dir/ to : to/dir/file
|
||||||
|
cp $DIRCAP to : E4-NEED-R
|
||||||
|
cp -r $DIRCAP to : to/file
|
||||||
|
cp $DIRALIAS to : E4-NEED-R
|
||||||
|
cp -r $DIRALIAS to : to/file
|
||||||
|
|
||||||
cp $FILECAP to/ : E2-DESTNAME
|
cp $FILECAP to/ : E2-DESTNAME
|
||||||
cp -r $FILECAP to/ : E2-DESTNAME
|
cp -r $FILECAP to/ : E2-DESTNAME
|
||||||
|
Loading…
Reference in New Issue
Block a user