summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMalthe Borch <mborch@gmail.com>2009-08-27 10:26:12 +0000
committerMalthe Borch <mborch@gmail.com>2009-08-27 10:26:12 +0000
commit2234c998d4eb7672065fb02c4974c0535f409dca (patch)
tree3755d4bd9f8722b728bee92ec4741fc942e48134
parent3d1abbd5be1d1bc0f27e488059ccf7aaca225f31 (diff)
downloadpyramid-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.py21
-rw-r--r--repoze/bfg/tests/test_zcml.py35
-rw-r--r--repoze/bfg/zcml.py10
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)