Merge pull request #18524 from github/redsun82/python-match-fps

Python: add some more FP tests around match
This commit is contained in:
yoff
2025-01-17 12:55:56 +01:00
committed by GitHub
4 changed files with 34 additions and 1 deletions

View File

@@ -1,3 +1,4 @@
| functions_test.py:18:1:18:11 | Function cr1 | Mixing implicit and explicit returns may indicate an error as implicit returns always return None. |
| functions_test.py:22:1:22:11 | Function cr2 | Mixing implicit and explicit returns may indicate an error as implicit returns always return None. |
| functions_test.py:336:1:336:16 | Function ok_match | Mixing implicit and explicit returns may indicate an error as implicit returns always return None. |
| functions_test.py:344:1:344:17 | Function ok_match2 | Mixing implicit and explicit returns may indicate an error as implicit returns always return None. |

View File

@@ -339,3 +339,11 @@ def ok_match(x): # FP
return 0
case _:
raise ValueError(x)
def ok_match2(x): # FP
match x:
case None:
return 0
case _:
return 1

View File

@@ -4,3 +4,6 @@
| test.py:21:5:21:38 | For | This statement is unreachable. |
| test.py:28:9:28:21 | ExprStmt | This statement is unreachable. |
| test.py:84:5:84:21 | ExceptStmt | This statement is unreachable. |
| test.py:158:9:159:16 | Case | This statement is unreachable. |
| test.py:162:13:162:16 | Pass | This statement is unreachable. |
| test.py:167:13:167:16 | Pass | This statement is unreachable. |

View File

@@ -141,8 +141,29 @@ def unreachable_catch_all_raise(x):
def ok_match(x):
match x:
case False:
pass # FP
pass
case True:
pass
case _:
pass
match x:
case "true":
pass
case _:
pass
match x:
case 42:
pass
case _: # FP
pass
match x:
case None:
pass # FP
case _:
pass
match x:
case 0.0:
pass # FP
case _:
pass