blob: c90bb67f0e89f388dcc253259ba128a515141e0d (
plain)
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
from typing import Any
from typing import Dict
from uuid import UUID as _py_uuid
from sqlalchemy import cast
from sqlalchemy import Column
from sqlalchemy import func
from sqlalchemy import Integer
from sqlalchemy import or_
from sqlalchemy import select
from sqlalchemy import Text
from sqlalchemy.dialects.postgresql import ARRAY
from sqlalchemy.dialects.postgresql import array
from sqlalchemy.dialects.postgresql import JSONB
from sqlalchemy.dialects.postgresql import UUID
from sqlalchemy.orm import DeclarativeBase
from sqlalchemy.orm import Mapped
from sqlalchemy.orm import mapped_column
# test #6402
c1 = Column(UUID())
# EXPECTED_TYPE: Column[UUID]
reveal_type(c1)
c2 = Column(UUID(as_uuid=False))
# EXPECTED_TYPE: Column[str]
reveal_type(c2)
class Base(DeclarativeBase):
pass
class Test(Base):
__tablename__ = "test_table_json"
id = mapped_column(Integer, primary_key=True)
data: Mapped[Dict[str, Any]] = mapped_column(JSONB)
ident: Mapped[_py_uuid] = mapped_column(UUID())
ident_str: Mapped[str] = mapped_column(UUID(as_uuid=False))
elem = func.jsonb_array_elements(Test.data, type_=JSONB).column_valued("elem")
stmt = select(Test).where(
or_(
cast("example code", ARRAY(Text)).contained_by(
array([select(elem["code"].astext).scalar_subquery()])
),
cast("stefan", ARRAY(Text)).contained_by(
array([select(elem["code"]["new_value"].astext).scalar_subquery()])
),
)
)
print(stmt)
t1 = Test()
# EXPECTED_RE_TYPE: .*[dD]ict\[.*str, Any\]
reveal_type(t1.data)
# EXPECTED_TYPE: UUID
reveal_type(t1.ident)
|