From d000b4b3fcb61b220c9e1152f3fb421484bb3e59 Mon Sep 17 00:00:00 2001 From: Nikita Sobolev Date: Fri, 26 Apr 2024 10:12:14 +0300 Subject: [PATCH] Document how to use `assert_type` (#148) --- .github/workflows/test.yml | 2 +- README.md | 18 ++++++++++++++++++ .../tests/test-assert-type.yml | 19 +++++++++++++++++++ 3 files changed, 38 insertions(+), 1 deletion(-) create mode 100644 pytest_mypy_plugins/tests/test-assert-type.yml diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index cedb5fb..6c32eb2 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -21,7 +21,7 @@ jobs: python-version: ["3.8", "3.9", "3.10", "3.11", "3.12"] pytest-version: ["~=7.2", "~=8.1"] # TODO: remove after several new versions of mypy - mypy-version: ["~=1.7", "~=1.9"] + mypy-version: ["~=1.7", "~=1.10"] steps: - uses: actions/checkout@v4 diff --git a/README.md b/README.md index 6290995..1d42aac 100644 --- a/README.md +++ b/README.md @@ -33,6 +33,24 @@ just execute: pytest ``` +### Asserting types + +There are two ways to assert types. +The custom one and regular [`typing.assert_type`](https://docs.python.org/3/library/typing.html#typing.assert_type). + +Our custom type assertion uses `reveal_type` helper and custom output matchers: + +```yml +- case: using_reveal_type + main: | + instance = 1 + reveal_type(instance) # N: Revealed type is 'builtins.int' +``` + +This method also allows to use `# E:` for matching exact error messages and codes. + +But, you can also use regular `assert_type`, examples can be [found here](https://github.com/typeddjango/pytest-mypy-plugins/blob/master/pytest_mypy_plugins/tests/test-assert-type.yml). + ### Paths The `PYTHONPATH` and `MYPYPATH` environment variables, if set, are passed to `mypy` on invocation. diff --git a/pytest_mypy_plugins/tests/test-assert-type.yml b/pytest_mypy_plugins/tests/test-assert-type.yml new file mode 100644 index 0000000..658ce07 --- /dev/null +++ b/pytest_mypy_plugins/tests/test-assert-type.yml @@ -0,0 +1,19 @@ +- case: assert_type + main: | + from typing_extensions import assert_type + + def x() -> int: + return 1 + + assert_type(x(), int) + +- case: assert_type_error + mypy_config: | + warn_unused_ignores = true + main: | + from typing_extensions import assert_type + + def x() -> int: + return 1 + + assert_type(x(), str) # type: ignore