lightly
lightly copied to clipboard
Type Check Package
We would like to type check all files in the package. Adding types helps to document the code and makes it easier to use.
How to work on this issue
- Go to pyproject.toml to the
excludesection of the mypy settings. There should be a list of files like this:
exclude = '''(?x)(
lightly/cli/version_cli.py |
lightly/cli/crop_cli.py |
lightly/cli/serve_cli.py |
lightly/cli/embed_cli.py |
lightly/cli/lightly_cli.py |
...
- Pick a file you would like to type. Best are files from
lightly/loss,lightly/data,lightly/utils,lightly/models/modules, and the corresponding test files. Do not type check deprecated model files inlightly/modelslikelightly/models/barlow_twins.py. - Run
mypy <filename>(make sure that you have installed lightly following the contribution guide). This should show a list with all the missing types/errors. - Add types until no more errors are shown. This is a good example on how a typed file should look like: https://github.com/lightly-ai/lightly/blob/master/lightly/models/modules/memory_bank.py
- Go to
pyproject.tomland remove the filename of the file you just typed from the mypyexcludelist. - If the file was the last file in a subdirectory that was missing types, then also remove the subdirectory name from the skip import list in pyprojec.toml
- Create a new PR named
Add types for <filename>and push your changes. Make sure all Github actions pass.
Important
Lightly still supports old Python versions (including 3.7, 3.8, and 3.9) that do not work with new typing features introduced in Python 3.10. To use the new Python 3.10 syntax you have to add from __future__ import annotations at the top of the file. The following typing features changed in 3.10:
- Union types can now be written as
str | intinstead ofUnion[str, int] - Optional types can now be written as
str | Noneinstead ofOptional[str] - Tuples, lists, and dicts can now be typed as
tuple[str, int],list[str],dict[str, int]instead ofTuple[str, int],List[str],Dict[str, int].
Please use from __future__ import annotations with the new types whenever possible. This will save a lot of refactoring in the future. Also feel free to update files with old types to the new syntax.
Hey, can I work on this issue ?
Hey @guarin, some of the mypy tests are failing in local, 48 errors in 23 files in master, do you think I can still push my changes for the fix of some of the files ?
Hi @ishaanagw! Thanks for contributing, feel free to work on any file :)
Hey @guarin, some of the mypy tests are failing in local, 48 errors in 23 files in master, do you think I can still push my changes for the fix of some of the files ?
Interesting, will have a look at this on Monday. Which mypy version are you using? CI uses mypy 1.4.1 with Python 3.7. The Python version should not be too important. We use 3.7 in CI to make sure we don't introduce any types that are incompatible with old Python versions.
Hey, @guarin Can you please review this PR - https://github.com/lightly-ai/lightly/pull/1651
Hey @guarin, some of the mypy tests are failing in local, 48 errors in 23 files in master, do you think I can still push my changes for the fix of some of the files ?
@ishaanagw I created a PR to fix the failing mypy tests: https://github.com/lightly-ai/lightly/pull/1654
Wow, that is impressive.
@ishaanagw I unassigned you from the issue to make it clearer that other people can also work on it.
can I work on this issue?
can i work on this ?
@Prasadayus and @Abhrajitdas02 can you select some files/submodules to work on? I can create other smaller issues and then assign those to you.
@guarin, hi! I have two questions:
- Where to find a list of deprecated models?
- What to do with mypy error
Untyped decorator makes function ... untyped? Add it to ignore?
These models in lightly/models are deprecated:
Regarding 2) you can just put a local # type: ignore[error code] comment where the error code is the reported error by mypy. See for example: https://github.com/lightly-ai/lightly/blob/ce5113424b9a98f7b113970f3bfae3ec0ced462b/lightly/models/modules/masked_causal_vision_transformer.py#L13-L14