committed by
GitHub
3 changed files with 59 additions and 2 deletions
@ -0,0 +1,53 @@ |
|||||
|
from typing import List |
||||
|
|
||||
|
from fastapi import FastAPI, Security |
||||
|
from fastapi.params import Depends |
||||
|
from fastapi.security import OAuth2PasswordBearer |
||||
|
from fastapi.security.oauth2 import SecurityScopes |
||||
|
from fastapi.testclient import TestClient |
||||
|
|
||||
|
app = FastAPI() |
||||
|
|
||||
|
oauth2_scheme = OAuth2PasswordBearer( |
||||
|
tokenUrl="token", |
||||
|
scopes={"me": "Read information about the current user.", "items": "Read items."}, |
||||
|
) |
||||
|
|
||||
|
|
||||
|
def get_security_scopes( |
||||
|
security_scopes: SecurityScopes, token=Depends(oauth2_scheme) |
||||
|
) -> List[str]: |
||||
|
return security_scopes.scopes |
||||
|
|
||||
|
|
||||
|
@app.get("/me") |
||||
|
async def read_single_scope( |
||||
|
current_scope=Security(get_security_scopes, scopes="me"), |
||||
|
): |
||||
|
return {"scopes": current_scope} |
||||
|
|
||||
|
|
||||
|
@app.get("/me-and-items") |
||||
|
async def read_multiple_scopes( |
||||
|
current_scope=Security(get_security_scopes, scopes=["me", "items"]), |
||||
|
): |
||||
|
return {"scopes": current_scope} |
||||
|
|
||||
|
|
||||
|
client = TestClient(app) |
||||
|
|
||||
|
|
||||
|
def test_single_scope_string(): |
||||
|
response = client.get("/me", headers={"Authorization": "Bearer sometoken"}) |
||||
|
|
||||
|
assert response.status_code == 200 |
||||
|
assert response.json() == {"scopes": ["me"]} |
||||
|
|
||||
|
|
||||
|
def test_list_scopes(): |
||||
|
response = client.get( |
||||
|
"/me-and-items", headers={"Authorization": "Bearer sometoken"} |
||||
|
) |
||||
|
|
||||
|
assert response.status_code == 200 |
||||
|
assert response.json() == {"scopes": ["me", "items"]} |
Loading…
Reference in new issue