Skip to content

Commit

Permalink
Use python 3.9+ type annotations
Browse files Browse the repository at this point in the history
  • Loading branch information
elchupanebrej committed Dec 11, 2024
1 parent 0bd3ed1 commit 55c3a88
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 31 deletions.
2 changes: 1 addition & 1 deletion python/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ generate: require install-deps
--allow-extra-fields \
--allow-population-by-field-name \
--snake-case-field \
--use-generic-container-types \
--use-standard-collections \
--use-double-quotes \
--use-exact-imports \
--use-field-description \
Expand Down
53 changes: 26 additions & 27 deletions python/src/cucumber_messages/_messages.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@

from dataclasses import dataclass
from enum import Enum
from typing import Sequence

from .json_converter import JSONDataclassMixin

Expand Down Expand Up @@ -91,7 +90,7 @@ class TableRow(JSONDataclassMixin):
"""
The location of the first cell in the row
"""
cells: Sequence[TableCell]
cells: list[TableCell]
"""
Cells in the row
"""
Expand Down Expand Up @@ -127,7 +126,7 @@ class Type(Enum):
class JavaMethod(JSONDataclassMixin):
class_name: str
method_name: str
method_parameter_types: Sequence[str]
method_parameter_types: list[str]


@dataclass
Expand Down Expand Up @@ -177,7 +176,7 @@ class PickleTableCell(JSONDataclassMixin):

@dataclass
class PickleTableRow(JSONDataclassMixin):
cells: Sequence[PickleTableCell]
cells: list[PickleTableCell]


@dataclass
Expand All @@ -202,7 +201,7 @@ class StepDefinitionPattern(JSONDataclassMixin):

@dataclass
class Group(JSONDataclassMixin):
children: Sequence[Group]
children: list[Group]
start: int | None = None
value: str | None = None

Expand All @@ -220,7 +219,7 @@ class StepMatchArgument(JSONDataclassMixin):

@dataclass
class StepMatchArgumentsList(JSONDataclassMixin):
step_match_arguments: Sequence[StepMatchArgument]
step_match_arguments: list[StepMatchArgument]


@dataclass
Expand All @@ -234,13 +233,13 @@ class TestStep(JSONDataclassMixin):
"""
Pointer to the `PickleStep` (if derived from a `PickleStep`)
"""
step_definition_ids: Sequence[str] | None = None
step_definition_ids: list[str] | None = None
"""
Pointer to all the matching `StepDefinition`s (if derived from a `PickleStep`)
Each element represents a matching step definition. A size of 0 means `UNDEFINED`,
and a size of 2+ means `AMBIGUOUS`
"""
step_match_arguments_lists: Sequence[StepMatchArgumentsList] | None = None
step_match_arguments_lists: list[StepMatchArgumentsList] | None = None
"""
A list of list of StepMatchArgument (if derived from a `PickleStep`).
"""
Expand Down Expand Up @@ -417,7 +416,7 @@ class Attachment(JSONDataclassMixin):
@dataclass
class DataTable(JSONDataclassMixin):
location: Location
rows: Sequence[TableRow]
rows: list[TableRow]


@dataclass
Expand All @@ -426,11 +425,11 @@ class Examples(JSONDataclassMixin):
"""
The location of the `Examples` keyword
"""
tags: Sequence[Tag]
tags: list[Tag]
keyword: str
name: str
description: str
table_body: Sequence[TableRow]
table_body: list[TableRow]
id: str
table_header: TableRow | None = None

Expand Down Expand Up @@ -489,7 +488,7 @@ class ParameterType(JSONDataclassMixin):
"""
The name is unique, so we don't need an id.
"""
regular_expressions: Sequence[str]
regular_expressions: list[str]
prefer_for_regular_expression_match: bool
use_for_snippets: bool
id: str
Expand All @@ -504,7 +503,7 @@ class ParseError(JSONDataclassMixin):

@dataclass
class PickleTable(JSONDataclassMixin):
rows: Sequence[PickleTableRow]
rows: list[PickleTableRow]


