-
-
Notifications
You must be signed in to change notification settings - Fork 3k
Description
Bug Report
The amount of memory that the daemon process consumes doesn't drop when typing errors are fixed; the memory consumption appears to stay the same if there are no errors, and when more errors appear, the memory consumption just continues increasing.
This is problematic when running the daemon on initially untyped code bases with large amounts of typing errors (as usually done in code editors integrating with a type-checker), as dmypy becomes sluggish very quickly (because the same existing errors are repeatedly reported).
To Reproduce & Actual Behaviour
-
Repeat this line 2000 times in a file
project/test/__init__.py
,aaaaaaaaaaaaaaaaaaaaaaaa
and create the following mypy configuration file at
project/mypy.ini
[mypy] files = test/
-
Navigate to
project/
, then rundmypy run > errors.txt
multiple times without editingproject/test/__init__.py
; watch the memory consumption grow for thedmypy
process. -
Delete all code in
project/test/__init__.py
, then rundmypy run
again multiple times. The memory consumption does not decrease.
Expected Behavior
I expect the memory consumption to be proportional to the number of errors, AST nodes, and size of a cache diff since the last time the checked code files have changed. If there's no code changes, it's surprising to me that memory consumption would grow for just repeated reports of the same errors.
Your Environment
- Mypy version used: 1.17.1
- Mypy command-line flags: None
- Mypy configuration options from
mypy.ini
(and other config files): See# project/mypy.ini
- Operating system: Ubuntu (Pop!_OS) 22.04 LTS
- Python version used: 3.11