Go to file
2023-11-19 09:49:50 -01:00
.devcontainer Add a Devcontainer (#6290) 2023-07-03 22:36:55 +00:00
.github Admin: Allow different release tracks 2023-11-17 21:18:33 -01:00
docs Docs: Add release information (#7041) 2023-11-17 20:37:14 -01:00
moto chore: update EC2 Instance Types (#7047) 2023-11-19 09:49:50 -01:00
other_langs Bump org.apache.maven.plugins:maven-surefire-plugin (#6981) 2023-11-02 18:25:02 -01:00
scripts Add new ELBv2 ssl protocols, add small helper script to fetch them (#7009) 2023-11-10 13:54:25 -01:00
tests EFS: Add support for describing access points using File system ID filter (#7043) 2023-11-18 19:09:06 -01:00
.coveragerc Introduce Github Actions to replace TravisCI (#3610) 2021-01-26 12:37:03 +00:00
.git-blame-ignore-revs Ignore Black formatting commits in the blame view (#5664) 2022-11-16 17:51:34 -08:00
.gitignore Feature: Proxy (#6848) 2023-09-27 18:34:30 +00:00
.gitmodules Terraform Tests - update to latest TF branch (#5031) 2022-04-16 10:02:57 +00:00
.readthedocs.yaml Update .readthedocs.yaml 2021-11-03 21:01:49 -01:00
AUTHORS.md IOT: check if policy name already taken (#5352) 2022-08-02 19:45:46 +02:00
CHANGELOG.md Post-release steps 2023-11-16 13:33:28 +00:00
CLOUDFORMATION_COVERAGE.md Prep Release 4.1.7 (#6201) 2023-04-11 14:31:46 +00:00
CODE_OF_CONDUCT.md Add docs on contributing and code of conduct. 2017-02-26 19:55:19 -05:00
codecov.yml Admin: Support Py 3.12 (#6966) 2023-10-30 19:01:03 -01:00
CONFIG_README.md address PR comments 2020-09-21 17:42:44 -06:00
CONTRIBUTING.md Admin: Update Docs to point to getmoto (#5826) 2023-01-07 10:35:14 -01:00
Dockerfile Docker image is now based on Python 3.11 (#6714) 2023-08-23 07:28:42 +00:00
IMPLEMENTATION_COVERAGE.md Docs: mark S3:put_public_access_block() as implemented (#7035) 2023-11-16 18:56:58 -01:00
ISSUE_TEMPLATE.md Add docs on contributing and code of conduct. 2017-02-26 19:55:19 -05:00
LICENSE Add license. 2013-04-26 17:13:43 -04:00
Makefile Introducing a new linter: ruff (#6752) 2023-09-03 06:16:24 +00:00
MANIFEST.in Feature: Proxy (#6848) 2023-09-27 18:34:30 +00:00
pyproject.toml Remove redundant wheel dep from pyproject.toml (#5832) 2023-01-11 19:44:34 -01:00
README.md Update README.md (#6960) 2023-10-28 08:09:38 +00:00
requirements-dev.txt Introducing a new linter: ruff (#6752) 2023-09-03 06:16:24 +00:00
requirements-tests.txt Up openapi-spec-validator version; swith to pytest-order (#6943) 2023-10-23 21:42:34 +00:00
requirements.txt First stab at extracting deps in setup.py to extras 2020-09-03 09:23:53 +01:00
ruff.toml BUG: fix lint error E721 (#6767) 2023-09-06 13:08:35 +00:00
setup.cfg AWSLambda: Ensure simple backend does not require docker-module (#7000) 2023-11-07 21:48:26 -01:00
update_version_from_git.py Move to pyproject.toml, instead of setup.py (#5821) 2023-01-06 18:43:16 -01:00

Moto - Mock AWS Services

Join the chat at https://gitter.im/awsmoto/Lobby

Build Status Coverage Status Docs PyPI PyPI - Python Version PyPI - Downloads Code style: black Financial Contributors

Install

$ pip install 'moto[ec2,s3,all]'

In a nutshell

Moto is a library that allows your tests to easily mock out AWS Services.

Imagine you have the following python code that you want to test:

import boto3


class MyModel:
    def __init__(self, name, value):
        self.name = name
        self.value = value

    def save(self):
        s3 = boto3.client("s3", region_name="us-east-1")
        s3.put_object(Bucket="mybucket", Key=self.name, Body=self.value)

Take a minute to think how you would have tested that in the past.

Now see how you could test it with Moto:

import boto3
from moto import mock_s3
from mymodule import MyModel


@mock_s3
def test_my_model_save():
    conn = boto3.resource("s3", region_name="us-east-1")
    # We need to create the bucket since this is all in Moto's 'virtual' AWS account
    conn.create_bucket(Bucket="mybucket")
    model_instance = MyModel("steve", "is awesome")
    model_instance.save()
    body = conn.Object("mybucket", "steve").get()["Body"].read().decode("utf-8")
    assert body == "is awesome"

With the decorator wrapping the test, all the calls to s3 are automatically mocked out. The mock keeps track of the state of the buckets and keys.

For a full list of which services and features are covered, please see our implementation coverage.

Documentation

The full documentation can be found here:

http://docs.getmoto.org/en/latest/

Financial Contributions

Support this project and its continued development, by sponsoring us!

Click the Sponsor-button at the top of the page for more information.

Our finances are managed by OpenCollective, which means you have full visibility into all our contributions and expenses: https://opencollective.com/moto

Security contact information

To report a security vulnerability, please use the Tidelift security contact. Tidelift will coordinate the fix and disclosure.