Commit 42cdc09
committed
Use get_protocol_members in protocol checking
This changes `check_protocol()` to make use of `get_protocol_members`
from typing-extensions. This allows removing an existing hard-coded
exclusion list for attributes existing on Protocol, but also handles the
cases `__orig_bases__` and `__weakref__` that was breaking when checking
intersecting protocols (a subclass of two or more protocols).
This has the effect of turning some false positives into true negatives,
but it also leaves some false negatives. To make that clear, xfail test
cases are added for the resulting false negatives.1 parent c72b675 commit 42cdc09
3 files changed
Lines changed: 96 additions & 14 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
7 | 12 | | |
8 | 13 | | |
9 | 14 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
654 | 654 | | |
655 | 655 | | |
656 | 656 | | |
657 | | - | |
658 | | - | |
659 | | - | |
660 | | - | |
661 | | - | |
662 | 657 | | |
663 | 658 | | |
664 | | - | |
665 | | - | |
666 | | - | |
667 | | - | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
668 | 663 | | |
669 | | - | |
670 | 664 | | |
671 | 665 | | |
672 | 666 | | |
| |||
681 | 675 | | |
682 | 676 | | |
683 | 677 | | |
684 | | - | |
685 | | - | |
686 | | - | |
687 | | - | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
688 | 682 | | |
689 | 683 | | |
690 | 684 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
16 | 16 | | |
17 | 17 | | |
18 | 18 | | |
| 19 | + | |
19 | 20 | | |
20 | 21 | | |
21 | 22 | | |
22 | 23 | | |
23 | 24 | | |
24 | 25 | | |
| 26 | + | |
25 | 27 | | |
26 | 28 | | |
| 29 | + | |
27 | 30 | | |
28 | 31 | | |
29 | 32 | | |
| |||
995 | 998 | | |
996 | 999 | | |
997 | 1000 | | |
| 1001 | + | |
| 1002 | + | |
| 1003 | + | |
| 1004 | + | |
| 1005 | + | |
| 1006 | + | |
| 1007 | + | |
| 1008 | + | |
| 1009 | + | |
| 1010 | + | |
| 1011 | + | |
| 1012 | + | |
| 1013 | + | |
| 1014 | + | |
| 1015 | + | |
| 1016 | + | |
| 1017 | + | |
| 1018 | + | |
| 1019 | + | |
| 1020 | + | |
| 1021 | + | |
| 1022 | + | |
| 1023 | + | |
| 1024 | + | |
| 1025 | + | |
| 1026 | + | |
| 1027 | + | |
| 1028 | + | |
| 1029 | + | |
| 1030 | + | |
| 1031 | + | |
| 1032 | + | |
| 1033 | + | |
| 1034 | + | |
| 1035 | + | |
| 1036 | + | |
| 1037 | + | |
| 1038 | + | |
| 1039 | + | |
| 1040 | + | |
| 1041 | + | |
| 1042 | + | |
| 1043 | + | |
| 1044 | + | |
| 1045 | + | |
| 1046 | + | |
| 1047 | + | |
| 1048 | + | |
| 1049 | + | |
| 1050 | + | |
| 1051 | + | |
| 1052 | + | |
| 1053 | + | |
| 1054 | + | |
| 1055 | + | |
| 1056 | + | |
| 1057 | + | |
| 1058 | + | |
| 1059 | + | |
| 1060 | + | |
| 1061 | + | |
| 1062 | + | |
| 1063 | + | |
| 1064 | + | |
| 1065 | + | |
| 1066 | + | |
| 1067 | + | |
| 1068 | + | |
| 1069 | + | |
| 1070 | + | |
| 1071 | + | |
| 1072 | + | |
| 1073 | + | |
| 1074 | + | |
| 1075 | + | |
| 1076 | + | |
| 1077 | + | |
| 1078 | + | |
| 1079 | + | |
| 1080 | + | |
998 | 1081 | | |
999 | 1082 | | |
1000 | 1083 | | |
| |||
0 commit comments