-
-
Notifications
You must be signed in to change notification settings - Fork 843
Expand file tree
/
Copy pathtest_field_sa_fk_args_kwargs.py
More file actions
49 lines (35 loc) · 1.51 KB
/
test_field_sa_fk_args_kwargs.py
File metadata and controls
49 lines (35 loc) · 1.51 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
from sqlalchemy import ForeignKey, create_engine
from sqlmodel import Field, SQLModel
def test_base_model_fk(clear_sqlmodel, caplog) -> None:
class User(SQLModel, table=True):
id: int | None = Field(default=None, primary_key=True)
class Base(SQLModel):
owner_id: int | None = Field(
default=None, sa_column_args=(ForeignKey("user.id", ondelete="SET NULL"),)
)
class Asset(Base, table=True):
id: int | None = Field(default=None, primary_key=True)
class Document(Base, table=True):
id: int | None = Field(default=None, primary_key=True)
engine = create_engine("sqlite://", echo=True)
SQLModel.metadata.create_all(engine)
assert (
"FOREIGN KEY(owner_id) REFERENCES user (id) ON DELETE SET NULL" in caplog.text
)
def test_base_model_fk_args(clear_sqlmodel, caplog) -> None:
class User(SQLModel, table=True):
id: int | None = Field(default=None, primary_key=True)
class Base(SQLModel):
owner_id: int | None = Field(
default=None,
foreign_key=ForeignKey("user.id", ondelete="SET NULL"),
)
class Asset(Base, table=True):
id: int | None = Field(default=None, primary_key=True)
class Document(Base, table=True):
id: int | None = Field(default=None, primary_key=True)
engine = create_engine("sqlite://", echo=True)
SQLModel.metadata.create_all(engine)
assert (
"FOREIGN KEY(owner_id) REFERENCES user (id) ON DELETE SET NULL" in caplog.text
)