Rebrand the Rust client crate (coven/ → hh/, package+binary "hack-house"), README, CLI strings, and branch (coven → hack-house). Gitea repo renamed cmd-chat → hack-house to match. Crypto/server logic unchanged; selftest + golden-vector test still green, binary is now `hack-house`. Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
101 lines
3.1 KiB
Plaintext
101 lines
3.1 KiB
Plaintext
Metadata-Version: 2.1
|
|
Name: sanic-testing
|
|
Version: 24.6.0
|
|
Summary: Core testing clients for Sanic
|
|
Home-page: https://github.com/sanic-org/sanic-testing/
|
|
Author: Adam Hopkins
|
|
Author-email: admhpkns@gmail.com
|
|
License: MIT
|
|
Platform: any
|
|
Classifier: Development Status :: 4 - Beta
|
|
Classifier: Environment :: Web Environment
|
|
Classifier: License :: OSI Approved :: MIT License
|
|
Classifier: Programming Language :: Python :: 3.8
|
|
Classifier: Programming Language :: Python :: 3.9
|
|
Classifier: Programming Language :: Python :: 3.10
|
|
Classifier: Programming Language :: Python :: 3.11
|
|
Classifier: Programming Language :: Python :: 3.12
|
|
Description-Content-Type: text/markdown
|
|
License-File: LICENSE
|
|
Requires-Dist: httpx >=0.18
|
|
Provides-Extra: dev
|
|
Requires-Dist: pytest ; extra == 'dev'
|
|
Requires-Dist: sanic >=22.12 ; extra == 'dev'
|
|
Requires-Dist: pytest-asyncio ; extra == 'dev'
|
|
Requires-Dist: setuptools ; (python_version > "3.11") and extra == 'dev'
|
|
|
|
# Sanic Core Test
|
|
|
|
This package is meant to be the core testing utility and clients for testing Sanic applications. It is mainly derived from `sanic.testing` which has (or will be) removed from the main Sanic repository in the future.
|
|
|
|
[Documentation](https://sanicframework.org/en/plugins/sanic-testing/getting-started.html)
|
|
|
|
## Getting Started
|
|
|
|
pip install sanic-testing
|
|
|
|
The package is meant to create an almost seemless transition. Therefore, after loading the package, it will attach itself to your Sanic instance and insert test clients.
|
|
|
|
```python
|
|
from sanic import Sanic
|
|
from sanic_testing import TestManager
|
|
|
|
sanic_app = Sanic(__name__)
|
|
TestManager(sanic_app)
|
|
```
|
|
|
|
This will provide access to both the sync (`sanic.test_client`) and async (`sanic.asgi_client`) clients. Both of these clients are also available directly on the `TestManager` instance.
|
|
|
|
## Writing a sync test
|
|
|
|
Testing should be pretty much the same as when the test client was inside Sanic core. The difference is just that you need to run `TestManager`.
|
|
|
|
```python
|
|
import pytest
|
|
|
|
@pytest.fixture
|
|
def app():
|
|
sanic_app = Sanic(__name__)
|
|
TestManager(sanic_app)
|
|
|
|
@sanic_app.get("/")
|
|
def basic(request):
|
|
return response.text("foo")
|
|
|
|
return sanic_app
|
|
|
|
def test_basic_test_client(app):
|
|
request, response = app.test_client.get("/")
|
|
|
|
assert response.body == b"foo"
|
|
assert response.status == 200
|
|
```
|
|
|
|
## Writing an async test
|
|
|
|
Testing of an async method is best done with `pytest-asyncio` installed. Again, the following test should look familiar to anyone that has used `asgi_client` in the Sanic core package before.
|
|
|
|
The main benefit of using the `asgi_client` is that it is able to reach inside your application, and execute your handlers without ever having to stand up a server or make a network call.
|
|
|
|
```python
|
|
import pytest
|
|
|
|
@pytest.fixture
|
|
def app():
|
|
sanic_app = Sanic(__name__)
|
|
TestManager(sanic_app)
|
|
|
|
@sanic_app.get("/")
|
|
def basic(request):
|
|
return response.text("foo")
|
|
|
|
return sanic_app
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_basic_asgi_client(app):
|
|
request, response = await app.asgi_client.get("/")
|
|
|
|
assert response.body == b"foo"
|
|
assert response.status == 200
|
|
```
|