File: PKG-INFO

package info (click to toggle)
python-moto 5.1.18-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 116,520 kB
  • sloc: python: 636,725; javascript: 181; makefile: 39; sh: 3
file content (325 lines) | stat: -rw-r--r-- 12,195 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
Metadata-Version: 2.4
Name: moto
Version: 5.1.18
Summary: A library that allows you to easily mock out tests based on AWS infrastructure
Home-page: https://github.com/getmoto/moto
Author: Steve Pulec
Author-email: spulec@gmail.com
License: Apache-2.0
Project-URL: Documentation, http://docs.getmoto.org/en/latest/
Project-URL: Issue tracker, https://github.com/getmoto/moto/issues
Project-URL: Changelog, https://github.com/getmoto/moto/blob/master/CHANGELOG.md
Keywords: aws ec2 s3 boto3 mock
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3.14
Classifier: Topic :: Software Development :: Testing
Requires-Python: >=3.9
Description-Content-Type: text/markdown
License-File: LICENSE
License-File: AUTHORS.md
Requires-Dist: boto3>=1.9.201
Requires-Dist: botocore!=1.35.45,!=1.35.46,>=1.20.88
Requires-Dist: cryptography>=35.0.0
Requires-Dist: requests>=2.5
Requires-Dist: xmltodict
Requires-Dist: werkzeug!=2.2.0,!=2.2.1,>=0.5
Requires-Dist: python-dateutil<3.0.0,>=2.1
Requires-Dist: responses!=0.25.5,>=0.15.0
Requires-Dist: Jinja2>=2.10.1
Provides-Extra: all
Requires-Dist: antlr4-python3-runtime; extra == "all"
Requires-Dist: joserfc>=0.9.0; extra == "all"
Requires-Dist: jsonpath_ng; extra == "all"
Requires-Dist: docker>=3.0.0; extra == "all"
Requires-Dist: graphql-core; extra == "all"
Requires-Dist: PyYAML>=5.1; extra == "all"
Requires-Dist: cfn-lint>=0.40.0; extra == "all"
Requires-Dist: jsonschema; extra == "all"
Requires-Dist: openapi-spec-validator>=0.5.0; extra == "all"
Requires-Dist: pyparsing>=3.0.7; extra == "all"
Requires-Dist: py-partiql-parser==0.6.3; extra == "all"
Requires-Dist: aws-xray-sdk!=0.96,>=0.93; extra == "all"
Requires-Dist: setuptools; extra == "all"
Requires-Dist: multipart; extra == "all"
Provides-Extra: proxy
Requires-Dist: antlr4-python3-runtime; extra == "proxy"
Requires-Dist: joserfc>=0.9.0; extra == "proxy"
Requires-Dist: jsonpath_ng; extra == "proxy"
Requires-Dist: docker>=2.5.1; extra == "proxy"
Requires-Dist: graphql-core; extra == "proxy"
Requires-Dist: PyYAML>=5.1; extra == "proxy"
Requires-Dist: cfn-lint>=0.40.0; extra == "proxy"
Requires-Dist: openapi-spec-validator>=0.5.0; extra == "proxy"
Requires-Dist: pyparsing>=3.0.7; extra == "proxy"
Requires-Dist: py-partiql-parser==0.6.3; extra == "proxy"
Requires-Dist: aws-xray-sdk!=0.96,>=0.93; extra == "proxy"
Requires-Dist: setuptools; extra == "proxy"
Requires-Dist: multipart; extra == "proxy"
Provides-Extra: server
Requires-Dist: antlr4-python3-runtime; extra == "server"
Requires-Dist: joserfc>=0.9.0; extra == "server"
Requires-Dist: jsonpath_ng; extra == "server"
Requires-Dist: docker>=3.0.0; extra == "server"
Requires-Dist: graphql-core; extra == "server"
Requires-Dist: PyYAML>=5.1; extra == "server"
Requires-Dist: cfn-lint>=0.40.0; extra == "server"
Requires-Dist: openapi-spec-validator>=0.5.0; extra == "server"
Requires-Dist: pyparsing>=3.0.7; extra == "server"
Requires-Dist: py-partiql-parser==0.6.3; extra == "server"
Requires-Dist: aws-xray-sdk!=0.96,>=0.93; extra == "server"
Requires-Dist: setuptools; extra == "server"
Requires-Dist: flask!=2.2.0,!=2.2.1; extra == "server"
Requires-Dist: flask-cors; extra == "server"
Provides-Extra: acm
Provides-Extra: acmpca
Provides-Extra: amp
Provides-Extra: apigateway
Requires-Dist: PyYAML>=5.1; extra == "apigateway"
Requires-Dist: joserfc>=0.9.0; extra == "apigateway"
Requires-Dist: openapi-spec-validator>=0.5.0; extra == "apigateway"
Provides-Extra: apigatewayv2
Requires-Dist: PyYAML>=5.1; extra == "apigatewayv2"
Requires-Dist: openapi-spec-validator>=0.5.0; extra == "apigatewayv2"
Provides-Extra: applicationautoscaling
Provides-Extra: appsync
Requires-Dist: graphql-core; extra == "appsync"
Provides-Extra: athena
Provides-Extra: autoscaling
Provides-Extra: awslambda
Requires-Dist: docker>=3.0.0; extra == "awslambda"
Provides-Extra: awslambda-simple
Provides-Extra: backup
Provides-Extra: batch
Requires-Dist: docker>=3.0.0; extra == "batch"
Provides-Extra: batch-simple
Provides-Extra: budgets
Provides-Extra: ce
Provides-Extra: cloudformation
Requires-Dist: joserfc>=0.9.0; extra == "cloudformation"
Requires-Dist: docker>=3.0.0; extra == "cloudformation"
Requires-Dist: graphql-core; extra == "cloudformation"
Requires-Dist: PyYAML>=5.1; extra == "cloudformation"
Requires-Dist: cfn-lint>=0.40.0; extra == "cloudformation"
Requires-Dist: openapi-spec-validator>=0.5.0; extra == "cloudformation"
Requires-Dist: pyparsing>=3.0.7; extra == "cloudformation"
Requires-Dist: py-partiql-parser==0.6.3; extra == "cloudformation"
Requires-Dist: aws-xray-sdk!=0.96,>=0.93; extra == "cloudformation"
Requires-Dist: setuptools; extra == "cloudformation"
Provides-Extra: cloudfront
Provides-Extra: cloudtrail
Provides-Extra: cloudwatch
Provides-Extra: codebuild
Provides-Extra: codecommit
Provides-Extra: codepipeline
Provides-Extra: cognitoidentity
Provides-Extra: cognitoidp
Requires-Dist: joserfc>=0.9.0; extra == "cognitoidp"
Provides-Extra: comprehend
Provides-Extra: config
Provides-Extra: databrew
Provides-Extra: datapipeline
Provides-Extra: datasync
Provides-Extra: dax
Provides-Extra: dms
Provides-Extra: ds
Provides-Extra: dynamodb
Requires-Dist: docker>=3.0.0; extra == "dynamodb"
Requires-Dist: py-partiql-parser==0.6.3; extra == "dynamodb"
Provides-Extra: dynamodbstreams
Requires-Dist: docker>=3.0.0; extra == "dynamodbstreams"
Requires-Dist: py-partiql-parser==0.6.3; extra == "dynamodbstreams"
Provides-Extra: ebs
Provides-Extra: ec2
Provides-Extra: ec2instanceconnect
Provides-Extra: ecr
Provides-Extra: ecs
Provides-Extra: efs
Provides-Extra: eks
Provides-Extra: elasticache
Provides-Extra: elasticbeanstalk
Provides-Extra: elastictranscoder
Provides-Extra: elb
Provides-Extra: elbv2
Provides-Extra: emr
Provides-Extra: emrcontainers
Provides-Extra: emrserverless
Provides-Extra: es
Provides-Extra: events
Requires-Dist: jsonpath_ng; extra == "events"
Provides-Extra: firehose
Provides-Extra: forecast
Provides-Extra: glacier
Provides-Extra: glue
Requires-Dist: pyparsing>=3.0.7; extra == "glue"
Provides-Extra: greengrass
Provides-Extra: guardduty
Provides-Extra: iam
Provides-Extra: inspector2
Provides-Extra: iot
Provides-Extra: iotdata
Provides-Extra: ivs
Provides-Extra: kinesis
Provides-Extra: kinesisvideo
Provides-Extra: kinesisvideoarchivedmedia
Provides-Extra: kms
Provides-Extra: logs
Provides-Extra: managedblockchain
Provides-Extra: mediaconnect
Provides-Extra: medialive
Provides-Extra: mediapackage
Provides-Extra: mediastore
Provides-Extra: mediastoredata
Provides-Extra: meteringmarketplace
Provides-Extra: mq
Provides-Extra: opsworks
Provides-Extra: organizations
Provides-Extra: panorama
Provides-Extra: personalize
Provides-Extra: pinpoint
Provides-Extra: polly
Provides-Extra: quicksight
Requires-Dist: jsonschema; extra == "quicksight"
Provides-Extra: ram
Provides-Extra: rds
Provides-Extra: redshift
Provides-Extra: redshiftdata
Provides-Extra: rekognition
Provides-Extra: resourcegroups
Provides-Extra: resourcegroupstaggingapi
Requires-Dist: joserfc>=0.9.0; extra == "resourcegroupstaggingapi"
Requires-Dist: docker>=3.0.0; extra == "resourcegroupstaggingapi"
Requires-Dist: graphql-core; extra == "resourcegroupstaggingapi"
Requires-Dist: PyYAML>=5.1; extra == "resourcegroupstaggingapi"
Requires-Dist: cfn-lint>=0.40.0; extra == "resourcegroupstaggingapi"
Requires-Dist: openapi-spec-validator>=0.5.0; extra == "resourcegroupstaggingapi"
Requires-Dist: pyparsing>=3.0.7; extra == "resourcegroupstaggingapi"
Requires-Dist: py-partiql-parser==0.6.3; extra == "resourcegroupstaggingapi"
Provides-Extra: route53
Provides-Extra: route53resolver
Provides-Extra: s3
Requires-Dist: PyYAML>=5.1; extra == "s3"
Requires-Dist: py-partiql-parser==0.6.3; extra == "s3"
Provides-Extra: s3crc32c
Requires-Dist: PyYAML>=5.1; extra == "s3crc32c"
Requires-Dist: py-partiql-parser==0.6.3; extra == "s3crc32c"
Requires-Dist: crc32c; extra == "s3crc32c"
Provides-Extra: s3control
Provides-Extra: sagemaker
Provides-Extra: sdb
Provides-Extra: scheduler
Provides-Extra: secretsmanager
Provides-Extra: servicediscovery
Provides-Extra: servicequotas
Provides-Extra: ses
Provides-Extra: signer
Provides-Extra: sns
Provides-Extra: sqs
Provides-Extra: ssm
Requires-Dist: PyYAML>=5.1; extra == "ssm"
Provides-Extra: ssoadmin
Provides-Extra: stepfunctions
Requires-Dist: antlr4-python3-runtime; extra == "stepfunctions"
Requires-Dist: jsonpath_ng; extra == "stepfunctions"
Provides-Extra: sts
Provides-Extra: support
Provides-Extra: swf
Provides-Extra: textract
Provides-Extra: timestreamwrite
Provides-Extra: transcribe
Provides-Extra: wafv2
Provides-Extra: xray
Requires-Dist: aws-xray-sdk!=0.96,>=0.93; extra == "xray"
Requires-Dist: setuptools; extra == "xray"
Dynamic: license-file

