Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion sqlmodel/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,7 @@ def __init__(
self.sa_relationship_kwargs = sa_relationship_kwargs


@dataclass
@dataclass(unsafe_hash=True)
class FieldInfoMetadata:
primary_key: bool | UndefinedType = Undefined
nullable: bool | UndefinedType = Undefined
Expand Down
29 changes: 29 additions & 0 deletions tests/test_field_info_metadata_hashable.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
from typing import Annotated

from sqlmodel import Field
from sqlmodel.main import FieldInfoMetadata


def test_field_info_metadata_is_hashable():
"""FieldInfoMetadata must be hashable so that Annotated types containing it
can be used in sets (e.g. FastAPI's OpenAPI schema generation)."""
meta = FieldInfoMetadata(primary_key=True)
hash(meta)


def test_annotated_with_field_info_metadata_in_set():
"""Annotated types carrying FieldInfoMetadata must work inside a set,
which is required by FastAPI's get_definitions()."""
t = Annotated[int, FieldInfoMetadata(unique=True)]
s = {t}
assert t in s


def test_annotated_field_type_in_set():
"""Realistic scenario: custom Annotated field aliases used in a set."""
PositiveInt = Annotated[int, Field(ge=0)]
ShortStr = Annotated[str, Field(max_length=32)]

s = {PositiveInt, ShortStr}
assert PositiveInt in s
assert ShortStr in s
Loading