| [case testAnnotated0] |
| from typing_extensions import Annotated |
| x: Annotated[int, ...] |
| reveal_type(x) # N: Revealed type is 'builtins.int' |
| |
| [case testAnnotated1] |
| from typing import Union |
| from typing_extensions import Annotated |
| x: Annotated[Union[int, str], ...] |
| reveal_type(x) # N: Revealed type is 'Union[builtins.int, builtins.str]' |
| |
| [case testAnnotated2] |
| from typing_extensions import Annotated |
| x: Annotated[int, THESE, ARE, IGNORED, FOR, NOW] |
| reveal_type(x) # N: Revealed type is 'builtins.int' |
| |
| [case testAnnotated3] |
| from typing_extensions import Annotated |
| x: Annotated[int, -+~12.3, "som"[e], more(anno+a+ions, that=[are]), (b"ignored",), 4, N.O.W, ...] |
| reveal_type(x) # N: Revealed type is 'builtins.int' |
| |
| [case testAnnotatedBadType] |
| from typing_extensions import Annotated |
| x: Annotated[XXX, ...] # E: Name 'XXX' is not defined |
| reveal_type(x) # N: Revealed type is 'Any' |
| |
| [case testAnnotatedBadNoArgs] |
| from typing_extensions import Annotated |
| x: Annotated # E: Annotated[...] must have exactly one type argument and at least one annotation |
| reveal_type(x) # N: Revealed type is 'Any' |
| |
| [case testAnnotatedBadOneArg] |
| from typing_extensions import Annotated |
| x: Annotated[int] # E: Annotated[...] must have exactly one type argument and at least one annotation |
| reveal_type(x) # N: Revealed type is 'Any' |
| |
| [case testAnnotatedNested0] |
| from typing_extensions import Annotated |
| x: Annotated[Annotated[int, ...], ...] |
| reveal_type(x) # N: Revealed type is 'builtins.int' |
| |
| [case testAnnotatedNested1] |
| from typing import Union |
| from typing_extensions import Annotated |
| x: Annotated[Annotated[Union[int, str], ...], ...] |
| reveal_type(x) # N: Revealed type is 'Union[builtins.int, builtins.str]' |
| |
| [case testAnnotatedNestedBadType] |
| from typing_extensions import Annotated |
| x: Annotated[Annotated[XXX, ...], ...] # E: Name 'XXX' is not defined |
| reveal_type(x) # N: Revealed type is 'Any' |
| |
| [case testAnnotatedNestedBadNoArgs] |
| from typing_extensions import Annotated |
| x: Annotated[Annotated, ...] # E: Annotated[...] must have exactly one type argument and at least one annotation |
| reveal_type(x) # N: Revealed type is 'Any' |
| |
| [case testAnnotatedNestedBadOneArg] |
| from typing_extensions import Annotated |
| x: Annotated[Annotated[int], ...] # E: Annotated[...] must have exactly one type argument and at least one annotation |
| reveal_type(x) # N: Revealed type is 'Any' |
| |
| [case testAnnotatedNoImport] |
| x: Annotated[int, ...] # E: Name 'Annotated' is not defined |
| reveal_type(x) # N: Revealed type is 'Any' |