本文整理匯總了Python中werkzeug.test.Client方法的典型用法代碼示例。如果您正苦於以下問題:Python test.Client方法的具體用法?Python test.Client怎麽用?Python test.Client使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類werkzeug.test
的用法示例。
在下文中一共展示了test.Client方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_basic
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def test_basic(sentry_init, crashing_app, capture_events):
sentry_init(send_default_pii=True)
app = SentryWsgiMiddleware(crashing_app)
client = Client(app)
events = capture_events()
with pytest.raises(ZeroDivisionError):
client.get("/")
(event,) = events
assert event["transaction"] == "generic WSGI request"
assert event["request"] == {
"env": {"SERVER_NAME": "localhost", "SERVER_PORT": "80"},
"headers": {"Host": "localhost"},
"method": "GET",
"query_string": "",
"url": "http://localhost/",
}
示例2: test_keyboard_interrupt_is_captured
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def test_keyboard_interrupt_is_captured(sentry_init, capture_events):
sentry_init(send_default_pii=True)
iterable = ExitingIterable(lambda: KeyboardInterrupt())
app = SentryWsgiMiddleware(IterableApp(iterable))
client = Client(app)
events = capture_events()
with pytest.raises(KeyboardInterrupt):
client.get("/")
(event,) = events
assert "exception" in event
exc = event["exception"]["values"][-1]
assert exc["type"] == "KeyboardInterrupt"
assert exc["value"] == ""
assert event["level"] == "error"
示例3: test_flow
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def test_flow(self, satosa_config_dict):
"""
Performs the test.
"""
test_client = Client(make_app(SATOSAConfig(satosa_config_dict)), BaseResponse)
# Make request to frontend
resp = test_client.get('/{}/{}/request'.format("backend", "frontend"))
assert resp.status == '200 OK'
headers = dict(resp.headers)
assert headers["Set-Cookie"]
# Fake response coming in to backend
resp = test_client.get('/{}/response'.format("backend"), headers=[("Cookie", headers["Set-Cookie"])])
assert resp.status == '200 OK'
assert resp.data.decode('utf-8') == "Auth response received, passed to test frontend"
示例4: test_full_path
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def test_full_path(self):
trace_id = trace_sdk.generate_trace_id()
# We need to use the Werkzeug test app because
# The headers are injected at the wsgi layer.
# The flask test app will not include these, and
# result in the values not propagated.
client = Client(self.app.wsgi_app, BaseResponse)
# emulate b3 headers
client.get(
"/",
headers={
"traceparent": "00-{:032x}-{:016x}-{:02x}".format(
trace_id,
trace_sdk.generate_span_id(),
trace.TraceFlags.SAMPLED,
)
},
)
# assert the http request header was propagated through.
prepared_request = self.send.call_args[0][1]
headers = prepared_request.headers
self.assertRegex(
headers["traceparent"],
r"00-{:032x}-[0-9a-f]{{16}}-01".format(trace_id),
)
示例5: test_uninstrument
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def test_uninstrument(self):
# pylint: disable=access-member-before-definition
resp = self.client.get("/hello/123")
self.assertEqual(200, resp.status_code)
self.assertEqual([b"Hello: 123"], list(resp.response))
span_list = self.memory_exporter.get_finished_spans()
self.assertEqual(len(span_list), 1)
FlaskInstrumentor().uninstrument()
self.app = flask.Flask(__name__)
self.app.route("/hello/<int:helloid>")(self._hello_endpoint)
# pylint: disable=attribute-defined-outside-init
self.client = Client(self.app, BaseResponse)
resp = self.client.get("/hello/123")
self.assertEqual(200, resp.status_code)
self.assertEqual([b"Hello: 123"], list(resp.response))
span_list = self.memory_exporter.get_finished_spans()
self.assertEqual(len(span_list), 1)
示例6: _common_initialization
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def _common_initialization(self, config):
# pylint: disable=unused-argument
def excluded_endpoint(request):
return Response("excluded")
# pylint: disable=unused-argument
def excluded2_endpoint(request):
return Response("excluded2")
config.add_route("hello", "/hello/{helloid}")
config.add_view(self._hello_endpoint, route_name="hello")
config.add_route("excluded_arg", "/excluded/{helloid}")
config.add_view(self._hello_endpoint, route_name="excluded_arg")
config.add_route("excluded", "/excluded_noarg")
config.add_view(excluded_endpoint, route_name="excluded")
config.add_route("excluded2", "/excluded_noarg2")
config.add_view(excluded2_endpoint, route_name="excluded2")
# pylint: disable=attribute-defined-outside-init
self.client = Client(config.make_wsgi_app(), BaseResponse)
示例7: make_request_and_maybe_assert_warn
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def make_request_and_maybe_assert_warn(
self, headers, expected_warn_substr,
):
@werkzeug.Request.application
def _simple_app(req):
return werkzeug.Response("OK", headers=headers)
app = security_validator.SecurityValidatorMiddleware(_simple_app)
server = werkzeug_test.Client(app, BaseResponse)
with mock.patch.object(logger, "warning") as mock_warn:
server.get("")
if expected_warn_substr is None:
mock_warn.assert_not_called()
else:
mock_warn.assert_called_with(_WARN_PREFIX + expected_warn_substr)
示例8: test_public_errors_serve_response
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def test_public_errors_serve_response(self):
@application._handling_errors
@wrappers.Request.application
def app(request):
raise errors.NotFoundError("no scalar data for run=foo, tag=bar")
server = werkzeug_test.Client(app, wrappers.BaseResponse)
response = server.get("/")
self.assertEqual(
response.get_data(),
b"Not found: no scalar data for run=foo, tag=bar",
)
self.assertEqual(response.status_code, 404)
self.assertStartsWith(
response.headers.get("Content-Type"), "text/plain"
)
示例9: setUp
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def setUp(self):
plugins = [
FakePlugin(plugin_name="foo"),
FakePlugin(
plugin_name="bar",
is_active_value=False,
element_name_value="tf-bar-dashboard",
),
FakePlugin(
plugin_name="baz",
routes_mapping={"/esmodule": lambda req: None,},
es_module_path_value="/esmodule",
),
]
app = application.TensorBoardWSGI(plugins, path_prefix=self.path_prefix)
self.server = werkzeug_test.Client(app, wrappers.BaseResponse)
示例10: setUp
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def setUp(self):
# pylint: disable=g-import-not-at-top
# Pre-import modules to patch them in advance.
from google.appengine.ext.vmruntime import vmconfig
# Instantiate an app with a simple fake configuration.
with patch.object(wsgi_config, 'get_module_config_filename'):
with patch.object(wsgi_config,
'get_module_config',
return_value=FAKE_APPINFO_EXTERNAL):
with patch.object(vmconfig,
'BuildVmAppengineEnvConfig',
return_value=FAKE_APPENGINE_CONFIG):
from vmruntime import wsgi
self.app = wsgi.meta_app
self.client = test.Client(self.app, wrappers.Response)
# Separate client for concurrent tests.
self.spare_client = test.Client(self.app, wrappers.Response)
# Clear the global event flags (only used in concurrency tests).
concurrent_request_is_started.clear()
concurrent_request_should_proceed.clear()
示例11: from_wsgi
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def from_wsgi(
schema_path: str,
app: Any,
base_url: Optional[str] = None,
method: Optional[Filter] = None,
endpoint: Optional[Filter] = None,
tag: Optional[Filter] = None,
operation_id: Optional[Filter] = None,
validate_schema: bool = True,
**kwargs: Any,
) -> BaseOpenAPISchema:
kwargs.setdefault("headers", {}).setdefault("User-Agent", USER_AGENT)
client = Client(app, WSGIResponse)
response = client.get(schema_path, **kwargs)
# Raising exception to provide unified behavior
# E.g. it will be handled in CLI - a proper error message will be shown
if 400 <= response.status_code < 600:
raise HTTPError(response=response, url=schema_path)
return from_file(
response.data,
location=schema_path,
base_url=base_url,
method=method,
endpoint=endpoint,
tag=tag,
operation_id=operation_id,
app=app,
validate_schema=validate_schema,
)
示例12: client
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def client():
return Client(application)
示例13: get_client
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def get_client(pyramid_config):
def inner():
return Client(pyramid_config.make_wsgi_app())
return inner
示例14: get_client
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def get_client(app):
def inner():
return Client(app)
return inner
示例15: test_systemexit_zero_is_ignored
# 需要導入模塊: from werkzeug import test [as 別名]
# 或者: from werkzeug.test import Client [as 別名]
def test_systemexit_zero_is_ignored(sentry_init, capture_events, request):
zero_code = request.param
sentry_init(send_default_pii=True)
iterable = ExitingIterable(lambda: SystemExit(zero_code))
app = SentryWsgiMiddleware(IterableApp(iterable))
client = Client(app)
events = capture_events()
with pytest.raises(SystemExit):
client.get("/")
assert len(events) == 0