Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Flow does not catch invalid switch statements #9104

Closed
ayroblu opened this issue Nov 5, 2023 · 2 comments
Closed

Flow does not catch invalid switch statements #9104

ayroblu opened this issue Nov 5, 2023 · 2 comments

Comments

@ayroblu
Copy link

ayroblu commented Nov 5, 2023

Posting here, cause this caused a production incident at our company. For the most part we're "fine" with our usage of flow, but this is one of the more serious bugs

Flow version:
0.220.1

Expected behavior

Incorrect switch case statements should throw an error

Actual behavior

Switch case statements are allowed to do anything

  • Link to Try-Flow or Github repo: link

Specifically see this part:
image
Note the usage of "random_access"

@gkz
Copy link
Member

gkz commented Nov 6, 2023

Thanks for the report. For now, if using the disjoint object union pattern, stick to using literal types 'foo' directly rather than using typeof X.Foo, both when defining the type and when refining it (e.g. in a switch).

@gkz
Copy link
Member

gkz commented Jan 22, 2025

Flow now errors on both invalid type keys (as of 0.259), including fetchPublicDataActionType.REQUEST: https://flow.org/try/#1N4Igxg9gdgZglgcxALlAIwIZoKYBsD6uEEAztvhgE6UYCe+JADpdhgCYowa5kA0I2KAFcAtiRQAXSkOz9sADwxgJ+NPTbYuQ3BMnTZA+Y2yU4IwRO4A6SFBIrGVDGM7c+h46fNRLuKxJIGWh8MeT0ZfhYlCStpHzNsFBAMIQkIEQwJODAQfiEyfBE4eWw2fDgofDBMsAALfAA3KjgsXGxxZC4eAw0G-GhcWn9aY3wWZldu-g1mbGqJUoBaCRHEzrcDEgBrbAk62kXhXFxJ923d-cPRHEpTgyEoMDaqZdW7vKgoOfaSKgOKpqmDA+d4gB5fMA-P6LCCMLLQbiLOoYCqgh6-GDYRYIXYLSgkRZkCR4jpddwPfJLZjpOBkO4AX34kA0SVs9gABJi9rUAApCNC4bIAEUyGAAgso4NAACqrdkAXnZAHk0AArOYxGAsbAAL2wAApgAAdKDs9kAJQAogBFACqloAytLkOyAOQ7WgAegAYpbpQBhAAS+CFYulYvwVrtjulrt4JvpAEoANwmtkSTkXXmmJoLEWWCXwqCy4wu4AAHxNZoA1FH7U6Xa7mHBc9gfX6g-geeaAJIANTDlsjNvrsfjUHL9IVyrVGqsWuwuoNxtNFpHMcbzdb7YDwe7-cHw+jTrjCZTJpNK2M7MLUrsCqr7PL7Ir7Kv2EbHrj7MctCI7BdexTCgBAn3pR9n1fd9P2wWgACZv1-f82DLZ80jYCBAKkCpQMnMCIJfNDVhdd8IBgTNuT5AVhVFW8ZVWKw6xjXgfzoZDULfCAMKw4DcKnScLy+IwIEoDN33ZB1LAWacVzNdDMJfR8zQAbQkAB3RcJB7FD2SAnCAF0eJw8czUZBMTQURgRIzDQtB0TkHklaB2RYNghEhSh9UfexMg-CSpNkR9ojvF06LsE1ExdSTfMU1cSDUuBuXZfVgugYZjETWKzTNaoyDdL8XSU7KzVSqArCQiB2HZDASF07CQOTdlPU9ZUAGkiuKlgJCEShTR8hZU1XHKauwCi6iowUwHzcUnOLBimIbDrstK8q2Mqthqtq4B5KMkD6Ua5q2qWs0up6vqAsG4rctG115Du10XUOy1zXNJVzRdAFuDgNhjuq2bVr-dbYmBDCRAoMBIRIWrDoAITmFI8rIt9alGkxKBE6q0AgBpZHZAADUq8fZWlqqgWhftO3q6t8y7suusbsxbXzprCktsEY9cGzNJ6Xrej6oCaQUfqG4qXN2M7qYGorbJSHRkAp8Wqf67BH3AqB6VyEAcfxO8kgaAAGKw4IAVgATisABGEB6SAA

Note that, once you get an error, this will turn the type of affected values to any. This is on purpose, as otherwise a single mistake with a single cause could cause hundreds of errors. You will get at least a single error that notifies you of the mistake made

@gkz gkz closed this as completed Jan 22, 2025
# for free to join this conversation on GitHub. Already have an account? # to comment
Projects
None yet
Development

No branches or pull requests

2 participants