diff --git a/tests/test_tutorial/test_body/test_tutorial001.py b/tests/test_tutorial/test_body/test_tutorial001.py index 7a07c0367..ee06de7ce 100644 --- a/tests/test_tutorial/test_body/test_tutorial001.py +++ b/tests/test_tutorial/test_body/test_tutorial001.py @@ -172,3 +172,9 @@ def test_post_body(path, body, expected_status, expected_response): response = client.post(path, json=body) assert response.status_code == expected_status assert response.json() == expected_response + + +def test_post_broken_body(): + response = client.post("/items/", data={"name": "Foo", "price": 50.5}) + assert response.status_code == 400 + assert response.json() == {"detail": "There was an error parsing the body"} diff --git a/tests/test_tutorial/test_request_files/test_tutorial001.py b/tests/test_tutorial/test_request_files/test_tutorial001.py index 1a59876b0..6e20dd911 100644 --- a/tests/test_tutorial/test_request_files/test_tutorial001.py +++ b/tests/test_tutorial/test_request_files/test_tutorial001.py @@ -110,11 +110,12 @@ def test_post_body_json(): assert response.json() == file_required -def test_multipart_request_files(tmpdir): +def test_post_file(tmpdir): path = os.path.join(tmpdir, "test.txt") with open(path, "wb") as file: file.write(b"") client = TestClient(app) response = client.post("/files/", files={"file": open(path, "rb")}) + assert response.status_code == 200 assert response.json() == {"file_size": 14} diff --git a/tests/test_tutorial/test_request_forms/test_tutorial001.py b/tests/test_tutorial/test_request_forms/test_tutorial001.py index 4e6ae457b..f80490df5 100644 --- a/tests/test_tutorial/test_request_forms/test_tutorial001.py +++ b/tests/test_tutorial/test_request_forms/test_tutorial001.py @@ -87,16 +87,6 @@ def test_openapi_scheme(): assert response.json() == openapi_schema -item_id_not_int = { - "detail": [ - { - "loc": ["path", "item_id"], - "msg": "value is not a valid integer", - "type": "type_error.integer", - } - ] -} - password_required = { "detail": [ { diff --git a/tests/test_tutorial/test_request_forms_and_files/__init__.py b/tests/test_tutorial/test_request_forms_and_files/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/tests/test_tutorial/test_request_forms_and_files/test_tutorial001.py b/tests/test_tutorial/test_request_forms_and_files/test_tutorial001.py new file mode 100644 index 000000000..968bbe565 --- /dev/null +++ b/tests/test_tutorial/test_request_forms_and_files/test_tutorial001.py @@ -0,0 +1,166 @@ +import os + +from starlette.testclient import TestClient + +from request_forms_and_files.tutorial001 import app + +client = TestClient(app) + +openapi_schema = { + "openapi": "3.0.2", + "info": {"title": "Fast API", "version": "0.1.0"}, + "paths": { + "/files/": { + "post": { + "responses": { + "200": { + "description": "Successful Response", + "content": {"application/json": {"schema": {}}}, + }, + "422": { + "description": "Validation Error", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/HTTPValidationError" + } + } + }, + }, + }, + "summary": "Create File Post", + "operationId": "create_file_files__post", + "requestBody": { + "content": { + "multipart/form-data": { + "schema": {"$ref": "#/components/schemas/Body_create_file"} + } + }, + "required": True, + }, + } + } + }, + "components": { + "schemas": { + "Body_create_file": { + "title": "Body_create_file", + "required": ["file", "token"], + "type": "object", + "properties": { + "file": {"title": "File", "type": "string", "format": "binary"}, + "token": {"title": "Token", "type": "string"}, + }, + }, + "ValidationError": { + "title": "ValidationError", + "required": ["loc", "msg", "type"], + "type": "object", + "properties": { + "loc": { + "title": "Location", + "type": "array", + "items": {"type": "string"}, + }, + "msg": {"title": "Message", "type": "string"}, + "type": {"title": "Error Type", "type": "string"}, + }, + }, + "HTTPValidationError": { + "title": "HTTPValidationError", + "type": "object", + "properties": { + "detail": { + "title": "Detail", + "type": "array", + "items": {"$ref": "#/components/schemas/ValidationError"}, + } + }, + }, + } + }, +} + + +def test_openapi_scheme(): + response = client.get("/openapi.json") + assert response.status_code == 200 + assert response.json() == openapi_schema + + +file_required = { + "detail": [ + { + "loc": ["body", "file"], + "msg": "field required", + "type": "value_error.missing", + } + ] +} + +token_required = { + "detail": [ + { + "loc": ["body", "token"], + "msg": "field required", + "type": "value_error.missing", + } + ] +} + +file_and_token_required = { + "detail": [ + { + "loc": ["body", "file"], + "msg": "field required", + "type": "value_error.missing", + }, + { + "loc": ["body", "token"], + "msg": "field required", + "type": "value_error.missing", + }, + ] +} + + +def test_post_form_no_body(): + response = client.post("/files/") + assert response.status_code == 422 + assert response.json() == file_and_token_required + + +def test_post_form_no_file(): + response = client.post("/files/", data={"token": "foo"}) + assert response.status_code == 422 + assert response.json() == file_required + + +def test_post_body_json(): + response = client.post("/files/", json={"file": "Foo", "token": "Bar"}) + assert response.status_code == 422 + assert response.json() == file_and_token_required + + +def test_post_file_no_token(tmpdir): + path = os.path.join(tmpdir, "test.txt") + with open(path, "wb") as file: + file.write(b"") + + client = TestClient(app) + response = client.post("/files/", files={"file": open(path, "rb")}) + assert response.status_code == 422 + assert response.json() == token_required + + +def test_post_file_and_token(tmpdir): + path = os.path.join(tmpdir, "test.txt") + with open(path, "wb") as file: + file.write(b"") + + client = TestClient(app) + response = client.post( + "/files/", data={"token": "foo"}, files={"file": open(path, "rb")} + ) + assert response.status_code == 200 + assert response.json() == {"file_size": 14, "token": "foo"}