refactor: Make types.py strictly typechecked. #336
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
We are now making the types module typecheck in strict mode.
This is mostly achieved by passing the correct types to the
generic type variables.
We ran into one specific issue with
JSONRPCRequest
andJSONRPCNotification
. Both are generic classes that take adict[str, Any]
as params and just a plain string as method.However, since the TypeVar for
RequestT
andNotificationT
arebound to
RequestParams
andNotificationParams
respectivelywe get into a type issue.
There are two ways of solving this:
dict[str, Any]
type hierarchy with Request and Notification roots.
It felt most naturally to keep JSONRPCRequest/JSONRPCNotification
part of the type hierarchy and allow for general passing of
dict[str, Any].
This now typechecks.