From 2cb05817a67c7ccb3a570d8cbf1c6682f57a9c9d Mon Sep 17 00:00:00 2001 From: Brian Warner <warner@allmydata.com> Date: Tue, 11 Dec 2007 19:47:04 -0700 Subject: [PATCH] test_web.py: survive localdir/localfile= names with spaces. Should close #223 --- src/allmydata/test/test_web.py | 57 +++++++++++++++++++--------------- 1 file changed, 32 insertions(+), 25 deletions(-) diff --git a/src/allmydata/test/test_web.py b/src/allmydata/test/test_web.py index 5299209c..974ac69b 100644 --- a/src/allmydata/test/test_web.py +++ b/src/allmydata/test/test_web.py @@ -444,8 +444,9 @@ class Web(WebMixin, unittest.TestCase): return res def test_GET_FILEURL_localfile(self): - localfile = os.path.abspath("web/GET_FILEURL_localfile") - url = self.public_url + "/foo/bar.txt?t=download&localfile=%s" % localfile + localfile = os.path.abspath("web/GET_FILEURL_local file") + url = (self.public_url + "/foo/bar.txt?t=download&localfile=%s" % + urllib.quote(localfile)) fileutil.make_dirs("web") d = self.GET(url) def _done(res): @@ -456,8 +457,9 @@ class Web(WebMixin, unittest.TestCase): return d def test_GET_FILEURL_localfile_disabled(self): - localfile = os.path.abspath("web/GET_FILEURL_localfile_disabled") - url = self.public_url + "/foo/bar.txt?t=download&localfile=%s" % localfile + localfile = os.path.abspath("web/GET_FILEURL_local file_disabled") + url = (self.public_url + "/foo/bar.txt?t=download&localfile=%s" % + urllib.quote(localfile)) fileutil.make_dirs("web") self.disable_local_access() d = self.GET(url) @@ -472,10 +474,10 @@ class Web(WebMixin, unittest.TestCase): # server's idea of what counts as "local". old_LOCALHOST = webish.LOCALHOST webish.LOCALHOST = "127.0.0.2" - localfile = os.path.abspath("web/GET_FILEURL_localfile_nonlocal") + localfile = os.path.abspath("web/GET_FILEURL_local file_nonlocal") fileutil.make_dirs("web") d = self.GET(self.public_url + "/foo/bar.txt?t=download&localfile=%s" - % localfile) + % urllib.quote(localfile)) d.addBoth(self.shouldFail, error.Error, "localfile non-local", "403 Forbidden", "localfile= or localdir= requires a local connection") @@ -492,7 +494,7 @@ class Web(WebMixin, unittest.TestCase): localfile = "web/nonabsolute/path" fileutil.make_dirs("web/nonabsolute") d = self.GET(self.public_url + "/foo/bar.txt?t=download&localfile=%s" - % localfile) + % urllib.quote(localfile)) d.addBoth(self.shouldFail, error.Error, "localfile non-absolute", "403 Forbidden", "localfile= or localdir= requires an absolute path") @@ -502,8 +504,9 @@ class Web(WebMixin, unittest.TestCase): return d def test_PUT_NEWFILEURL_localfile(self): - localfile = os.path.abspath("web/PUT_NEWFILEURL_localfile") - url = self.public_url + "/foo/new.txt?t=upload&localfile=%s" % localfile + localfile = os.path.abspath("web/PUT_NEWFILEURL_local file") + url = (self.public_url + "/foo/new.txt?t=upload&localfile=%s" % + urllib.quote(localfile)) fileutil.make_dirs("web") f = open(localfile, "wb") f.write(self.NEWFILE_CONTENTS) @@ -516,8 +519,9 @@ class Web(WebMixin, unittest.TestCase): return d def test_PUT_NEWFILEURL_localfile_disabled(self): - localfile = os.path.abspath("web/PUT_NEWFILEURL_localfile_disabled") - url = self.public_url + "/foo/new.txt?t=upload&localfile=%s" % localfile + localfile = os.path.abspath("web/PUT_NEWFILEURL_local file_disabled") + url = (self.public_url + "/foo/new.txt?t=upload&localfile=%s" % + urllib.quote(localfile)) fileutil.make_dirs("web") f = open(localfile, "wb") f.write(self.NEWFILE_CONTENTS) @@ -530,13 +534,13 @@ class Web(WebMixin, unittest.TestCase): return d def test_PUT_NEWFILEURL_localfile_mkdirs(self): - localfile = os.path.abspath("web/PUT_NEWFILEURL_localfile_mkdirs") + localfile = os.path.abspath("web/PUT_NEWFILEURL_local file_mkdirs") fileutil.make_dirs("web") f = open(localfile, "wb") f.write(self.NEWFILE_CONTENTS) f.close() d = self.PUT(self.public_url + "/foo/newdir/new.txt?t=upload&localfile=%s" - % localfile, "") + % urllib.quote(localfile), "") d.addCallback(self.failUnlessURIMatchesChild, self._foo_node, "newdir/new.txt") d.addCallback(lambda res: @@ -714,9 +718,10 @@ class Web(WebMixin, unittest.TestCase): return d def test_GET_DIRURL_localdir(self): - localdir = os.path.abspath("web/GET_DIRURL_localdir") + localdir = os.path.abspath("web/GET_DIRURL_local dir") fileutil.make_dirs("web") - d = self.GET(self.public_url + "/foo?t=download&localdir=%s" % localdir) + d = self.GET(self.public_url + "/foo?t=download&localdir=%s" % + urllib.quote(localdir)) def _check(res): barfile = os.path.join(localdir, "bar.txt") self.failUnless(os.path.exists(barfile)) @@ -730,19 +735,21 @@ class Web(WebMixin, unittest.TestCase): return d def test_GET_DIRURL_localdir_disabled(self): - localdir = os.path.abspath("web/GET_DIRURL_localdir_disabled") + localdir = os.path.abspath("web/GET_DIRURL_local dir_disabled") fileutil.make_dirs("web") self.disable_local_access() - d = self.GET(self.public_url + "/foo?t=download&localdir=%s" % localdir) + d = self.GET(self.public_url + "/foo?t=download&localdir=%s" % + urllib.quote(localdir)) d.addBoth(self.shouldFail, error.Error, "localfile disabled", "403 Forbidden", "local file access is disabled") return d def test_GET_DIRURL_localdir_nonabsolute(self): - localdir = "web/nonabsolute/dirpath" + localdir = "web/nonabsolute/dir path" fileutil.make_dirs("web/nonabsolute") - d = self.GET(self.public_url + "/foo?t=download&localdir=%s" % localdir) + d = self.GET(self.public_url + "/foo?t=download&localdir=%s" % + urllib.quote(localdir)) d.addBoth(self.shouldFail, error.Error, "localdir non-absolute", "403 Forbidden", "localfile= or localdir= requires an absolute path") @@ -810,7 +817,7 @@ class Web(WebMixin, unittest.TestCase): self.failUnless(FakeCHKFileNode.all_contents[got_uri] == contents) def test_PUT_NEWDIRURL_localdir(self): - localdir = os.path.abspath("web/PUT_NEWDIRURL_localdir") + localdir = os.path.abspath("web/PUT_NEWDIRURL_local dir") # create some files there fileutil.make_dirs(os.path.join(localdir, "one")) fileutil.make_dirs(os.path.join(localdir, "one/sub")) @@ -821,7 +828,7 @@ class Web(WebMixin, unittest.TestCase): self.touch(localdir, "zap.zip") d = self.PUT(self.public_url + "/newdir?t=upload&localdir=%s" - % localdir, "") + % urllib.quote(localdir), "") pr = self.public_root d.addCallback(lambda res: self.failUnlessNodeHasChild(pr, "newdir")) d.addCallback(lambda res: pr.get("newdir")) @@ -839,7 +846,7 @@ class Web(WebMixin, unittest.TestCase): return d def test_PUT_NEWDIRURL_localdir_disabled(self): - localdir = os.path.abspath("web/PUT_NEWDIRURL_localdir_disabled") + localdir = os.path.abspath("web/PUT_NEWDIRURL_local dir_disabled") # create some files there fileutil.make_dirs(os.path.join(localdir, "one")) fileutil.make_dirs(os.path.join(localdir, "one/sub")) @@ -851,14 +858,14 @@ class Web(WebMixin, unittest.TestCase): self.disable_local_access() d = self.PUT(self.public_url + "/newdir?t=upload&localdir=%s" - % localdir, "") + % urllib.quote(localdir), "") d.addBoth(self.shouldFail, error.Error, "localfile disabled", "403 Forbidden", "local file access is disabled") return d def test_PUT_NEWDIRURL_localdir_mkdirs(self): - localdir = os.path.abspath("web/PUT_NEWDIRURL_localdir_mkdirs") + localdir = os.path.abspath("web/PUT_NEWDIRURL_local dir_mkdirs") # create some files there fileutil.make_dirs(os.path.join(localdir, "one")) fileutil.make_dirs(os.path.join(localdir, "one/sub")) @@ -869,7 +876,7 @@ class Web(WebMixin, unittest.TestCase): self.touch(localdir, "zap.zip") d = self.PUT(self.public_url + "/foo/subdir/newdir?t=upload&localdir=%s" - % localdir, + % urllib.quote(localdir), "") fn = self._foo_node d.addCallback(lambda res: self.failUnlessNodeHasChild(fn, "subdir")) -- 2.45.2