mirror of
https://github.com/kennethreitz/pydantic.git
synced 2026-06-05 23:00:18 +00:00
bc1f09b3e4
Previously, the Mypy plugin only supported drawing settings from a Config class. Now, it fully supports drawing settings from class kwargs too. Co-authored-by: Matthew Gamble <matthew.gamble@rea-group.com>
258 lines
4.3 KiB
Python
258 lines
4.3 KiB
Python
from typing import ClassVar, Generic, List, Optional, TypeVar, Union
|
|
|
|
from pydantic import BaseModel, Field, create_model, validator
|
|
from pydantic.dataclasses import dataclass
|
|
from pydantic.generics import GenericModel
|
|
|
|
|
|
class Model(BaseModel):
|
|
x: float
|
|
y: str
|
|
|
|
class Config:
|
|
orm_mode = True
|
|
|
|
class NotConfig:
|
|
allow_mutation = False
|
|
|
|
|
|
class SelfReferencingModel(BaseModel):
|
|
submodel: Optional['SelfReferencingModel']
|
|
|
|
@property
|
|
def prop(self) -> None:
|
|
...
|
|
|
|
|
|
SelfReferencingModel.model_rebuild()
|
|
|
|
model = Model(x=1, y='y')
|
|
Model(x=1, y='y', z='z')
|
|
model.x = 2
|
|
model.from_orm(model)
|
|
|
|
self_referencing_model = SelfReferencingModel(submodel=SelfReferencingModel(submodel=None))
|
|
|
|
|
|
class KwargsModel(BaseModel, orm_mode=True):
|
|
x: float
|
|
y: str
|
|
|
|
class NotConfig:
|
|
allow_mutation = False
|
|
|
|
|
|
kwargs_model = KwargsModel(x=1, y='y')
|
|
KwargsModel(x=1, y='y', z='z')
|
|
kwargs_model.x = 2
|
|
kwargs_model.from_orm(kwargs_model)
|
|
|
|
|
|
class InheritingModel(Model):
|
|
z: int = 1
|
|
|
|
|
|
InheritingModel.from_orm(model)
|
|
|
|
|
|
class ForwardReferencingModel(Model):
|
|
future: 'FutureModel'
|
|
|
|
|
|
class FutureModel(Model):
|
|
pass
|
|
|
|
|
|
ForwardReferencingModel.model_rebuild()
|
|
future_model = FutureModel(x=1, y='a')
|
|
forward_model = ForwardReferencingModel(x=1, y='a', future=future_model)
|
|
|
|
|
|
class NoMutationModel(BaseModel):
|
|
x: int
|
|
|
|
class Config:
|
|
allow_mutation = False
|
|
|
|
|
|
class MutationModel(NoMutationModel):
|
|
a = 1
|
|
|
|
class Config:
|
|
allow_mutation = True
|
|
orm_mode = True
|
|
|
|
|
|
MutationModel(x=1).x = 2
|
|
MutationModel.from_orm(model)
|
|
|
|
|
|
class KwargsNoMutationModel(BaseModel, allow_mutation=False):
|
|
x: int
|
|
|
|
|
|
class KwargsMutationModel(KwargsNoMutationModel, allow_mutation=True, orm_mode=True):
|
|
a = 1
|
|
|
|
|
|
KwargsMutationModel(x=1).x = 2
|
|
KwargsMutationModel.from_orm(model)
|
|
|
|
|
|
class OverrideModel(Model):
|
|
x: int
|
|
|
|
|
|
OverrideModel(x=1.5, y='b')
|
|
|
|
|
|
class Mixin:
|
|
def f(self) -> None:
|
|
pass
|
|
|
|
|
|
class MultiInheritanceModel(BaseModel, Mixin):
|
|
pass
|
|
|
|
|
|
MultiInheritanceModel().f()
|
|
|
|
|
|
class AliasModel(BaseModel):
|
|
x: str = Field(..., alias='y')
|
|
|
|
|
|
alias_model = AliasModel(y='hello')
|
|
assert alias_model.x == 'hello'
|
|
|
|
|
|
class ClassVarModel(BaseModel):
|
|
x: int
|
|
y: ClassVar[int] = 1
|
|
|
|
|
|
ClassVarModel(x=1)
|
|
|
|
|
|
class Config:
|
|
validate_assignment = True
|
|
|
|
|
|
@dataclass(config=Config)
|
|
class AddProject:
|
|
name: str
|
|
slug: Optional[str]
|
|
description: Optional[str]
|
|
|
|
|
|
p = AddProject(name='x', slug='y', description='z')
|
|
|
|
|
|
class TypeAliasAsAttribute(BaseModel):
|
|
__type_alias_attribute__ = Union[str, bytes]
|
|
|
|
|
|
class NestedModel(BaseModel):
|
|
class Model(BaseModel):
|
|
id: str
|
|
|
|
model: Model
|
|
|
|
|
|
_ = NestedModel.Model
|
|
|
|
|
|
DynamicModel = create_model('DynamicModel', __base__=Model)
|
|
|
|
dynamic_model = DynamicModel(x=1, y='y')
|
|
dynamic_model.x = 2
|
|
|
|
|
|
class FrozenModel(BaseModel):
|
|
x: int
|
|
|
|
class Config:
|
|
frozen = True
|
|
|
|
|
|
class NotFrozenModel(FrozenModel):
|
|
a: int = 1
|
|
|
|
class Config:
|
|
frozen = False
|
|
orm_mode = True
|
|
|
|
|
|
NotFrozenModel(x=1).x = 2
|
|
NotFrozenModel.from_orm(model)
|
|
|
|
|
|
class KwargsFrozenModel(BaseModel, frozen=True):
|
|
x: int
|
|
|
|
|
|
class KwargsNotFrozenModel(FrozenModel, frozen=False, orm_mode=True):
|
|
a: int = 1
|
|
|
|
|
|
KwargsNotFrozenModel(x=1).x = 2
|
|
KwargsNotFrozenModel.from_orm(model)
|
|
|
|
|
|
class ModelWithSelfField(BaseModel):
|
|
self: str
|
|
|
|
|
|
def f(name: str) -> str:
|
|
return name
|
|
|
|
|
|
class ModelWithAllowReuseValidator(BaseModel):
|
|
name: str
|
|
_normalize_name = validator('name', allow_reuse=True)(f)
|
|
|
|
|
|
model_with_allow_reuse_validator = ModelWithAllowReuseValidator(name='xyz')
|
|
|
|
|
|
T = TypeVar('T')
|
|
|
|
|
|
class Response(GenericModel, Generic[T]):
|
|
data: T
|
|
error: Optional[str]
|
|
|
|
|
|
response = Response[Model](data=model, error=None)
|
|
|
|
|
|
class ModelWithAnnotatedValidator(BaseModel):
|
|
name: str
|
|
|
|
@validator('name')
|
|
def noop_validator_with_annotations(cls, name: str) -> str:
|
|
return name
|
|
|
|
|
|
def _default_factory_str() -> str:
|
|
return 'x'
|
|
|
|
|
|
def _default_factory_list() -> List[int]:
|
|
return [1, 2, 3]
|
|
|
|
|
|
class FieldDefaultTestingModel(BaseModel):
|
|
# Required
|
|
a: int
|
|
b: int = Field()
|
|
c: int = Field(...)
|
|
|
|
# Default
|
|
d: int = Field(1)
|
|
|
|
# Default factory
|
|
g: List[int] = Field(default_factory=_default_factory_list)
|
|
h: str = Field(default_factory=_default_factory_str)
|
|
i: str = Field(default_factory=lambda: 'test')
|