@dataclass
Expand All @@ -521,7 +520,7 @@ class TestCase(JSONDataclassMixin):
"""
The ID of the `Pickle` this `TestCase` is derived from.
"""
test_steps: Sequence[TestStep]
test_steps: list[TestStep]
test_run_started_id: str | None = None
"""
Identifier for the test run that this test case belongs to
Expand Down Expand Up @@ -589,7 +588,7 @@ class Background(JSONDataclassMixin):
keyword: str
name: str
description: str
steps: Sequence[Step]
steps: list[Step]
id: str


Expand All @@ -599,12 +598,12 @@ class Scenario(JSONDataclassMixin):
"""
The location of the `Scenario` keyword
"""
tags: Sequence[Tag]
tags: list[Tag]
keyword: str
name: str
description: str
steps: Sequence[Step]
examples: Sequence[Examples]
steps: list[Step]
examples: list[Examples]
id: str


Expand Down Expand Up @@ -665,7 +664,7 @@ class RuleChild(JSONDataclassMixin):

@dataclass
class PickleStep(JSONDataclassMixin):
ast_node_ids: Sequence[str]
ast_node_ids: list[str]
"""
References the IDs of the source of the step. For Gherkin, this can be
the ID of a Step, and possibly also the ID of a TableRow
Expand All @@ -690,14 +689,14 @@ class Rule(JSONDataclassMixin):
"""
The location of the `Rule` keyword
"""
tags: Sequence[Tag]
tags: list[Tag]
"""
All the tags placed above the `Rule` keyword
"""
keyword: str
name: str
description: str
children: Sequence[RuleChild]
children: list[RuleChild]
id: str


Expand All @@ -720,17 +719,17 @@ class Pickle(JSONDataclassMixin):
"""
The language of the pickle
"""
steps: Sequence[PickleStep]
steps: list[PickleStep]
"""
One or more steps
"""
tags: Sequence[PickleTag]
tags: list[PickleTag]
"""
*
One or more tags. If this pickle is constructed from a Gherkin document,
It includes inherited tags from the `Feature` as well.
"""
ast_node_ids: Sequence[str]
ast_node_ids: list[str]
"""
*
Points to the AST node locations of the pickle. The last one represents the unique
Expand All @@ -752,7 +751,7 @@ class Feature(JSONDataclassMixin):
"""
The location of the `Feature` keyword
"""
tags: Sequence[Tag]
tags: list[Tag]
"""
All the tags placed above the `Feature` keyword
"""
Expand All @@ -772,15 +771,15 @@ class Feature(JSONDataclassMixin):
"""
The line(s) underneath the line with the `keyword` that are used as description
"""
children: Sequence[FeatureChild]
children: list[FeatureChild]
"""
Zero or more children
"""


@dataclass
class GherkinDocument(JSONDataclassMixin):
comments: Sequence[Comment]
comments: list[Comment]
"""
All the comments in the Gherkin document
"""
Expand Down
7 changes: 5 additions & 2 deletions python/src/cucumber_messages/json_converter.py
Original file line number Diff line number Diff line change
Expand Up @@ -55,11 +55,14 @@ def __init__(self, module_scope: types.ModuleType) -> None:

def _get_sequence_type(self, type_str: str) -> Optional[Tuple[Any, str]]:
sequence_match = re.match(r"Sequence\[(.*)\]", type_str)
list_match = re.match(r"List\[(.*)\]", type_str)
list_legacy_match = re.match(r"List\[(.*)\]", type_str)
list_match = re.match(r"list\[(.*)\]", type_str)
if sequence_match:
return (Sequence, sequence_match.group(1))
if list_match:
if list_legacy_match:
return (List, list_match.group(1))
if list_match:
return (list, list_match.group(1))
return None

def resolve_type(self, type_hint: Any) -> Any:
Expand Down
2 changes: 1 addition & 1 deletion python/tests/test_model_load.py
Original file line number Diff line number Diff line change
Expand Up @@ -205,7 +205,7 @@ def test_simple_load_model(model_datum, oracle_model):

assert isinstance(model, Envelope)
# Models support deep-nested comparison
assert oracle_model == model
assert model == oracle_model

# Serialized model must be the same to original non-restored model
assert model_datum == model.to_dict()

0 comments on commit 55c3a88

Please sign in to comment.