Merge pull request #431 from subyraman/test-client-v2
Add Flask-like `test_client` to replace `sanic_endpoint_test`
This commit is contained in:
		| @@ -1,51 +1,73 @@ | ||||
| # Testing | ||||
|  | ||||
| Sanic endpoints can be tested locally using the `sanic.utils` module, which | ||||
| Sanic endpoints can be tested locally using the `test_client` object, which | ||||
| depends on the additional [aiohttp](https://aiohttp.readthedocs.io/en/stable/) | ||||
| library. The `sanic_endpoint_test` function runs a local server, issues a | ||||
| configurable request to an endpoint, and returns the result. It takes the | ||||
| following arguments: | ||||
| library.  | ||||
|  | ||||
| - `app` An instance of a Sanic app. | ||||
| - `method` *(default `'get'`)* A string representing the HTTP method to use. | ||||
| - `uri` *(default `'/'`)* A string representing the endpoint to test. | ||||
| The `test_client` exposes `get`, `post`, `put`, `delete`, `patch`, `head` and `options` methods | ||||
| for you to run against your application. A simple example (using pytest) is like follows: | ||||
|  | ||||
| ```python | ||||
| # Import the Sanic app, usually created with Sanic(__name__) | ||||
| from external_server import app | ||||
|  | ||||
| def test_index_returns_200(): | ||||
|     request, response = app.test_client.get('/') | ||||
|     assert response.status == 200 | ||||
|  | ||||
| def test_index_put_not_allowed(): | ||||
|     request, response = app.test_client.put('/') | ||||
|     assert response.status == 405 | ||||
| ``` | ||||
|  | ||||
| Internally, each time you call one of the `test_client` methods, the Sanic app is run at `127.0.01:42101` and  | ||||
| your test request is executed against your application, using `aiohttp`.  | ||||
|  | ||||
| The `test_client` methods accept the following arguments and keyword arguments: | ||||
|  | ||||
| - `uri` *(default `'/'`)* A string representing the URI to test. | ||||
| - `gather_request` *(default `True`)* A boolean which determines whether the | ||||
|   original request will be returned by the function. If set to `True`, the | ||||
|   return value is a tuple of `(request, response)`, if `False` only the | ||||
|   response is returned. | ||||
| - `loop` *(default `None`)* The event loop to use. | ||||
| - `debug` *(default `False`)* A boolean which determines whether to run the | ||||
|   server in debug mode. | ||||
| - `server_kwargs` *(default `{}`) a dict of additional arguments to pass into `app.run` before the test request is run. | ||||
| - `debug` *(default `False`)* A boolean which determines whether to run the server in debug mode. | ||||
|  | ||||
| The function further takes the `*request_args` and `**request_kwargs`, which | ||||
| are passed directly to the aiohttp ClientSession request. For example, to | ||||
| supply data with a GET request, `method` would be `get` and the keyword | ||||
| argument `params={'value', 'key'}` would be supplied. More information about | ||||
| The function further takes the `*request_args` and `**request_kwargs`, which are passed directly to the aiohttp ClientSession request. | ||||
|  | ||||
| For example, to supply data to a GET request, you would do the following: | ||||
|  | ||||
| ```python | ||||
| def test_get_request_includes_data(): | ||||
|     params = {'key1': 'value1', 'key2': 'value2'} | ||||
|     request, response = app.test_client.get('/', params=params) | ||||
|     assert request.args.get('key1') == 'value1' | ||||
| ``` | ||||
|  | ||||
| And to supply data to a JSON POST request: | ||||
|  | ||||
| ```python | ||||
| def test_post_json_request_includes_data(): | ||||
|     data = {'key1': 'value1', 'key2': 'value2'} | ||||
|     request, response = app.test_client.post('/', data=json.dumps(data)) | ||||
|     assert request.json.get('key1') == 'value1' | ||||
| ``` | ||||
|  | ||||
|  | ||||
| More information about | ||||
| the available arguments to aiohttp can be found | ||||
| [in the documentation for ClientSession](https://aiohttp.readthedocs.io/en/stable/client_reference.html#client-session). | ||||
|  | ||||
| Below is a complete example of an endpoint test, | ||||
| using [pytest](http://doc.pytest.org/en/latest/). The test checks that the | ||||
| `/challenge` endpoint responds to a GET request with a supplied challenge | ||||
| string. | ||||
|  | ||||
| ```python | ||||
| import pytest | ||||
| import aiohttp | ||||
| ### Deprecated: `sanic_endpoint_test` | ||||
|  | ||||
| Prior to version 0.3.2, testing was provided through the `sanic_endpoint_test` method. This method will be deprecated in the next major version after 0.4.0; please use the `test_client` instead. | ||||
|  | ||||
| ``` | ||||
| from sanic.utils import sanic_endpoint_test | ||||
|  | ||||
| # Import the Sanic app, usually created with Sanic(__name__) | ||||
| from external_server import app | ||||
|  | ||||
| def test_endpoint_challenge(): | ||||
|     # Create the challenge data | ||||
|     request_data = {'challenge': 'dummy_challenge'} | ||||
|  | ||||
|     # Send the request to the endpoint, using the default `get` method | ||||
|     request, response = sanic_endpoint_test(app, | ||||
|                                             uri='/challenge', | ||||
|                                             params=request_data) | ||||
|  | ||||
|     # Assert that the server responds with the challenge string | ||||
|     assert response.text == request_data['challenge'] | ||||
| def test_index_returns_200(): | ||||
|     request, response = sanic_endpoint_test(app) | ||||
|     assert response.status == 200 | ||||
| ``` | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Eli Uriegas
					Eli Uriegas