Coverage for docs_src/app_testing/app_b/main.py: 100%
25 statements
« prev ^ index » next coverage.py v7.6.1, created at 2025-12-04 08:29 +0000
« prev ^ index » next coverage.py v7.6.1, created at 2025-12-04 08:29 +0000
1from typing import Union 1abcdefg
3from fastapi import FastAPI, Header, HTTPException 1abcdefg
4from pydantic import BaseModel 1abcdefg
6fake_secret_token = "coneofsilence" 1abcdefg
8fake_db = { 1abcdefg
9 "foo": {"id": "foo", "title": "Foo", "description": "There goes my hero"},
10 "bar": {"id": "bar", "title": "Bar", "description": "The bartenders"},
11}
13app = FastAPI() 1abcdefg
16class Item(BaseModel): 1abcdefg
17 id: str 1abcdefg
18 title: str 1abcdefg
19 description: Union[str, None] = None 1abcdefg
22@app.get("/items/{item_id}", response_model=Item) 1abcdefg
23async def read_main(item_id: str, x_token: str = Header()): 1abcdefg
24 if x_token != fake_secret_token: 1hijklmn
25 raise HTTPException(status_code=400, detail="Invalid X-Token header") 1hijklmn
26 if item_id not in fake_db: 1hijklmn
27 raise HTTPException(status_code=404, detail="Item not found") 1hijklmn
28 return fake_db[item_id] 1hijklmn
31@app.post("/items/", response_model=Item) 1abcdefg
32async def create_item(item: Item, x_token: str = Header()): 1abcdefg
33 if x_token != fake_secret_token: 1hijklmn
34 raise HTTPException(status_code=400, detail="Invalid X-Token header") 1hijklmn
35 if item.id in fake_db: 1hijklmn
36 raise HTTPException(status_code=409, detail="Item already exists") 1hijklmn
37 fake_db[item.id] = item 1hijklmn
38 return item 1hijklmn