mirror of https://github.com/tiangolo/fastapi.git
✅ Simplify tests for `dependency_testing` (#13223)
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Alejandra <90076947+alejsdev@users.noreply.github.com>
This commit is contained in:
parent
540d8ff398
commit
1e6d95ce6d
|
|
@ -1,25 +1,48 @@
|
||||||
from docs_src.dependency_testing.tutorial001 import (
|
import importlib
|
||||||
app,
|
from types import ModuleType
|
||||||
client,
|
|
||||||
test_override_in_items,
|
import pytest
|
||||||
test_override_in_items_with_params,
|
|
||||||
test_override_in_items_with_q,
|
from ...utils import needs_py39, needs_py310
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(
|
||||||
|
name="test_module",
|
||||||
|
params=[
|
||||||
|
"tutorial001",
|
||||||
|
pytest.param("tutorial001_py310", marks=needs_py310),
|
||||||
|
"tutorial001_an",
|
||||||
|
pytest.param("tutorial001_an_py39", marks=needs_py39),
|
||||||
|
pytest.param("tutorial001_an_py310", marks=needs_py310),
|
||||||
|
],
|
||||||
)
|
)
|
||||||
|
def get_test_module(request: pytest.FixtureRequest) -> ModuleType:
|
||||||
|
mod: ModuleType = importlib.import_module(
|
||||||
|
f"docs_src.dependency_testing.{request.param}"
|
||||||
|
)
|
||||||
|
return mod
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_items_run():
|
def test_override_in_items_run(test_module: ModuleType):
|
||||||
|
test_override_in_items = test_module.test_override_in_items
|
||||||
|
|
||||||
test_override_in_items()
|
test_override_in_items()
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_items_with_q_run():
|
def test_override_in_items_with_q_run(test_module: ModuleType):
|
||||||
|
test_override_in_items_with_q = test_module.test_override_in_items_with_q
|
||||||
|
|
||||||
test_override_in_items_with_q()
|
test_override_in_items_with_q()
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_items_with_params_run():
|
def test_override_in_items_with_params_run(test_module: ModuleType):
|
||||||
|
test_override_in_items_with_params = test_module.test_override_in_items_with_params
|
||||||
|
|
||||||
test_override_in_items_with_params()
|
test_override_in_items_with_params()
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_users():
|
def test_override_in_users(test_module: ModuleType):
|
||||||
|
client = test_module.client
|
||||||
response = client.get("/users/")
|
response = client.get("/users/")
|
||||||
assert response.status_code == 200, response.text
|
assert response.status_code == 200, response.text
|
||||||
assert response.json() == {
|
assert response.json() == {
|
||||||
|
|
@ -28,7 +51,8 @@ def test_override_in_users():
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_users_with_q():
|
def test_override_in_users_with_q(test_module: ModuleType):
|
||||||
|
client = test_module.client
|
||||||
response = client.get("/users/?q=foo")
|
response = client.get("/users/?q=foo")
|
||||||
assert response.status_code == 200, response.text
|
assert response.status_code == 200, response.text
|
||||||
assert response.json() == {
|
assert response.json() == {
|
||||||
|
|
@ -37,7 +61,8 @@ def test_override_in_users_with_q():
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_users_with_params():
|
def test_override_in_users_with_params(test_module: ModuleType):
|
||||||
|
client = test_module.client
|
||||||
response = client.get("/users/?q=foo&skip=100&limit=200")
|
response = client.get("/users/?q=foo&skip=100&limit=200")
|
||||||
assert response.status_code == 200, response.text
|
assert response.status_code == 200, response.text
|
||||||
assert response.json() == {
|
assert response.json() == {
|
||||||
|
|
@ -46,7 +71,9 @@ def test_override_in_users_with_params():
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
def test_normal_app():
|
def test_normal_app(test_module: ModuleType):
|
||||||
|
app = test_module.app
|
||||||
|
client = test_module.client
|
||||||
app.dependency_overrides = None
|
app.dependency_overrides = None
|
||||||
response = client.get("/items/?q=foo&skip=100&limit=200")
|
response = client.get("/items/?q=foo&skip=100&limit=200")
|
||||||
assert response.status_code == 200, response.text
|
assert response.status_code == 200, response.text
|
||||||
|
|
|
||||||
|
|
@ -1,56 +0,0 @@
|
||||||
from docs_src.dependency_testing.tutorial001_an import (
|
|
||||||
app,
|
|
||||||
client,
|
|
||||||
test_override_in_items,
|
|
||||||
test_override_in_items_with_params,
|
|
||||||
test_override_in_items_with_q,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_items_run():
|
|
||||||
test_override_in_items()
|
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_items_with_q_run():
|
|
||||||
test_override_in_items_with_q()
|
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_items_with_params_run():
|
|
||||||
test_override_in_items_with_params()
|
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_users():
|
|
||||||
response = client.get("/users/")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": None, "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_users_with_q():
|
|
||||||
response = client.get("/users/?q=foo")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": "foo", "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
def test_override_in_users_with_params():
|
|
||||||
response = client.get("/users/?q=foo&skip=100&limit=200")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": "foo", "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
def test_normal_app():
|
|
||||||
app.dependency_overrides = None
|
|
||||||
response = client.get("/items/?q=foo&skip=100&limit=200")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Items!",
|
|
||||||
"params": {"q": "foo", "skip": 100, "limit": 200},
|
|
||||||
}
|
|
||||||
|
|
@ -1,75 +0,0 @@
|
||||||
from ...utils import needs_py310
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_items_run():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py310 import test_override_in_items
|
|
||||||
|
|
||||||
test_override_in_items()
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_items_with_q_run():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py310 import (
|
|
||||||
test_override_in_items_with_q,
|
|
||||||
)
|
|
||||||
|
|
||||||
test_override_in_items_with_q()
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_items_with_params_run():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py310 import (
|
|
||||||
test_override_in_items_with_params,
|
|
||||||
)
|
|
||||||
|
|
||||||
test_override_in_items_with_params()
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_users():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py310 import client
|
|
||||||
|
|
||||||
response = client.get("/users/")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": None, "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_users_with_q():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py310 import client
|
|
||||||
|
|
||||||
response = client.get("/users/?q=foo")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": "foo", "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_users_with_params():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py310 import client
|
|
||||||
|
|
||||||
response = client.get("/users/?q=foo&skip=100&limit=200")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": "foo", "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_normal_app():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py310 import app, client
|
|
||||||
|
|
||||||
app.dependency_overrides = None
|
|
||||||
response = client.get("/items/?q=foo&skip=100&limit=200")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Items!",
|
|
||||||
"params": {"q": "foo", "skip": 100, "limit": 200},
|
|
||||||
}
|
|
||||||
|
|
@ -1,75 +0,0 @@
|
||||||
from ...utils import needs_py39
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py39
|
|
||||||
def test_override_in_items_run():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py39 import test_override_in_items
|
|
||||||
|
|
||||||
test_override_in_items()
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py39
|
|
||||||
def test_override_in_items_with_q_run():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py39 import (
|
|
||||||
test_override_in_items_with_q,
|
|
||||||
)
|
|
||||||
|
|
||||||
test_override_in_items_with_q()
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py39
|
|
||||||
def test_override_in_items_with_params_run():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py39 import (
|
|
||||||
test_override_in_items_with_params,
|
|
||||||
)
|
|
||||||
|
|
||||||
test_override_in_items_with_params()
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py39
|
|
||||||
def test_override_in_users():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py39 import client
|
|
||||||
|
|
||||||
response = client.get("/users/")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": None, "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py39
|
|
||||||
def test_override_in_users_with_q():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py39 import client
|
|
||||||
|
|
||||||
response = client.get("/users/?q=foo")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": "foo", "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py39
|
|
||||||
def test_override_in_users_with_params():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py39 import client
|
|
||||||
|
|
||||||
response = client.get("/users/?q=foo&skip=100&limit=200")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": "foo", "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py39
|
|
||||||
def test_normal_app():
|
|
||||||
from docs_src.dependency_testing.tutorial001_an_py39 import app, client
|
|
||||||
|
|
||||||
app.dependency_overrides = None
|
|
||||||
response = client.get("/items/?q=foo&skip=100&limit=200")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Items!",
|
|
||||||
"params": {"q": "foo", "skip": 100, "limit": 200},
|
|
||||||
}
|
|
||||||
|
|
@ -1,75 +0,0 @@
|
||||||
from ...utils import needs_py310
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_items_run():
|
|
||||||
from docs_src.dependency_testing.tutorial001_py310 import test_override_in_items
|
|
||||||
|
|
||||||
test_override_in_items()
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_items_with_q_run():
|
|
||||||
from docs_src.dependency_testing.tutorial001_py310 import (
|
|
||||||
test_override_in_items_with_q,
|
|
||||||
)
|
|
||||||
|
|
||||||
test_override_in_items_with_q()
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_items_with_params_run():
|
|
||||||
from docs_src.dependency_testing.tutorial001_py310 import (
|
|
||||||
test_override_in_items_with_params,
|
|
||||||
)
|
|
||||||
|
|
||||||
test_override_in_items_with_params()
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_users():
|
|
||||||
from docs_src.dependency_testing.tutorial001_py310 import client
|
|
||||||
|
|
||||||
response = client.get("/users/")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": None, "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_users_with_q():
|
|
||||||
from docs_src.dependency_testing.tutorial001_py310 import client
|
|
||||||
|
|
||||||
response = client.get("/users/?q=foo")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": "foo", "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_override_in_users_with_params():
|
|
||||||
from docs_src.dependency_testing.tutorial001_py310 import client
|
|
||||||
|
|
||||||
response = client.get("/users/?q=foo&skip=100&limit=200")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Users!",
|
|
||||||
"params": {"q": "foo", "skip": 5, "limit": 10},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@needs_py310
|
|
||||||
def test_normal_app():
|
|
||||||
from docs_src.dependency_testing.tutorial001_py310 import app, client
|
|
||||||
|
|
||||||
app.dependency_overrides = None
|
|
||||||
response = client.get("/items/?q=foo&skip=100&limit=200")
|
|
||||||
assert response.status_code == 200, response.text
|
|
||||||
assert response.json() == {
|
|
||||||
"message": "Hello Items!",
|
|
||||||
"params": {"q": "foo", "skip": 100, "limit": 200},
|
|
||||||
}
|
|
||||||
Loading…
Reference in New Issue