generated from daniil-berg/boilerplate-py
Compare commits
3 Commits
0e443f08b9
...
3f0e3db427
Author | SHA1 | Date | |
---|---|---|---|
3f0e3db427 | |||
862a517018 | |||
3c16b4ebd6 |
25
.github/workflows/ci.yaml
vendored
25
.github/workflows/ci.yaml
vendored
@ -2,17 +2,15 @@ name: CI
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches: master
|
||||||
- master
|
tags: 'v*.*.*'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
test-and-check:
|
test:
|
||||||
name: Tests and checks
|
name: Test
|
||||||
uses: daniil-berg/reusable-workflows/.github/workflows/python-test.yaml@v0.0.1
|
uses: daniil-berg/reusable-workflows/.github/workflows/python-test.yaml@v0.2.1
|
||||||
with:
|
with:
|
||||||
versions: '["3.9", "3.10", "3.11"]'
|
versions: '["3.9", "3.10", "3.11"]'
|
||||||
cache: pip
|
|
||||||
cache-dependency-path: pyproject.toml
|
|
||||||
unittest-command: 'scripts/test.sh'
|
unittest-command: 'scripts/test.sh'
|
||||||
coverage-command: 'scripts/cov.sh'
|
coverage-command: 'scripts/cov.sh'
|
||||||
unittest-requirements: "-e '.[dev]'"
|
unittest-requirements: "-e '.[dev]'"
|
||||||
@ -21,3 +19,16 @@ jobs:
|
|||||||
typecheck-all-versions: true
|
typecheck-all-versions: true
|
||||||
lint-command: 'scripts/lint.sh'
|
lint-command: 'scripts/lint.sh'
|
||||||
lint-requirements: '-Ur requirements/dev.txt'
|
lint-requirements: '-Ur requirements/dev.txt'
|
||||||
|
|
||||||
|
release:
|
||||||
|
name: Release
|
||||||
|
if: ${{ github.ref_type == 'tag' }}
|
||||||
|
needs: test
|
||||||
|
uses: daniil-berg/reusable-workflows/.github/workflows/python-release.yaml@v0.2.1
|
||||||
|
with:
|
||||||
|
git-ref: ${{ github.ref_name }}
|
||||||
|
secrets:
|
||||||
|
release-token: ${{ secrets.TOKEN_GITHUB_CREATE_RELEASE }}
|
||||||
|
publish-token: ${{ secrets.TOKEN_PYPI_PROJECT }}
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
@ -37,18 +37,15 @@ dynamic = [
|
|||||||
]
|
]
|
||||||
|
|
||||||
[project.optional-dependencies]
|
[project.optional-dependencies]
|
||||||
full = [
|
|
||||||
|
|
||||||
]
|
|
||||||
dev = [
|
dev = [
|
||||||
"black",
|
"black==23.3.0",
|
||||||
"build",
|
"build==0.10.0",
|
||||||
"coverage[toml]",
|
"coverage[toml]==7.2.3",
|
||||||
"isort",
|
"isort==5.12.0",
|
||||||
"mkdocs-material",
|
"mkdocs-material==9.1.6",
|
||||||
"mkdocstrings[python]",
|
"mkdocstrings[python]==0.21.2",
|
||||||
"mypy",
|
"mypy==1.2.0",
|
||||||
"ruff",
|
"ruff==0.0.262",
|
||||||
]
|
]
|
||||||
|
|
||||||
[project.urls]
|
[project.urls]
|
||||||
|
@ -1 +1 @@
|
|||||||
marshmallow
|
marshmallow>=3.12.0
|
@ -1,9 +1,9 @@
|
|||||||
-r common.txt
|
-r common.txt
|
||||||
black
|
black==23.3.0
|
||||||
build
|
build==0.10.0
|
||||||
coverage[toml]
|
coverage[toml]==7.2.3
|
||||||
isort
|
isort==5.12.0
|
||||||
mkdocs-material
|
mkdocs-material==9.1.6
|
||||||
mkdocstrings[python]
|
mkdocstrings[python]==0.21.2
|
||||||
mypy
|
mypy==1.2.0
|
||||||
ruff
|
ruff==0.0.262
|
||||||
|
@ -16,6 +16,11 @@ from .decorators import post_load
|
|||||||
|
|
||||||
Model = TypeVar("Model")
|
Model = TypeVar("Model")
|
||||||
|
|
||||||
|
MANY_SCHEMA_UNSAFE = (
|
||||||
|
"Changing `many` schema-wide breaks type safety. "
|
||||||
|
"Use the the `many` parameter of specific methods (like `load`) instead."
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class GenericSchema(GenericInsightMixin1[Model], Schema):
|
class GenericSchema(GenericInsightMixin1[Model], Schema):
|
||||||
"""
|
"""
|
||||||
@ -100,6 +105,7 @@ class GenericSchema(GenericInsightMixin1[Model], Schema):
|
|||||||
[`load`][marshmallow_generic.GenericSchema.load]/
|
[`load`][marshmallow_generic.GenericSchema.load]/
|
||||||
[`loads`][marshmallow_generic.GenericSchema.loads].
|
[`loads`][marshmallow_generic.GenericSchema.loads].
|
||||||
"""
|
"""
|
||||||
|
self._pre_init = True
|
||||||
super().__init__(
|
super().__init__(
|
||||||
only=only,
|
only=only,
|
||||||
exclude=exclude,
|
exclude=exclude,
|
||||||
@ -110,6 +116,7 @@ class GenericSchema(GenericInsightMixin1[Model], Schema):
|
|||||||
partial=partial,
|
partial=partial,
|
||||||
unknown=unknown,
|
unknown=unknown,
|
||||||
)
|
)
|
||||||
|
self._pre_init = False
|
||||||
|
|
||||||
def __setattr__(self, name: str, value: Any) -> None:
|
def __setattr__(self, name: str, value: Any) -> None:
|
||||||
"""
|
"""
|
||||||
@ -119,10 +126,7 @@ class GenericSchema(GenericInsightMixin1[Model], Schema):
|
|||||||
[`object.__setattr__`](https://docs.python.org/3/reference/datamodel.html#object.__setattr__).
|
[`object.__setattr__`](https://docs.python.org/3/reference/datamodel.html#object.__setattr__).
|
||||||
"""
|
"""
|
||||||
if name == "many" and value is not False:
|
if name == "many" and value is not False:
|
||||||
warn(
|
warn(MANY_SCHEMA_UNSAFE, stacklevel=4 if self._pre_init else 2)
|
||||||
"Changing `many` schema-wide breaks type safety. Use the the "
|
|
||||||
"`many` parameter of specific methods (like `load`) instead."
|
|
||||||
)
|
|
||||||
super().__setattr__(name, value)
|
super().__setattr__(name, value)
|
||||||
|
|
||||||
@post_load
|
@post_load
|
||||||
|
Loading…
Reference in New Issue
Block a user