Mercurial > hg > FileServer
changeset 12:8127dde8da22
fix slashing
author | Jeff Hammel <jhammel@mozilla.com> |
---|---|
date | Wed, 29 Feb 2012 15:41:01 -0800 (2012-02-29) |
parents | 1aaf2ba89b30 |
children | e3993fa05b89 |
files | fileserver/web.py tests/doctest.txt |
diffstat | 2 files changed, 18 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/fileserver/web.py Wed Feb 29 15:22:51 2012 -0800 +++ b/fileserver/web.py Wed Feb 29 15:41:01 2012 -0800 @@ -49,6 +49,11 @@ def normpath(path): return os.path.normcase(os.path.abspath(path)) + def add_slash(self, request): + import pdb; pdb.set_trace() + location = '' + response = exc.HTTPMovedPermanantly() + def index(self, directory): """ generate a directory listing for a given directory @@ -81,6 +86,8 @@ if os.path.isdir(full): # serve directory index if not path_info.endswith('/'): + response = exc.HTTPMovedPermanently(add_slash=True) + return response(environ, start_response) return self.add_slash(environ, start_response) index = self.index(full) response_headers = [('Content-Type', 'text/html'),
--- a/tests/doctest.txt Wed Feb 29 15:22:51 2012 -0800 +++ b/tests/doctest.txt Wed Feb 29 15:41:01 2012 -0800 @@ -5,6 +5,7 @@ >>> import fileserver >>> import os + >>> import urlparse >>> from paste.fixture import TestApp Make a single file server:: @@ -53,7 +54,17 @@ Ensure you can get resources from subdirectories:: >>> response = testapp.get('/foo') + >>> response.status # 301 Moved Permanently + 301 + >>> location = response.header_dict['location'] + >>> shema, netloc, path, query, fragment = urlparse.urlsplit(location) + >>> path + '/foo/' + >>> response = testapp.get('/foo/') >>> response.status + 200 + >>> 'bar.txt' in response.body + True Ensure you can't get to non-allowed resources::