KEMBAR78
Fix #19491, crash when using enable_error_code value of wrong type in pyproject.toml by wyattscarpenter · Pull Request #19494 · python/mypy · GitHub
Skip to content

Conversation

@wyattscarpenter
Copy link
Contributor

@wyattscarpenter wyattscarpenter commented Jul 24, 2025

Fixes #19491

If you give a string in toml, you get Invalid error code(s): whatever. However, if you give a value that doesn't mean a string in toml, you get a crash like TypeError: 'int' object is not iterable.

I suspect this would also apply to many other pyproject.toml values if you set them wrong, because we pass many of them immediately into try_split, which tries to iterate them.

I have added a (fairly minimal) test for this behavior.

@github-actions

This comment has been minimized.

@wyattscarpenter wyattscarpenter marked this pull request as draft July 26, 2025 01:12
wyattscarpenter and others added 4 commits July 29, 2025 02:59
@github-actions

This comment has been minimized.

@wyattscarpenter
Copy link
Contributor Author

The fact that we're now raising an error instead of allowing the value to go through and yet the test apparently still passes makes me wonder if the test is wrong. Or maybe I just got lucky and the implications of raising an error result in the same error message and thus pass the test the same way.

@wyattscarpenter wyattscarpenter marked this pull request as ready for review July 29, 2025 08:00
@wyattscarpenter wyattscarpenter marked this pull request as draft July 30, 2025 21:29
@github-actions

This comment has been minimized.

Ah, this should be object, not Any, shouldn't it?

And while I'm at it, I can simplify the split regex
@github-actions

This comment has been minimized.

Copy link
Collaborator

@sterliakov sterliakov left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks great, thanks!

I'm committing this because it's very convenient through the web interface, but I will presumably have to make a second commit to change the test output that depends on this

Co-authored-by: Shantanu <12621235+hauntsaninja@users.noreply.github.com>
@github-actions
Copy link
Contributor

github-actions bot commented Aug 3, 2025

According to mypy_primer, this change doesn't affect type check results on a corpus of open source code. ✅

@hauntsaninja hauntsaninja merged commit a6bfb2e into python:master Aug 8, 2025
20 checks passed
@wyattscarpenter wyattscarpenter deleted the 19491 branch August 8, 2025 05:10
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Crash when using an invalid 'enable_error_code' value in pyproject.toml

3 participants