summaryrefslogtreecommitdiff
path: root/tests/fake_packages/FakeApp.egg
diff options
context:
space:
mode:
Diffstat (limited to 'tests/fake_packages/FakeApp.egg')
-rw-r--r--tests/fake_packages/FakeApp.egg/FakeApp.egg-info/PKG-INFO10
-rw-r--r--tests/fake_packages/FakeApp.egg/FakeApp.egg-info/entry_points.txt22
-rw-r--r--tests/fake_packages/FakeApp.egg/FakeApp.egg-info/top_level.txt1
-rw-r--r--tests/fake_packages/FakeApp.egg/fakeapp/__init__.py1
-rw-r--r--tests/fake_packages/FakeApp.egg/fakeapp/apps.py69
-rw-r--r--tests/fake_packages/FakeApp.egg/fakeapp/configapps.py14
-rw-r--r--tests/fake_packages/FakeApp.egg/setup.py23
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
+ """,
+ },
+ )