From 049fac01dba0e21d5373459d9c16054e23f8a870 Mon Sep 17 00:00:00 2001 From: Brian Warner Date: Thu, 24 Mar 2016 08:46:29 -0700 Subject: [PATCH] tolerate trailing slash on "wormhole send dirname/" Previously, the trailing slash would cause the receiving side to get an empty-named directory. --- src/wormhole/scripts/send_common.py | 1 + src/wormhole/test/test_scripts.py | 28 ++++++++++++++++++++++++---- 2 files changed, 25 insertions(+), 4 deletions(-) diff --git a/src/wormhole/scripts/send_common.py b/src/wormhole/scripts/send_common.py index 20f2b63..a8f3080 100644 --- a/src/wormhole/scripts/send_common.py +++ b/src/wormhole/scripts/send_common.py @@ -34,6 +34,7 @@ def build_phase1_data(args): return phase1, fd_to_send what = os.path.join(args.cwd, args.what) + what = what.rstrip(os.sep) if not os.path.exists(what): raise TransferError("Cannot send: no file/directory named '%s'" % args.what) diff --git a/src/wormhole/test/test_scripts.py b/src/wormhole/test/test_scripts.py index 687df5d..2939f67 100644 --- a/src/wormhole/test/test_scripts.py +++ b/src/wormhole/test/test_scripts.py @@ -71,7 +71,7 @@ class Phase1Data(unittest.TestCase): self.assertEqual(str(e), "Cannot send: no file/directory named '%s'" % filename) - def test_directory(self): + def _do_test_directory(self, addslash): parent_dir = self.mktemp() os.mkdir(parent_dir) send_dir = "dirname" @@ -81,7 +81,10 @@ class Phase1Data(unittest.TestCase): with open(os.path.join(parent_dir, send_dir, p), "wb") as f: f.write(("%s ponies\n" % p).encode("ascii")) - send_args = [ "send", send_dir ] + send_dir_arg = send_dir + if addslash: + send_dir_arg += os.sep + send_args = [ "send", send_dir_arg ] args = runner.parser.parse_args(send_args) args.cwd = parent_dir args.stdout = io.StringIO() @@ -110,6 +113,12 @@ class Phase1Data(unittest.TestCase): self.assertEqual(("%s ponies\n" % name).encode("ascii"), contents) + def test_directory(self): + return self._do_test_directory(addslash=False) + + def test_directory_addslash(self): + return self._do_test_directory(addslash=True) + def test_unknown(self): filename = "unknown" send_dir = self.mktemp() @@ -210,7 +219,7 @@ class PregeneratedCode(ServerBase, ScriptsBase, unittest.TestCase): @inlineCallbacks def _do_test(self, as_subprocess=False, - mode="text", override_filename=False, + mode="text", addslash=False, override_filename=False, sender_twisted=False, receiver_twisted=False): assert mode in ("text", "file", "directory") common_args = ["--hide-progress", @@ -266,7 +275,10 @@ class PregeneratedCode(ServerBase, ScriptsBase, unittest.TestCase): for i in range(5): with open(os.path.join(source_dir, str(i)), "w") as f: f.write(message(i)) - send_args.append(os.path.join("middle", send_dirname)) + send_dirname_arg = os.path.join("middle", send_dirname) + if addslash: + send_dirname_arg += os.sep + send_args.append(send_dirname_arg) receive_dirname = send_dirname receive_args.append("--accept-file") @@ -427,12 +439,20 @@ class PregeneratedCode(ServerBase, ScriptsBase, unittest.TestCase): def test_directory(self): return self._do_test(mode="directory") + def test_directory_addslash(self): + return self._do_test(mode="directory", addslash=True) def test_directory_override(self): return self._do_test(mode="directory", override_filename=True) def test_directory_twisted_to_blocking(self): return self._do_test(mode="directory", sender_twisted=True) + def test_directory_twisted_to_blocking_addslash(self): + return self._do_test(mode="directory", addslash=True, + sender_twisted=True) def test_directory_blocking_to_twisted(self): return self._do_test(mode="directory", receiver_twisted=True) def test_directory_twisted_to_twisted(self): return self._do_test(mode="directory", sender_twisted=True, receiver_twisted=True) + def test_directory_twisted_to_twisted_addslash(self): + return self._do_test(mode="directory", addslash=True, + sender_twisted=True, receiver_twisted=True)