Go to file
2023-05-21 11:13:07 +00:00
.github Bump peter-evans/create-or-update-comment from 2 to 3 (#6200) 2023-04-11 18:22:21 +00:00
docs Docs: Improve explanation for the 'Pesky Imports' section (#6327) 2023-05-21 11:13:07 +00:00
moto Core: add date to response metadata (#6329) 2023-05-20 20:47:08 +00:00
other_langs Bump software.amazon.awssdk:bom in /other_langs/tests_java (#6275) 2023-05-02 12:18:03 +00:00
scripts SES v2 (#6259) 2023-05-01 18:15:29 +00:00
tests Core: add date to response metadata (#6329) 2023-05-20 20:47:08 +00:00
.coveragerc
.git-blame-ignore-revs
.gitignore
.gitmodules
.readthedocs.yaml
AUTHORS.md
CHANGELOG.md Post-release steps 2023-05-08 17:11:26 +00:00
CLOUDFORMATION_COVERAGE.md Prep Release 4.1.7 (#6201) 2023-04-11 14:31:46 +00:00
CODE_OF_CONDUCT.md
codecov.yml
CONFIG_README.md
CONTRIBUTING.md
Dockerfile
IMPLEMENTATION_COVERAGE.md Add sessions to Glue (#6302) 2023-05-12 15:41:48 +00:00
ISSUE_TEMPLATE.md
LICENSE Add license. 2013-04-26 17:13:43 -04:00
Makefile Prep Release 4.1.7 (#6201) 2023-04-11 14:31:46 +00:00
MANIFEST.in
pyproject.toml
README.md Add Security/vulnerability procedure 2023-04-14 09:52:02 +00:00
requirements-dev.txt Move to pyproject.toml, instead of setup.py (#5821) 2023-01-06 18:43:16 -01:00
requirements-tests.txt
requirements.txt
setup.cfg Techdebt: MyPy T (#6270) 2023-04-29 22:21:00 +00: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

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 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/

Security contact information

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