本文整理匯總了Python中pulsar.apps.wsgi.Route類的典型用法代碼示例。如果您正苦於以下問題:Python Route類的具體用法?Python Route怎麽用?Python Route使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Route類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: testSplitLeaf
def testSplitLeaf(self):
r = Route('bla/foo/<id>/pluto/leaf')
p, l = r.split()
self.assertFalse(p.is_leaf)
self.assertTrue(l.is_leaf)
self.assertEqual(p.path, '/bla/foo/<id>/pluto/')
self.assertEqual(l.path, '/leaf')
示例2: testIntVariable
def testIntVariable(self):
r = Route('<int:id>/')
self.assertEqual(str(r), '/<int:id>/')
self.assertEqual(r.variables, set(['id']))
self.assertEqual(r.breadcrumbs, ((True, 'id'),))
self.assertEqual(r.match('35/'), {'id': 35})
self.assertEqual(r.url(id=1), '/1/')
self.assertRaises(ValueError, r.url, id='bla')
示例3: testSplitDir
def testSplitDir(self):
r = Route('bla/foo/<id>/pluto/')
self.assertEqual(r.level, 4)
p, l = r.split()
self.assertFalse(p.is_leaf)
self.assertFalse(l.is_leaf)
self.assertEqual(p.path, '/bla/foo/<id>/')
self.assertEqual(l.path, '/pluto/')
示例4: testRoot
def testRoot(self):
r = Route('/')
self.assertFalse(r.is_leaf)
self.assertEqual(r.rule, '')
r = Route('////')
self.assertFalse(r.is_leaf)
self.assertEqual(r.rule, '')
self.assertEqual(r.match(''), {})
self.assertEqual(r.match('bee/'), {'__remaining__': 'bee/'})
示例5: testPathVaiable
def testPathVaiable(self):
r = Route('bla/<path:rest>', defaults={'rest': ''})
self.assertEqual(r.variables, set(['rest']))
self.assertEqual(r.level, 2)
self.assertTrue(r.is_leaf)
self.assertEqual(r.match('bla/a/b/c.html'), {'rest': 'a/b/c.html'})
self.assertEqual(r.match('bla/'), {'rest': ''})
self.assertEqual(r.url(rest='a/'), '/bla/a/')
self.assertEqual(r.url(), '/bla/')
示例6: testSimple
def testSimple(self):
r = Route('bla/')
self.assertFalse(r.is_leaf)
self.assertEqual(r.level,1)
self.assertEqual(len(r.variables), 0)
self.assertEqual(r.rule,'bla/')
self.assertEqual(r.match('bla/'),{})
self.assertEqual(r.match('bladdd/'),None)
self.assertEqual(r.match('bla/another/'), {'__remaining__':'another/'})
示例7: testStringVariable
def testStringVariable(self):
r = Route('<name>/')
self.assertFalse(r.is_leaf)
self.assertEqual(r.variables, set(['name']))
self.assertEqual(r.breadcrumbs, ((True, 'name'),))
self.assertEqual(r.rule, '<name>/')
self.assertEqual(r.match('bla-foo/'), {'name': 'bla-foo'})
self.assertEqual(r.match('bla/another/'),
{'name': 'bla', '__remaining__': 'another/'})
self.assertEqual(r.url(name='luca'), '/luca/')
示例8: test2StringVariables
def test2StringVariables(self):
r = Route('<name>/<child>/')
self.assertFalse(r.is_leaf)
self.assertEqual(r.level, 2)
self.assertEqual(r.variables, set(['name', 'child']))
self.assertEqual(r.breadcrumbs, ((True, 'name'), (True, 'child')))
self.assertEqual(r.rule, '<name>/<child>/')
self.assertEqual(r.match('bla/foo/'), {'name': 'bla', 'child': 'foo'})
self.assertEqual(r.match('bla/foo/another/'),
{'name': 'bla',
'child': 'foo',
'__remaining__': 'another/'})
self.assertRaises(KeyError, r.url, name='luca')
self.assertEqual(r.url(name='luca', child='joshua'), '/luca/joshua/')
示例9: testIntVariableFixDigits
def testIntVariableFixDigits(self):
r = Route('<int(2):id>/')
self.assertEqual(str(r),'/<int(2):id>/')
self.assertEqual(r.variables, set(['id']))
self.assertEqual(r.breadcrumbs, ((True,'id'),))
self.assertEqual(r.match('35/'),{'id':35})
self.assertEqual(r.match('355/'),None)
self.assertEqual(r.match('6/'),None)
self.assertEqual(r.match('ch/'),None)
self.assertEqual(r.url(id = 13), '/13/')
self.assertEqual(r.url(id = 1), '/01/')
self.assertRaises(ValueError,lambda : r.url(id = 134))
self.assertRaises(ValueError,lambda : r.url(id = 'bl'))
self.assertRaises(ValueError,lambda : r.url(id = 'bla'))
示例10: testIntVariableMinMax
def testIntVariableMinMax(self):
r = Route('<int(min=1):cid>/')
self.assertEqual(str(r),'/<int(min=1):cid>/')
self.assertEqual(r.variables, set(['cid']))
self.assertEqual(r.breadcrumbs,((True,'cid'),))
self.assertEqual(r.match('1/'),{'cid':1})
self.assertEqual(r.match('476876/'),{'cid':476876})
self.assertEqual(r.match('0/'),None)
self.assertEqual(r.match('-5/'),None)
self.assertEqual(r.url(cid = 13), '/13/')
self.assertEqual(r.url(cid = 1), '/1/')
self.assertRaises(ValueError,lambda : r.url(cid = 0))
self.assertRaises(ValueError,lambda : r.url(cid = -10))
self.assertRaises(ValueError,lambda : r.url(cid = 'bla'))
示例11: page
def page(self, path):
'''Obtain a page object from a path
'''
key = self.cache_key()
try:
sitemap = self.app.cache_server.get_json(key)
assert isinstance(sitemap, list)
except Exception:
sitemap = None
if not sitemap:
sitemap = self.build_map()
self.app.cache_server.set_json(key, sitemap)
for page in sitemap:
route = Route(page['path'])
if route.match(path):
return page
示例12: match
def match(self, path, sitemap=None):
'''Match a path with a page form ``sitemap``
If no sitemap is given, use the default sitemap
form the :meth:`site_map` method.
If no page is matched returns Nothing.
'''
if sitemap is None:
sitemap = self.site_map(self.app)
for page in sitemap:
route = Route(page['path'])
if isinstance(path, Route):
if path == route:
return page
else:
matched = route.match(path)
if matched is not None and '__remaining__' not in matched:
return page
示例13: Proxy
class Proxy(LocalMixin):
'''Proxy requests to another server
'''
def __init__(self, route, url):
self.route = Route(route)
self.url = url
@local_property
def http_client(self):
'''The :class:`.HttpClient` used by this proxy middleware for
accessing upstream resources'''
return HttpClient(decompress=False, store_cookies=False)
def __call__(self, environ, start_response):
request = wsgi_request(environ)
path = request.path
match = self.route.match(path[1:])
if match is not None:
query = request.get('QUERY_STRING', '')
path = urljoin(self.url, match.pop('__remaining__', ''))
if query:
path = '%s?%s' % (path, query)
return self._call(request, path, start_response)
@task
def _call(self, request, path, start_response):
data, files = yield from as_coroutine(request.data_and_files())
response = yield from self.http_client.request(
request.method, path, data=data, files=files,
headers=self.request_headers(request.environ),
version=request.get('SERVER_PROTOCOL'))
response.raise_for_status()
start_response(response.get_status(), list(response.headers))
return [response.get_content()]
def request_headers(self, environ):
'''Fill request headers from the environ dictionary and
modify them via the list of :attr:`headers_middleware`.
The returned headers will be sent to the target uri.
'''
headers = Headers(kind='client')
for k in environ:
if k.startswith('HTTP_'):
head = k[5:].replace('_', '-')
headers[head] = environ[k]
for head in ENVIRON_HEADERS:
k = head.replace('-', '_').upper()
v = environ.get(k)
if v:
headers[head] = v
return headers
示例14: __init__
def __init__(self, app, name, spec, spec_path, url, jwt=None, cors=True):
self.init_app(app)
if name == '*':
name = ''
self.spec = spec
self.route = Route('%s/<path:path>' % name)
self.url = url
self.jwt = jwt
self.cors = cors
self.registry = {}
self._spec_path = spec_path
self._router = [Specification(spec_path, api=self)]
self.spec.add_schema(ErrorSchema)
self.spec.add_schema(ErrorMessageSchema)
示例15: testSplitRoot
def testSplitRoot(self):
r = Route('')
self.assertEqual(r.level, 0)
p, l = r.split()
self.assertFalse(p.is_leaf)
self.assertEqual(p.path, '/')
self.assertEqual(l, None)
r = Route('bla')
p, l = r.split()
self.assertFalse(p.is_leaf)
self.assertTrue(l.is_leaf)
self.assertEqual(p.path, '/')
self.assertEqual(l.path, '/bla')
r = Route('bla/')
p, l = r.split()
self.assertFalse(p.is_leaf)
self.assertFalse(l.is_leaf)
self.assertEqual(p.path, '/')
self.assertEqual(l.path, '/bla/')