diff options
| author | Malthe Borch <mborch@gmail.com> | 2009-08-27 10:26:12 +0000 |
|---|---|---|
| committer | Malthe Borch <mborch@gmail.com> | 2009-08-27 10:26:12 +0000 |
| commit | 2234c998d4eb7672065fb02c4974c0535f409dca (patch) | |
| tree | 3755d4bd9f8722b728bee92ec4741fc942e48134 | |
| parent | 3d1abbd5be1d1bc0f27e488059ccf7aaca225f31 (diff) | |
| download | pyramid-2234c998d4eb7672065fb02c4974c0535f409dca.tar.gz pyramid-2234c998d4eb7672065fb02c4974c0535f409dca.tar.bz2 pyramid-2234c998d4eb7672065fb02c4974c0535f409dca.zip | |
Rebase module-relative static views on the nearest package path.
| -rw-r--r-- | repoze/bfg/static.py | 21 | ||||
| -rw-r--r-- | repoze/bfg/tests/test_zcml.py | 35 | ||||
| -rw-r--r-- | repoze/bfg/zcml.py | 10 |
3 files changed, 47 insertions, 19 deletions
diff --git a/repoze/bfg/static.py b/repoze/bfg/static.py index 01ce98a30..be33ebee1 100644 --- a/repoze/bfg/static.py +++ b/repoze/bfg/static.py @@ -1,4 +1,5 @@ import os +import sys import pkg_resources from paste.httpheaders import ETAG @@ -6,6 +7,26 @@ from paste.urlparser import StaticURLParser from paste import httpexceptions from paste import request +def find_package(path): + """ + Determine the Python-package where path is located. If the path + is not located within the Python sys-path, return ``None``. + """ + + syspaths = list(sys.path) + syspaths.sort(key=lambda syspath: path.startswith('path') and 'path', reverse=True) + syspath = syspaths[0] + + path = os.path.normpath(path) + if not path.startswith(syspath): + return + + path = path[len(syspath):] + if path.startswith(os.path.sep): + path = path[1:] + + return path + class PackageURLParser(StaticURLParser): """ This probably won't work with zipimported resources """ def __init__(self, package_name, resource_name, root_resource=None, diff --git a/repoze/bfg/tests/test_zcml.py b/repoze/bfg/tests/test_zcml.py index d17babaf3..b19f20148 100644 --- a/repoze/bfg/tests/test_zcml.py +++ b/repoze/bfg/tests/test_zcml.py @@ -412,25 +412,25 @@ class TestViewDirective(unittest.TestCase): self.assertEqual(len(actions), 2) permission = actions[0] - permission_discriminator = ('permission', IFoo, '', IDummy, + permission_discriminator = ('permission', IFoo, '', DummyModule, IViewPermission) self.assertEqual(permission['discriminator'], permission_discriminator) self.assertEqual(permission['callable'], handler) self.assertEqual(permission['args'][0], 'registerAdapter') self.failUnless(isinstance(permission['args'][1],ViewPermissionFactory)) self.assertEqual(permission['args'][1].permission_name, 'repoze.view') - self.assertEqual(permission['args'][2], (IFoo, IDummy)) + self.assertEqual(permission['args'][2], (IFoo, DummyModule)) self.assertEqual(permission['args'][3], IViewPermission) self.assertEqual(permission['args'][4], '') self.assertEqual(permission['args'][5], None) regadapt = actions[1] - regadapt_discriminator = ('view', IFoo, '', IDummy, IView) + regadapt_discriminator = ('view', IFoo, '', DummyModule, IView) self.assertEqual(regadapt['discriminator'], regadapt_discriminator) self.assertEqual(regadapt['callable'], handler) self.assertEqual(regadapt['args'][0], 'registerAdapter') self.assertEqual(regadapt['args'][1], view) - self.assertEqual(regadapt['args'][2], (IFoo, IDummy)) + self.assertEqual(regadapt['args'][2], (IFoo, DummyModule)) self.assertEqual(regadapt['args'][3], IView) self.assertEqual(regadapt['args'][4], '') self.assertEqual(regadapt['args'][5], None) @@ -466,10 +466,10 @@ class TestViewDirective(unittest.TestCase): self.assertEqual(len(actions), 2) permission = actions[0] - self.assertEqual(permission['args'][2], (IFoo, IDummy)) + self.assertEqual(permission['args'][2], (IFoo, DummyModule)) regadapt = actions[1] - regadapt_discriminator = ('view', IFoo, '', IDummy, IView) - self.assertEqual(regadapt['args'][2], (IFoo, IDummy)) + regadapt_discriminator = ('view', IFoo, '', DummyModule, IView) + self.assertEqual(regadapt['args'][2], (IFoo, DummyModule)) def test_with_route_name(self): from zope.component import getSiteManager @@ -1076,8 +1076,7 @@ class TestStaticDirective(unittest.TestCase): self.assertEqual(route_callable, connect_route) self.assertEqual(route_discriminator, ( 'route', 'name', None, None)) - self.assertEqual(route_args, ( - 'name*subpath', 'name', None)) + self.assertEqual(route_args[0], 'name*subpath') def test_package_relative(self): from repoze.bfg.zcml import handler @@ -1104,8 +1103,7 @@ class TestStaticDirective(unittest.TestCase): self.assertEqual(route_callable, connect_route) self.assertEqual(route_discriminator, ( 'route', 'name', None, None)) - self.assertEqual(route_args, ( - 'name*subpath', 'name', None)) + self.assertEqual(route_args[0], 'name*subpath') class TestResourceDirective(unittest.TestCase): def setUp(self): @@ -1145,7 +1143,7 @@ class TestResourceDirective(unittest.TestCase): self.assertEqual(action['callable'], _override) self.assertEqual(action['discriminator'], None) self.assertEqual(action['args'], - (IDummy, '', IDummy, '')) + (DummyModule, '', DummyModule, '')) def test_with_colons(self): from repoze.bfg.zcml import _override @@ -1157,7 +1155,7 @@ class TestResourceDirective(unittest.TestCase): self.assertEqual(action['callable'], _override) self.assertEqual(action['discriminator'], None) self.assertEqual(action['args'], - (IDummy, 'foo.pt', IDummy, 'foo.pt')) + (DummyModule, 'foo.pt', DummyModule, 'foo.pt')) def test_override_module_with_directory(self): from repoze.bfg.zcml import _override @@ -1169,7 +1167,7 @@ class TestResourceDirective(unittest.TestCase): self.assertEqual(action['callable'], _override) self.assertEqual(action['discriminator'], None) self.assertEqual(action['args'], - (IDummy, '', IDummy, 'foo/')) + (DummyModule, '', DummyModule, 'foo/')) def test_override_directory_with_module(self): from repoze.bfg.zcml import _override @@ -1181,7 +1179,7 @@ class TestResourceDirective(unittest.TestCase): self.assertEqual(action['callable'], _override) self.assertEqual(action['discriminator'], None) self.assertEqual(action['args'], - (IDummy, 'foo/', IDummy, '')) + (DummyModule, 'foo/', DummyModule, '')) def test_override_module_with_module(self): from repoze.bfg.zcml import _override @@ -1193,7 +1191,7 @@ class TestResourceDirective(unittest.TestCase): self.assertEqual(action['callable'], _override) self.assertEqual(action['discriminator'], None) self.assertEqual(action['args'], - (IDummy, '', IDummy, '')) + (DummyModule, '', DummyModule, '')) class Test_OverrideFunction(unittest.TestCase): def setUp(self): @@ -1559,7 +1557,8 @@ class TestRequestOnly(unittest.TestCase): self.assertTrue(self._callFUT(foo), True) class DummyModule: - __name__ = 'dummy' + __path__ = "foo" + __name__ = "dummy" class DummyModuleGrokker: def __init__(self): @@ -1592,7 +1591,7 @@ class DummyContext: ) def resolve(self, dottedname): - return IDummy + return DummyModule class Dummy: pass diff --git a/repoze/bfg/zcml.py b/repoze/bfg/zcml.py index e0c8d2e8e..dbc145149 100644 --- a/repoze/bfg/zcml.py +++ b/repoze/bfg/zcml.py @@ -1,3 +1,5 @@ +import os +import sys import inspect import types @@ -46,6 +48,8 @@ from repoze.bfg.security import ViewPermissionFactory from repoze.bfg.secpols import registerBBBAuthn +from repoze.bfg.static import find_package + from repoze.bfg.view import static as static_view import martian @@ -365,7 +369,11 @@ def static(_context, name, path, cache_max_age=3600): if ':' in path: package_name, path = path.split(':') else: - package_name = _context.resolve('.').__name__ + package_path = _context.resolve('.').__path__[0] + package_name = find_package(package_path) + if package_name is not None: + path = os.path.join(package_path, path) + path = path[len(sys.modules[package_name].__path__[0])+1:] view = static_view( path, cache_max_age=cache_max_age, package_name=package_name) |
