pythonasyncioapiasyncfastapiframeworkjsonjson-schemaopenapiopenapi3pydanticpython-typespython3redocreststarletteswaggerswagger-uiuvicornweb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
421 lines
11 KiB
421 lines
11 KiB
from dirty_equals import IsDict
|
|
from fastapi.testclient import TestClient
|
|
|
|
from .main import app
|
|
|
|
client = TestClient(app)
|
|
|
|
|
|
def test_query():
|
|
response = client.get("/query")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "missing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Field required",
|
|
"input": None,
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "field required",
|
|
"type": "value_error.missing",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_query_baz():
|
|
response = client.get("/query?query=baz")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar baz"
|
|
|
|
|
|
def test_query_not_declared_baz():
|
|
response = client.get("/query?not_declared=baz")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "missing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Field required",
|
|
"input": None,
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "field required",
|
|
"type": "value_error.missing",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_optional():
|
|
response = client.get("/query/optional")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar"
|
|
|
|
|
|
def test_query_optional_query_baz():
|
|
response = client.get("/query/optional?query=baz")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar baz"
|
|
|
|
|
|
def test_query_optional_not_declared_baz():
|
|
response = client.get("/query/optional?not_declared=baz")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar"
|
|
|
|
|
|
def test_query_int():
|
|
response = client.get("/query/int")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "missing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Field required",
|
|
"input": None,
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "field required",
|
|
"type": "value_error.missing",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_int_query_42():
|
|
response = client.get("/query/int?query=42")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar 42"
|
|
|
|
|
|
def test_query_int_query_42_5():
|
|
response = client.get("/query/int?query=42.5")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "int_parsing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Input should be a valid integer, unable to parse string as an integer",
|
|
"input": "42.5",
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "value is not a valid integer",
|
|
"type": "type_error.integer",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_int_query_baz():
|
|
response = client.get("/query/int?query=baz")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "int_parsing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Input should be a valid integer, unable to parse string as an integer",
|
|
"input": "baz",
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "value is not a valid integer",
|
|
"type": "type_error.integer",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_int_not_declared_baz():
|
|
response = client.get("/query/int?not_declared=baz")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "missing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Field required",
|
|
"input": None,
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "field required",
|
|
"type": "value_error.missing",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_int_optional():
|
|
response = client.get("/query/int/optional")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar"
|
|
|
|
|
|
def test_query_int_optional_query_50():
|
|
response = client.get("/query/int/optional?query=50")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar 50"
|
|
|
|
|
|
def test_query_int_optional_query_foo():
|
|
response = client.get("/query/int/optional?query=foo")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "int_parsing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Input should be a valid integer, unable to parse string as an integer",
|
|
"input": "foo",
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "value is not a valid integer",
|
|
"type": "type_error.integer",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_int_default():
|
|
response = client.get("/query/int/default")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar 10"
|
|
|
|
|
|
def test_query_int_default_query_50():
|
|
response = client.get("/query/int/default?query=50")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar 50"
|
|
|
|
|
|
def test_query_int_default_query_foo():
|
|
response = client.get("/query/int/default?query=foo")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "int_parsing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Input should be a valid integer, unable to parse string as an integer",
|
|
"input": "foo",
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "value is not a valid integer",
|
|
"type": "type_error.integer",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_param():
|
|
response = client.get("/query/param")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar"
|
|
|
|
|
|
def test_query_param_query_50():
|
|
response = client.get("/query/param?query=50")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar 50"
|
|
|
|
|
|
def test_query_param_required():
|
|
response = client.get("/query/param-required")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "missing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Field required",
|
|
"input": None,
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "field required",
|
|
"type": "value_error.missing",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_param_required_query_50():
|
|
response = client.get("/query/param-required?query=50")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar 50"
|
|
|
|
|
|
def test_query_param_required_int():
|
|
response = client.get("/query/param-required/int")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "missing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Field required",
|
|
"input": None,
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "field required",
|
|
"type": "value_error.missing",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_param_required_int_query_50():
|
|
response = client.get("/query/param-required/int?query=50")
|
|
assert response.status_code == 200
|
|
assert response.json() == "foo bar 50"
|
|
|
|
|
|
def test_query_param_required_int_query_foo():
|
|
response = client.get("/query/param-required/int?query=foo")
|
|
assert response.status_code == 422
|
|
assert response.json() == IsDict(
|
|
{
|
|
"detail": [
|
|
{
|
|
"type": "int_parsing",
|
|
"loc": ["query", "query"],
|
|
"msg": "Input should be a valid integer, unable to parse string as an integer",
|
|
"input": "foo",
|
|
}
|
|
]
|
|
}
|
|
) | IsDict(
|
|
# TODO: remove when deprecating Pydantic v1
|
|
{
|
|
"detail": [
|
|
{
|
|
"loc": ["query", "query"],
|
|
"msg": "value is not a valid integer",
|
|
"type": "type_error.integer",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
|
|
|
|
def test_query_frozenset_query_1_query_1_query_2():
|
|
response = client.get("/query/frozenset/?query=1&query=1&query=2")
|
|
assert response.status_code == 200
|
|
assert response.json() == "1,2"
|
|
|
|
|
|
def test_query_list():
|
|
response = client.get("/query/list/?device_ids=1&device_ids=2")
|
|
assert response.status_code == 200
|
|
assert response.json() == [1, 2]
|
|
|
|
|
|
def test_query_list_empty():
|
|
response = client.get("/query/list/")
|
|
assert response.status_code == 422
|
|
|
|
|
|
def test_query_list_default():
|
|
response = client.get("/query/list-default/?device_ids=1&device_ids=2")
|
|
assert response.status_code == 200
|
|
assert response.json() == [1, 2]
|
|
|
|
|
|
def test_query_list_default_empty():
|
|
response = client.get("/query/list-default/")
|
|
assert response.status_code == 200
|
|
assert response.json() == []
|
|
|