2016-12-23 00:08:04 +00:00
# Testing
2017-02-14 19:51:20 +00:00
Sanic endpoints can be tested locally using the `test_client` object, which
2016-12-23 00:08:04 +00:00
depends on the additional [aiohttp ](https://aiohttp.readthedocs.io/en/stable/ )
2017-02-14 19:51:20 +00:00
library.
2016-12-23 00:08:04 +00:00
2017-02-14 19:51:20 +00:00
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.
2016-12-23 00:08:04 +00:00
- `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.
2017-02-14 19:51:20 +00:00
- `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.
2016-12-23 00:08:04 +00:00
2017-02-14 19:51:20 +00:00
The function further takes the `*request_args` and `**request_kwargs` , which are passed directly to the aiohttp ClientSession request.
2016-12-23 00:08:04 +00:00
2017-02-14 19:51:20 +00:00
For example, to supply data to a GET request, you would do the following:
2016-12-23 00:08:04 +00:00
```python
2017-02-14 19:51:20 +00:00
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'
```
2016-12-23 00:08:04 +00:00
2017-02-14 19:51:20 +00:00
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 ).
2016-12-23 00:08:04 +00:00
2017-02-14 19:51:20 +00:00
### Deprecated: `sanic_endpoint_test`
2017-02-14 20:16:58 +00:00
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.
2016-12-23 00:08:04 +00:00
```
2017-02-14 19:51:20 +00:00
from sanic.utils import sanic_endpoint_test
def test_index_returns_200():
request, response = sanic_endpoint_test(app)
assert response.status == 200
```