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.
		
		
		
		
		
			
		
			
				
					
					
						
							163 lines
						
					
					
						
							5.5 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							163 lines
						
					
					
						
							5.5 KiB
						
					
					
				| import pytest | |
| from dirty_equals import IsDict | |
| from fastapi import FastAPI, Query | |
| from fastapi.testclient import TestClient | |
| from typing_extensions import Annotated | |
| 
 | |
| from .utils import needs_py310 | |
| 
 | |
| 
 | |
| def get_client(): | |
|     app = FastAPI() | |
|     with pytest.warns(DeprecationWarning): | |
| 
 | |
|         @app.get("/items/") | |
|         async def read_items( | |
|             q: Annotated[str | None, Query(regex="^fixedquery$")] = None, | |
|         ): | |
|             if q: | |
|                 return f"Hello {q}" | |
|             else: | |
|                 return "Hello World" | |
| 
 | |
|     client = TestClient(app) | |
|     return client | |
| 
 | |
| 
 | |
| @needs_py310 | |
| def test_query_params_str_validations_no_query(): | |
|     client = get_client() | |
|     response = client.get("/items/") | |
|     assert response.status_code == 200 | |
|     assert response.json() == "Hello World" | |
| 
 | |
| 
 | |
| @needs_py310 | |
| def test_query_params_str_validations_q_fixedquery(): | |
|     client = get_client() | |
|     response = client.get("/items/", params={"q": "fixedquery"}) | |
|     assert response.status_code == 200 | |
|     assert response.json() == "Hello fixedquery" | |
| 
 | |
| 
 | |
| @needs_py310 | |
| def test_query_params_str_validations_item_query_nonregexquery(): | |
|     client = get_client() | |
|     response = client.get("/items/", params={"q": "nonregexquery"}) | |
|     assert response.status_code == 422 | |
|     assert response.json() == IsDict( | |
|         { | |
|             "detail": [ | |
|                 { | |
|                     "type": "string_pattern_mismatch", | |
|                     "loc": ["query", "q"], | |
|                     "msg": "String should match pattern '^fixedquery$'", | |
|                     "input": "nonregexquery", | |
|                     "ctx": {"pattern": "^fixedquery$"}, | |
|                 } | |
|             ] | |
|         } | |
|     ) | IsDict( | |
|         # TODO: remove when deprecating Pydantic v1 | |
|         { | |
|             "detail": [ | |
|                 { | |
|                     "ctx": {"pattern": "^fixedquery$"}, | |
|                     "loc": ["query", "q"], | |
|                     "msg": 'string does not match regex "^fixedquery$"', | |
|                     "type": "value_error.str.regex", | |
|                 } | |
|             ] | |
|         } | |
|     ) | |
| 
 | |
| 
 | |
| @needs_py310 | |
| def test_openapi_schema(): | |
|     client = get_client() | |
|     response = client.get("/openapi.json") | |
|     assert response.status_code == 200, response.text | |
|     # insert_assert(response.json()) | |
|     assert response.json() == { | |
|         "openapi": "3.1.0", | |
|         "info": {"title": "FastAPI", "version": "0.1.0"}, | |
|         "paths": { | |
|             "/items/": { | |
|                 "get": { | |
|                     "summary": "Read Items", | |
|                     "operationId": "read_items_items__get", | |
|                     "parameters": [ | |
|                         { | |
|                             "name": "q", | |
|                             "in": "query", | |
|                             "required": False, | |
|                             "schema": IsDict( | |
|                                 { | |
|                                     "anyOf": [ | |
|                                         {"type": "string", "pattern": "^fixedquery$"}, | |
|                                         {"type": "null"}, | |
|                                     ], | |
|                                     "title": "Q", | |
|                                 } | |
|                             ) | |
|                             | IsDict( | |
|                                 # TODO: remove when deprecating Pydantic v1 | |
|                                 { | |
|                                     "type": "string", | |
|                                     "pattern": "^fixedquery$", | |
|                                     "title": "Q", | |
|                                 } | |
|                             ), | |
|                         } | |
|                     ], | |
|                     "responses": { | |
|                         "200": { | |
|                             "description": "Successful Response", | |
|                             "content": {"application/json": {"schema": {}}}, | |
|                         }, | |
|                         "422": { | |
|                             "description": "Validation Error", | |
|                             "content": { | |
|                                 "application/json": { | |
|                                     "schema": { | |
|                                         "$ref": "#/components/schemas/HTTPValidationError" | |
|                                     } | |
|                                 } | |
|                             }, | |
|                         }, | |
|                     }, | |
|                 } | |
|             } | |
|         }, | |
|         "components": { | |
|             "schemas": { | |
|                 "HTTPValidationError": { | |
|                     "properties": { | |
|                         "detail": { | |
|                             "items": {"$ref": "#/components/schemas/ValidationError"}, | |
|                             "type": "array", | |
|                             "title": "Detail", | |
|                         } | |
|                     }, | |
|                     "type": "object", | |
|                     "title": "HTTPValidationError", | |
|                 }, | |
|                 "ValidationError": { | |
|                     "properties": { | |
|                         "loc": { | |
|                             "items": { | |
|                                 "anyOf": [{"type": "string"}, {"type": "integer"}] | |
|                             }, | |
|                             "type": "array", | |
|                             "title": "Location", | |
|                         }, | |
|                         "msg": {"type": "string", "title": "Message"}, | |
|                         "type": {"type": "string", "title": "Error Type"}, | |
|                     }, | |
|                     "type": "object", | |
|                     "required": ["loc", "msg", "type"], | |
|                     "title": "ValidationError", | |
|                 }, | |
|             } | |
|         }, | |
|     }
 | |
| 
 |