Skip to content
This repository has been archived by the owner on Jan 5, 2024. It is now read-only.

beartype/bearboto3

Repository files navigation

bearboto3

GitHub Workflow Status GitHub Workflow Status PyPI - Downloads PyPI - Python Version

This project provides support for using the boto3 library (AWS Python SDK) and associated stub libraries such as boto3-stubs together with beartype for runtime type-checking.

Since boto3 uses a data-driven factory model to create class types at runtime, you cannot annotate them without support of stub libraries such as boto3-stubs. However, if you are using a runtime type-checker such as beartype, type validation will fail since the types technically do not match (even though they represent the same object schema).

Behold...

this project makes use of the typing.TYPE_CHECKING constant found in the python typing module to conditionally load either static types from a stub library (in this case boto3-stubs), or custom annotated types that can be checked with beartype.

Installation/Use

See the list of services to see what is currently implemented.

Supported python versions:

  • >= 3.7

Install with pip:

pip3 install bearboto3

or with whatever dependency management tool you use (like poetry):

poetry add bearboto3

Then in your code, import the specific types you need:

from beartype import beartype
from bearboto3.s3 import S3Client, Bucket
import boto3

@beartype
def example(s3: S3Client) -> Bucket:
    return s3.create_bucket(Bucket='mybucket')

s3_client = boto3.client('s3')
bucket = example(s3_client)

You will be able to have your salmon and eat it too!

Installing the type stubs

At present, there does not appear to be a way in pyproject.toml to specify extra/optional packages that should be installed as dev dependencies. The type stubs for each service (which allow for IDE integration courtsey of boto3-stubs) can be installed as extras such as:

poetry install bearboto3[s3]

but NOTE this will install the type stubs as runtime dependencies given the limitations above. The type stub libraries are not needed to run any code you use this package with, so the recommended approach is to install whatever type stubs you need yourself in your project's dev-dependencies section.

Future work includes being able to isolate installing bearboto3 runtime type definitions per service, like you are able to specify with moto and boto3-stubs.

Versioning

For the most part this project will try to adhere to semantic versioning. The first 1.0.0 release will come when type checking for all of the AWS services have been finished. 0.x.0 releases will contain type checking for new services, and 0.x.x releases will contain any fixes on the existing implemented services.

If the community disagrees with this approach and would like to propose an alternative, please feel free to start a discussion or open an issue.

Contributing

See contributing

Acknowledgements

  • @leycec For being an avid supporter and welcoming me to the beartype family