From 703ade7967cecdcd617189369144dae29a855476 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sebasti=C3=A1n=20Ram=C3=ADrez?= Date: Wed, 29 May 2019 13:34:46 +0400 Subject: [PATCH] :bug: Fix path in path parameters (#272) --- docs/src/path_params/tutorial004.py | 8 ++ fastapi/routing.py | 5 +- .../test_path_params/__init__.py | 0 .../test_path_params/test_tutorial004.py | 91 +++++++++++++++++++ 4 files changed, 102 insertions(+), 2 deletions(-) create mode 100644 docs/src/path_params/tutorial004.py create mode 100644 tests/test_tutorial/test_path_params/__init__.py create mode 100644 tests/test_tutorial/test_path_params/test_tutorial004.py diff --git a/docs/src/path_params/tutorial004.py b/docs/src/path_params/tutorial004.py new file mode 100644 index 000000000..76adf3821 --- /dev/null +++ b/docs/src/path_params/tutorial004.py @@ -0,0 +1,8 @@ +from fastapi import FastAPI + +app = FastAPI() + + +@app.get("/files/{file_path:path}") +async def read_user_me(file_path: str): + return {"file_path": file_path} diff --git a/fastapi/routing.py b/fastapi/routing.py index 4e5342c8d..b35a5f45d 100644 --- a/fastapi/routing.py +++ b/fastapi/routing.py @@ -255,10 +255,11 @@ class APIRoute(routing.Route): assert inspect.isfunction(endpoint) or inspect.ismethod( endpoint ), f"An endpoint must be a function or method" - self.dependant = get_dependant(path=path, call=self.endpoint) + self.dependant = get_dependant(path=self.path_format, call=self.endpoint) for depends in self.dependencies[::-1]: self.dependant.dependencies.insert( - 0, get_parameterless_sub_dependant(depends=depends, path=path) + 0, + get_parameterless_sub_dependant(depends=depends, path=self.path_format), ) self.body_field = get_body_field(dependant=self.dependant, name=self.name) self.app = request_response( diff --git a/tests/test_tutorial/test_path_params/__init__.py b/tests/test_tutorial/test_path_params/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/tests/test_tutorial/test_path_params/test_tutorial004.py b/tests/test_tutorial/test_path_params/test_tutorial004.py new file mode 100644 index 000000000..e4590db7b --- /dev/null +++ b/tests/test_tutorial/test_path_params/test_tutorial004.py @@ -0,0 +1,91 @@ +from starlette.testclient import TestClient + +from path_params.tutorial004 import app + +client = TestClient(app) + +openapi_schema = { + "openapi": "3.0.2", + "info": {"title": "Fast API", "version": "0.1.0"}, + "paths": { + "/files/{file_path}": { + "get": { + "responses": { + "200": { + "description": "Successful Response", + "content": {"application/json": {"schema": {}}}, + }, + "422": { + "description": "Validation Error", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/HTTPValidationError" + } + } + }, + }, + }, + "summary": "Read User Me", + "operationId": "read_user_me_files__file_path__get", + "parameters": [ + { + "required": True, + "schema": {"title": "File_Path", "type": "string"}, + "name": "file_path", + "in": "path", + } + ], + } + } + }, + "components": { + "schemas": { + "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(): + response = client.get("/openapi.json") + assert response.status_code == 200 + assert response.json() == openapi_schema + + +def test_file_path(): + response = client.get("/files/home/johndoe/myfile.txt") + print(response.content) + assert response.status_code == 200 + assert response.json() == {"file_path": "home/johndoe/myfile.txt"} + + +def test_root_file_path(): + response = client.get("/files//home/johndoe/myfile.txt") + print(response.content) + assert response.status_code == 200 + assert response.json() == {"file_path": "/home/johndoe/myfile.txt"}