# Moto - Mock AWS Services

[![Join the chat at https://gitter.im/awsmoto/Lobby](https://badges.gitter.im/awsmoto/Lobby.svg)](https://gitter.im/awsmoto/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)

[![Build Status](https://github.com/getmoto/moto/workflows/TestNDeploy/badge.svg)](https://github.com/getmoto/moto/actions)
[![Coverage Status](https://codecov.io/gh/getmoto/moto/branch/master/graph/badge.svg)](https://codecov.io/gh/getmoto/moto)
[![Docs](https://readthedocs.org/projects/pip/badge/?version=stable)](http://docs.getmoto.org)
[![PyPI](https://img.shields.io/pypi/v/moto.svg)](https://pypi.org/project/moto/)
[![PyPI - Python Version](https://img.shields.io/pypi/pyversions/moto.svg)](#)
[![PyPI - Downloads](https://img.shields.io/pypi/dw/moto.svg)](https://pypistats.org/packages/moto)
[![Code style: Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json)](https://github.com/astral-sh/ruff)
[![Financial Contributors](https://opencollective.com/moto/tiers/badge.svg)](https://opencollective.com/moto)


## Install

```console
$ 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:

```python
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:

```python
import boto3
from moto import mock_aws
from mymodule import MyModel


@mock_aws
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](https://github.com/getmoto/moto/blob/master/IMPLEMENTATION_COVERAGE.md).


### Documentation
The full documentation can be found here:

[http://docs.getmoto.org/en/latest/](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](https://tidelift.com/security).
Tidelift will coordinate the fix and disclosure.