python3Packages.moto: 1.3.14 -> 1.3.16

This commit is contained in:
Robert T. McGibbon 2020-12-28 16:06:52 -05:00
parent c27538ee3f
commit 396fbd0302

View File

@ -1,7 +1,6 @@
{ lib, buildPythonPackage, fetchPypi, isPy27, fetchpatch { lib, buildPythonPackage, fetchPypi, isPy27, fetchpatch
, aws-xray-sdk , aws-xray-sdk
, backports_tempfile , backports_tempfile
, boto
, boto3 , boto3
, botocore , botocore
, cfn-lint , cfn-lint
@ -11,7 +10,6 @@
, jinja2 , jinja2
, jsondiff , jsondiff
, mock , mock
, nose
, pyaml , pyaml
, python-jose , python-jose
, pytz , pytz
@ -24,34 +22,42 @@
, xmltodict , xmltodict
, parameterized , parameterized
, idna , idna
, nose
, pytestCheckHook
}: }:
buildPythonPackage rec { buildPythonPackage rec {
pname = "moto"; pname = "moto";
version = "1.3.14"; version = "1.3.16";
src = fetchPypi { src = fetchPypi {
inherit pname version; inherit pname version;
sha256 = "0fm09074qic24h8rw9a0paklygyb7xd0ch4890y4v8lj2pnsxbkr"; sha256 = "0zy0prsyip264i6h03lxsn1qg1n3dc8c4iyfawckjqvm24gnns3c";
}; };
postPatch = '' postPatch = ''
substituteInPlace setup.py \ substituteInPlace setup.py \
--replace "jsondiff==1.1.2" "jsondiff~=1.1" --replace "ecdsa<0.15" "ecdsa"
sed -i '/datetime/d' setup.py # should be taken care of by std library
''; '';
patches = [ patches = [
# loosen idna upper limit # Remove dependence on boto. The boto library (long ago superseded by boto3)
# has not had an official release in over two years or even a commit in the
# last 18 months. These patches should be included in the next moto release
# after 1.3.16
(fetchpatch { (fetchpatch {
url = "https://github.com/spulec/moto/commit/649b497f71cce95a6474a3ff6f3c9c3339efb68f.patch"; url = "https://github.com/spulec/moto/pull/3503/commits/ae85c539fd57034c4d5cfd0f95af41ff19862dd1.patch";
sha256 = "03qdybzlskgbdadmlcg6ayxfp821b5iaa8q2542cwkcq7msqbbqc"; sha256 = "16hr2py6q701d8ih6zcvs3lbanshpbk15ixckgdqngjf160k5m9p";
excludes = ["tests/test_ec2/test_ec2_cloudformation.py"];
})
(fetchpatch {
url = "https://github.com/spulec/moto/pull/3468/commits/6ee39bd7fda4d3623569e10dcd9561bf2cd1d0bd.patch";
sha256 = "10m3xdqxgys7spav9mkbhcn4z0124rlprwxnw6ysb10610xlna0i";
}) })
]; ];
propagatedBuildInputs = [ propagatedBuildInputs = [
aws-xray-sdk aws-xray-sdk
boto
boto3 boto3
botocore botocore
cfn-lint cfn-lint
@ -72,26 +78,183 @@ buildPythonPackage rec {
idna idna
] ++ lib.optionals isPy27 [ backports_tempfile ]; ] ++ lib.optionals isPy27 [ backports_tempfile ];
checkInputs = [ boto3 freezegun nose sure parameterized ]; # Next release after 1.3.16 will not require `nose`
checkInputs = [ boto3 nose freezegun pytestCheckHook sure parameterized ];
checkPhase = '' # Multiple test files still import boto, rather than boto3 like
nosetests -v ./tests/ \ # boto is long-deprecated and broken on python3.9
-e test_invoke_function_from_sns \ # https://github.com/spulec/moto/blob/63ce647123755e4c4693a89f52c254596004c098/tests/test_autoscaling/test_autoscaling.py#L2
-e test_invoke_requestresponse_function \ # NOTE: This should change to use disabledTestFiles / disabledTestPaths once that
-e test_context_manager \ # feature stabalizes: see #113153 (mostly the discussion therein), #113167, #110700
-e test_decorator_start_and_stop \ pytestFlagsArray = [
-e test_invoke_event_function \ "--ignore=tests/test_awslambda/test_policy.py"
-e test_invoke_function_from_dynamodb \ "--ignore=tests/test_autoscaling/test_autoscaling.py"
-e test_invoke_function_from_sqs \ "--ignore=tests/test_autoscaling/test_cloudformation.py"
-e test_invoke_lambda_error \ "--ignore=tests/test_autoscaling/test_elbv2.py"
-e test_invoke_async_function \ "--ignore=tests/test_autoscaling/test_launch_configurations.py"
-e test_passthrough_requests "--ignore=tests/test_autoscaling/test_policies.py"
''; "--ignore=tests/test_autoscaling/test_server.py"
"--ignore=tests/test_awslambda/test_lambda.py"
"--ignore=tests/test_awslambda/test_lambda_cloudformation.py"
"--ignore=tests/test_batch/test_cloudformation.py"
"--ignore=tests/test_batch/test_server.py"
"--ignore=tests/test_cloudformation/test_cloudformation_depends_on.py"
"--ignore=tests/test_cloudformation/test_cloudformation_stack_crud.py"
"--ignore=tests/test_cloudformation/test_cloudformation_stack_crud_boto3.py"
"--ignore=tests/test_cloudformation/test_cloudformation_stack_integration.py"
"--ignore=tests/test_cloudformation/test_stack_parsing.py"
"--ignore=tests/test_cloudformation/test_validate.py"
"--ignore=tests/test_cloudwatch/test_cloudwatch.py"
"--ignore=tests/test_cognitoidentity/test_server.py"
"--ignore=tests/test_config/test_config.py"
"--ignore=tests/test_core/test_auth.py"
"--ignore=tests/test_core/test_decorator_calls.py"
"--ignore=tests/test_core/test_nested.py"
"--ignore=tests/test_core/test_server.py"
"--ignore=tests/test_datapipeline/test_datapipeline.py"
"--ignore=tests/test_datapipeline/test_server.py"
"--ignore=tests/test_datasync/test_datasync.py"
"--ignore=tests/test_dynamodb/test_dynamodb.py"
"--ignore=tests/test_dynamodb/test_dynamodb_table_with_range_key.py"
"--ignore=tests/test_dynamodb/test_dynamodb_table_without_range_key.py"
"--ignore=tests/test_dynamodb/test_server.py"
"--ignore=tests/test_dynamodb2/test_dynamodb.py"
"--ignore=tests/test_dynamodb2/test_dynamodb_table_with_range_key.py"
"--ignore=tests/test_dynamodb2/test_dynamodb_table_without_range_key.py"
"--ignore=tests/test_dynamodb2/test_server.py"
"--ignore=tests/test_ec2/test_amazon_dev_pay.py"
"--ignore=tests/test_ec2/test_amis.py"
"--ignore=tests/test_ec2/test_availability_zones_and_regions.py"
"--ignore=tests/test_ec2/test_customer_gateways.py"
"--ignore=tests/test_ec2/test_dhcp_options.py"
"--ignore=tests/test_ec2/test_elastic_block_store.py"
"--ignore=tests/test_ec2/test_elastic_ip_addresses.py"
"--ignore=tests/test_ec2/test_elastic_network_interfaces.py"
"--ignore=tests/test_ec2/test_general.py"
"--ignore=tests/test_ec2/test_instances.py"
"--ignore=tests/test_ec2/test_internet_gateways.py"
"--ignore=tests/test_ec2/test_ip_addresses.py"
"--ignore=tests/test_ec2/test_key_pairs.py"
"--ignore=tests/test_ec2/test_monitoring.py"
"--ignore=tests/test_ec2/test_network_acls.py"
"--ignore=tests/test_ec2/test_placement_groups.py"
"--ignore=tests/test_ec2/test_regions.py"
"--ignore=tests/test_ec2/test_reserved_instances.py"
"--ignore=tests/test_ec2/test_route_tables.py"
"--ignore=tests/test_ec2/test_security_groups.py"
"--ignore=tests/test_ec2/test_spot_instances.py"
"--ignore=tests/test_ec2/test_subnets.py"
"--ignore=tests/test_ec2/test_tags.py"
"--ignore=tests/test_ec2/test_virtual_private_gateways.py"
"--ignore=tests/test_ec2/test_vm_export.py"
"--ignore=tests/test_ec2/test_vm_import.py"
"--ignore=tests/test_ec2/test_vpc_peering.py"
"--ignore=tests/test_ec2/test_vpcs.py"
"--ignore=tests/test_ec2/test_vpn_connections.py"
"--ignore=tests/test_ec2/test_vpn_connections.py"
"--ignore=tests/test_ec2/test_windows.py"
"--ignore=tests/test_ecs/test_ecs_boto3.py"
"--ignore=tests/test_elb/test_elb.py"
"--ignore=tests/test_elb/test_server.py"
"--ignore=tests/test_elbv2/test_elbv2.py"
"--ignore=tests/test_elbv2/test_server.py"
"--ignore=tests/test_emr/test_emr.py"
"--ignore=tests/test_emr/test_server.py"
"--ignore=tests/test_glacier/test_glacier_archives.py"
"--ignore=tests/test_glacier/test_glacier_jobs.py"
"--ignore=tests/test_glacier/test_glacier_vaults.py"
"--ignore=tests/test_iam/test_iam.py"
"--ignore=tests/test_iam/test_iam_cloudformation.py"
"--ignore=tests/test_iam/test_iam_groups.py"
"--ignore=tests/test_iam/test_server.py"
"--ignore=tests/test_iot/test_server.py"
"--ignore=tests/test_iotdata/test_server.py"
"--ignore=tests/test_kinesis/test_kinesis.py"
"--ignore=tests/test_kinesis/test_kinesis_cloudformation.py"
"--ignore=tests/test_kinesis/test_server.py"
"--ignore=tests/test_kinesisvideo/test_server.py"
"--ignore=tests/test_kinesisvideoarchivedmedia/test_server.py"
"--ignore=tests/test_kms/test_kms.py"
"--ignore=tests/test_kms/test_server.py"
"--ignore=tests/test_kms/test_utils.py"
"--ignore=tests/test_logs/test_logs.py"
"--ignore=tests/test_polly/test_server.py"
"--ignore=tests/test_rds/test_rds.py"
"--ignore=tests/test_rds/test_server.py"
"--ignore=tests/test_rds2/test_server.py"
"--ignore=tests/test_redshift/test_redshift.py"
"--ignore=tests/test_redshift/test_server.py"
"--ignore=tests/test_resourcegroupstaggingapi/test_resourcegroupstaggingapi.py"
"--ignore=tests/test_route53/test_route53.py"
"--ignore=tests/test_s3/test_s3.py"
"--ignore=tests/test_s3/test_s3_cloudformation.py"
"--ignore=tests/test_s3/test_s3_lifecycle.py"
"--ignore=tests/test_s3/test_s3_storageclass.py"
"--ignore=tests/test_s3/test_s3_utils.py"
"--ignore=tests/test_s3bucket_path/test_s3bucket_path.py"
"--ignore=tests/test_s3bucket_path/test_s3bucket_path_combo.py"
"--ignore=tests/test_secretsmanager/test_server.py"
"--ignore=tests/test_ses/test_server.py"
"--ignore=tests/test_ses/test_ses.py"
"--ignore=tests/test_ses/test_ses_boto3.py"
"--ignore=tests/test_ses/test_ses_sns_boto3.py"
"--ignore=tests/test_sns/test_application.py"
"--ignore=tests/test_sns/test_application_boto3.py"
"--ignore=tests/test_sns/test_publishing.py"
"--ignore=tests/test_sns/test_publishing_boto3.py"
"--ignore=tests/test_sns/test_server.py"
"--ignore=tests/test_sns/test_subscriptions.py"
"--ignore=tests/test_sns/test_subscriptions_boto3.py"
"--ignore=tests/test_sns/test_topics.py"
"--ignore=tests/test_sns/test_topics_boto3.py"
"--ignore=tests/test_sqs/test_server.py"
"--ignore=tests/test_sqs/test_sqs.py"
"--ignore=tests/test_ssm/test_ssm_boto3.py"
"--ignore=tests/test_ssm/test_ssm_docs.py"
"--ignore=tests/test_sts/test_server.py"
"--ignore=tests/test_sts/test_sts.py"
"--ignore=tests/test_swf/models/test_activity_task.py"
"--ignore=tests/test_swf/models/test_decision_task.py"
"--ignore=tests/test_swf/models/test_timeout.py"
"--ignore=tests/test_swf/models/test_workflow_execution.py"
"--ignore=tests/test_swf/responses/test_activity_tasks.py"
"--ignore=tests/test_swf/responses/test_activity_types.py"
"--ignore=tests/test_swf/responses/test_decision_tasks.py"
"--ignore=tests/test_swf/responses/test_domains.py"
"--ignore=tests/test_swf/responses/test_timeouts.py"
"--ignore=tests/test_swf/responses/test_workflow_executions.py"
"--ignore=tests/test_swf/responses/test_workflow_types.py"
];
# Disabling because of 20 failing tests due to https://github.com/spulec/moto/issues/2728 disabledTests = [
# We should enable these as soon as possible again though. Note the issue # these tests rely on the network
# is unrelated to the docutils 0.16 bump. "test_server"
doCheck = false; "test_managedblockchain_nodes"
"test_swf"
"test_simple_instance"
"test_passthrough_requests"
"test_s3_server_get"
"test_s3_server_bucket_create"
"test_s3_server_post_to_bucket"
"test_s3_server_put_ipv6"
"test_s3_server_put_ipv4"
"test_http_proxying_integration"
"test_submit_job_by_name"
"test_submit_job"
"test_list_jobs"
"test_terminate_job"
"test_idtoken_contains_kid_header"
"test_latest_meta_data"
"test_meta_data_iam"
"test_meta_data_security_credentials"
"test_meta_data_default_role"
"test_reset_api"
"test_data_api"
"test_requests_to_amazon_subdomains_dont_work"
"test_get_records_seq"
"test_stream_with_range_key"
"test_create_notebook_instance_bad_volume_size"
];
meta = with lib; { meta = with lib; {
description = "Allows your tests to easily mock out AWS Services"; description = "Allows your tests to easily mock out AWS Services";