Skip to content

Commit

Permalink
fix: remove unnecessary typing-extensions for py3.8 (#281)
Browse files Browse the repository at this point in the history
* fix: remove unnecessary typing-extensions for py3.8

* chore: update changelog

Co-authored-by: heitorlessa <[email protected]>
  • Loading branch information
nadobando and heitorlessa authored Feb 4, 2021
1 parent 80081af commit 2591050
Show file tree
Hide file tree
Showing 10 changed files with 22 additions and 8 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

* **Utilities**: Correctly handle and list multiple exceptions in SQS batch processing utility.
* **Docs*:: Fix typos on AppConfig docstring import, and `SnsModel` typo in parser.
* **Utilities**: `typing_extensions` package is now only installed in Python < 3.8

## [1.10.1] - 2021-01-19

Expand Down
3 changes: 2 additions & 1 deletion aws_lambda_powertools/utilities/parser/models/dynamodb.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,8 @@
from typing import Any, Dict, List, Optional

from pydantic import BaseModel
from typing_extensions import Literal

from ..types import Literal


class DynamoDBStreamChangedRecordModel(BaseModel):
Expand Down
3 changes: 2 additions & 1 deletion aws_lambda_powertools/utilities/parser/models/kinesis.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@

from pydantic import BaseModel, validator
from pydantic.types import PositiveInt
from typing_extensions import Literal

from ..types import Literal

logger = logging.getLogger(__name__)

Expand Down
3 changes: 2 additions & 1 deletion aws_lambda_powertools/utilities/parser/models/s3.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@
from pydantic.fields import Field
from pydantic.networks import IPvAnyNetwork
from pydantic.types import PositiveInt
from typing_extensions import Literal

from ..types import Literal


class S3EventRecordGlacierRestoreEventData(BaseModel):
Expand Down
3 changes: 2 additions & 1 deletion aws_lambda_powertools/utilities/parser/models/ses.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,8 @@
from pydantic import BaseModel, Field
from pydantic.networks import EmailStr
from pydantic.types import PositiveInt
from typing_extensions import Literal

from ..types import Literal


class SesReceiptVerdict(BaseModel):
Expand Down
3 changes: 2 additions & 1 deletion aws_lambda_powertools/utilities/parser/models/sns.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,8 @@

from pydantic import BaseModel, root_validator
from pydantic.networks import HttpUrl
from typing_extensions import Literal

from ..types import Literal


class SnsMsgAttributeModel(BaseModel):
Expand Down
3 changes: 2 additions & 1 deletion aws_lambda_powertools/utilities/parser/models/sqs.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,8 @@
from typing import Dict, List, Optional

from pydantic import BaseModel
from typing_extensions import Literal

from ..types import Literal


class SqsAttributesModel(BaseModel):
Expand Down
7 changes: 7 additions & 0 deletions aws_lambda_powertools/utilities/parser/types.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
"""Generics and other shared types used across parser"""

from typing import TypeVar

from pydantic import BaseModel

# We only need typing_extensions for python versions <3.8
try:
from typing import Literal # noqa: F401
except ImportError:
from typing_extensions import Literal # noqa: F401

Model = TypeVar("Model", bound=BaseModel)
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ boto3 = "^1.12"
jmespath = "^0.10.0"
pydantic = {version = "^1.6.0", optional = true }
email-validator = {version = "*", optional = true }
typing_extensions = {version = "^3.7.4.2", optional = true }
typing_extensions = {version = "^3.7.4.2", optional = true, python= "<3.8" }

[tool.poetry.dev-dependencies]
coverage = {extras = ["toml"], version = "^5.0.3"}
Expand Down
2 changes: 1 addition & 1 deletion tests/functional/parser/schemas.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
from typing import Dict, List, Optional

from pydantic import BaseModel
from typing_extensions import Literal

from aws_lambda_powertools.utilities.parser.models import (
DynamoDBStreamChangedRecordModel,
Expand All @@ -14,6 +13,7 @@
SqsModel,
SqsRecordModel,
)
from aws_lambda_powertools.utilities.parser.types import Literal


class MyDynamoBusiness(BaseModel):
Expand Down

0 comments on commit 2591050

Please sign in to comment.