Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[fastapi] Handle parameters with Depends correctly (FAST003) #15364

Open
wants to merge 6 commits into
base: main
Choose a base branch
from

Conversation

InSyncWithFoo
Copy link
Contributor

Summary

Resolves #13657.

Test Plan

cargo nextest run and cargo insta test.

Copy link
Contributor

github-actions bot commented Jan 9, 2025

ruff-ecosystem results

Linter (stable)

✅ ecosystem check detected no linter changes.

Linter (preview)

✅ ecosystem check detected no linter changes.

@charliermarsh charliermarsh self-assigned this Jan 9, 2025
Copy link
Member

@MichaReiser MichaReiser left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice. A few comments related to how the code is structured and the used terminology

@MichaReiser MichaReiser added the rule Implementing or modifying a lint rule label Jan 9, 2025
@dhruvmanila dhruvmanila added the preview Related to preview mode features label Jan 9, 2025
Copy link
Member

@MichaReiser MichaReiser left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is great. One small nit and an understand question from my end.

@app.get("/things/{thing_id}")
async def single(other: Annotated[str, Depends(not_so_dependable)]): ...
@app.get("/things/{thing_id}")
async def double(other: Annotated[str, Depends(not_so_dependable), Depends(dependable)]): ...
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just for my understanding. Is this an error because fastapi only respects the first Depends? Do you have a reference that documents this behavior or did you find it out by try and error?

Copy link
Contributor Author

@InSyncWithFoo InSyncWithFoo Jan 9, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The documentation doesn't mention what happens when two Depends are used in a path operation function, only when multiple of them are used in a path operation decorator.

Testing this again, I think I made a mistake. FastAPI seems to respect the last rather than the first. The code in question:

from fastapi import FastAPI, Depends
from typing import Annotated

app = FastAPI()

def foo(a: str) -> str:
    print(f'foo: {a}')
    return 'lorem'
    
def bar(b: str) -> int:
    print(f'bar: {b}')
    return 42
    
def baz(c: str) -> bytes:
    print(f'baz: {c}')
    return b''

@app.get("/things/{c}")  # `a`/`b`
async def read_thing(other: Annotated[str, Depends(baz), Depends(bar), Depends(foo)]):
    return other
$ uv run fastapi run hello.py
      ...
      INFO   1.2.3.4:5 - "GET /things/ipsum HTTP/1.1" 422
{
    "detail": [
        {
            "type": "missing",
            "loc": ["query", "a"],
            "msg": "Field required",
            "input": null
        }
    ]
}

It would be best if we could ask someone with FastAPI expertise to have a look.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the detailed investigation.

@charliermarsh do you know someone we could ping on this?

I'd otherwise suggest to bail (ignore the rule) if multiple Depends are seen

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I asked Sebastian

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the ping @charliermarsh ! (and thanks for doing it on DM, I wouldn't have seen the GitHub notification 😅)

Yeah, only one Depends() is supported in path operation function parameters. I actually didn't give much thought about what would happen if there's more than one when implementing it, I don't think I have tests for that. So I currently don't have any guarantee (tests) to ensure that it's always the first or last one (maybe I should? 🤔)... It's currently unspecified. 😅

Nevertheless, although there are no current guarantees, the implementation is probably gonna stay the same for quite a while.

@charliermarsh charliermarsh removed their assignment Jan 9, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
preview Related to preview mode features rule Implementing or modifying a lint rule
Projects
None yet
Development

Successfully merging this pull request may close these issues.

FAST003 doesn't detect params used in injected dependencies
5 participants