diff options
Diffstat (limited to 'tests/fake_packages')
7 files changed, 140 insertions, 0 deletions
diff --git a/tests/fake_packages/FakeApp.egg/FakeApp.egg-info/PKG-INFO b/tests/fake_packages/FakeApp.egg/FakeApp.egg-info/PKG-INFO new file mode 100644 index 0000000..a2a1137 --- /dev/null +++ b/tests/fake_packages/FakeApp.egg/FakeApp.egg-info/PKG-INFO @@ -0,0 +1,10 @@ +Metadata-Version: 1.0 +Name: FakeApp +Version: 1.0 +Summary: UNKNOWN +Home-page: UNKNOWN +Author: UNKNOWN +Author-email: UNKNOWN +License: UNKNOWN +Description: UNKNOWN +Platform: UNKNOWN diff --git a/tests/fake_packages/FakeApp.egg/FakeApp.egg-info/entry_points.txt b/tests/fake_packages/FakeApp.egg/FakeApp.egg-info/entry_points.txt new file mode 100644 index 0000000..9bfc986 --- /dev/null +++ b/tests/fake_packages/FakeApp.egg/FakeApp.egg-info/entry_points.txt @@ -0,0 +1,22 @@ +[paste.app_factory] + + basic_app=fakeapp.apps:make_basic_app + other=fakeapp.apps:make_basic_app2 + configed=fakeapp.configapps:SimpleApp.make_app + + +[paste.composit_factory] + + remote_addr=fakeapp.apps:make_remote_addr + + +[paste.filter_app_factory] + + caps2=fakeapp.apps:CapFilter + + +[paste.filter_factory] + + caps=fakeapp.apps:make_cap_filter + + diff --git a/tests/fake_packages/FakeApp.egg/FakeApp.egg-info/top_level.txt b/tests/fake_packages/FakeApp.egg/FakeApp.egg-info/top_level.txt new file mode 100644 index 0000000..79ed67a --- /dev/null +++ b/tests/fake_packages/FakeApp.egg/FakeApp.egg-info/top_level.txt @@ -0,0 +1 @@ +fakeapp diff --git a/tests/fake_packages/FakeApp.egg/fakeapp/__init__.py b/tests/fake_packages/FakeApp.egg/fakeapp/__init__.py new file mode 100644 index 0000000..792d600 --- /dev/null +++ b/tests/fake_packages/FakeApp.egg/fakeapp/__init__.py @@ -0,0 +1 @@ +# diff --git a/tests/fake_packages/FakeApp.egg/fakeapp/apps.py b/tests/fake_packages/FakeApp.egg/fakeapp/apps.py new file mode 100644 index 0000000..cae7eba --- /dev/null +++ b/tests/fake_packages/FakeApp.egg/fakeapp/apps.py @@ -0,0 +1,69 @@ +############################################################ +## Apps +############################################################ + +def simple_app(response, environ, start_response): + start_response('200 OK', [('Content-type', 'text/html')]) + return ['This is ', response] + +def basic_app(environ, start_response): + return simple_app('basic app', environ, start_response) + +def make_basic_app(global_conf, **conf): + return basic_app + +def basic_app2(environ, start_response): + return simple_app('basic app2', environ, start_response) + +def make_basic_app2(global_conf, **conf): + return basic_app2 + +############################################################ +## Composits +############################################################ + +def make_remote_addr(loader, global_conf, **conf): + apps = {} + addrs = {} + for name, value in conf.items(): + if name.startswith('app.'): + apps[name[4:]] = loader.get_app(value, global_conf) + elif name.startswith('addr.'): + addrs[name[5:]] = value + dispatcher = RemoteAddrDispatch() + for name in apps: + dispatcher.map[addrs[name]] = apps[name] + return dispatcher + +class RemoteAddrDispatch(object): + def __init__(self, map=None): + self.map = map or {} + + def __call__(self, environ, start_response): + addr = environ['REMOTE_ADDR'] + app = self.map.get(addr) or self.map['0.0.0.0'] + return app(environ, start_response) + +############################################################ +## Filters +############################################################ + +def make_cap_filter(global_conf, method_to_call='upper'): + def cap_filter(app): + return CapFilter(app, global_conf, method_to_call) + return cap_filter + +class CapFilter(object): + + def __init__(self, app, global_conf, method_to_call='upper'): + self.app = app + self.method_to_call = method_to_call + self.global_conf = global_conf + + def __call__(self, environ, start_response): + app_iter = self.app(environ, start_response) + for item in app_iter: + yield getattr(item, self.method_to_call)() + if hasattr(app_iter, 'close'): + app_iter.close() + diff --git a/tests/fake_packages/FakeApp.egg/fakeapp/configapps.py b/tests/fake_packages/FakeApp.egg/fakeapp/configapps.py new file mode 100644 index 0000000..ef13182 --- /dev/null +++ b/tests/fake_packages/FakeApp.egg/fakeapp/configapps.py @@ -0,0 +1,14 @@ +class SimpleApp(object): + def __init__(self, global_conf, local_conf, name): + self.global_conf = global_conf + self.local_conf = local_conf + self.name = name + + def __call__(self, environ, start_response): + start_response('200 OK', [('Content-type', 'text/html')]) + return ['I am: ', name] + + def make_app(cls, global_conf, **conf): + return cls(global_conf, conf, 'basic') + make_app = classmethod(make_app) + diff --git a/tests/fake_packages/FakeApp.egg/setup.py b/tests/fake_packages/FakeApp.egg/setup.py new file mode 100644 index 0000000..854483e --- /dev/null +++ b/tests/fake_packages/FakeApp.egg/setup.py @@ -0,0 +1,23 @@ +from setuptools import setup, find_packages + +setup( + name="FakeApp", + version="1.0", + packages=find_packages(), + entry_points={ + 'paste.app_factory': """ + basic_app=fakeapp.apps:make_basic_app + other=fakeapp.apps:make_basic_app2 + configed=fakeapp.configapps:SimpleApp.make_app + """, + 'paste.composit_factory': """ + remote_addr=fakeapp.apps:make_remote_addr + """, + 'paste.filter_factory': """ + caps=fakeapp.apps:make_cap_filter + """, + 'paste.filter_app_factory': """ + caps2=fakeapp.apps:CapFilter + """, + }, + ) |