fog-aws 3.9.0 → 3.13.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +251 -17
- data/README.md +1 -1
- data/fog-aws.gemspec +6 -6
- data/lib/fog/aws/compute.rb +6 -3
- data/lib/fog/aws/credential_fetcher.rb +14 -7
- data/lib/fog/aws/models/compute/security_group.rb +13 -5
- data/lib/fog/aws/models/compute/server.rb +2 -0
- data/lib/fog/aws/models/storage/file.rb +21 -17
- data/lib/fog/aws/parsers/compute/describe_security_groups.rb +18 -4
- data/lib/fog/aws/requests/compute/authorize_security_group_ingress.rb +15 -0
- data/lib/fog/aws/requests/compute/create_network_interface.rb +7 -4
- data/lib/fog/aws/requests/compute/create_subnet.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_security_groups.rb +2 -0
- data/lib/fog/aws/requests/compute/run_instances.rb +44 -0
- data/lib/fog/aws/requests/storage/delete_multiple_objects.rb +18 -8
- data/lib/fog/aws/requests/storage/get_object.rb +1 -1
- data/lib/fog/aws/storage.rb +42 -3
- data/lib/fog/aws/version.rb +1 -1
- metadata +11 -297
- data/.gitignore +0 -17
- data/.travis.yml +0 -124
- data/Gemfile +0 -14
- data/Rakefile +0 -14
- data/bin/console +0 -14
- data/bin/setup +0 -8
- data/gemfiles/Gemfile-edge +0 -14
- data/gemfiles/Gemfile-ruby-2.0 +0 -7
- data/stale.yml +0 -17
- data/tests/credentials_tests.rb +0 -149
- data/tests/helper.rb +0 -29
- data/tests/helpers/collection_helper.rb +0 -90
- data/tests/helpers/compute/flavors_helper.rb +0 -28
- data/tests/helpers/compute/server_helper.rb +0 -23
- data/tests/helpers/compute/servers_helper.rb +0 -8
- data/tests/helpers/dns_helper.rb +0 -56
- data/tests/helpers/formats_helper.rb +0 -100
- data/tests/helpers/formats_helper_tests.rb +0 -107
- data/tests/helpers/mock_helper.rb +0 -109
- data/tests/helpers/model_helper.rb +0 -30
- data/tests/helpers/responds_to_helper.rb +0 -11
- data/tests/helpers/schema_validator_tests.rb +0 -104
- data/tests/helpers/succeeds_helper.rb +0 -9
- data/tests/lorem.txt +0 -1
- data/tests/models/auto_scaling/activities_tests.rb +0 -6
- data/tests/models/auto_scaling/configuration_test.rb +0 -13
- data/tests/models/auto_scaling/configurations_tests.rb +0 -11
- data/tests/models/auto_scaling/groups_test.rb +0 -27
- data/tests/models/auto_scaling/helper.rb +0 -0
- data/tests/models/auto_scaling/instance_tests.rb +0 -15
- data/tests/models/auto_scaling/instances_tests.rb +0 -6
- data/tests/models/beanstalk/application_tests.rb +0 -69
- data/tests/models/beanstalk/applications_tests.rb +0 -7
- data/tests/models/beanstalk/environment_tests.rb +0 -131
- data/tests/models/beanstalk/environments_tests.rb +0 -34
- data/tests/models/beanstalk/template_tests.rb +0 -47
- data/tests/models/beanstalk/templates_tests.rb +0 -62
- data/tests/models/beanstalk/version_tests.rb +0 -66
- data/tests/models/beanstalk/versions_tests.rb +0 -60
- data/tests/models/cdn/distribution_tests.rb +0 -15
- data/tests/models/cdn/distributions_tests.rb +0 -15
- data/tests/models/cdn/invalidation_tests.rb +0 -31
- data/tests/models/cdn/invalidations_tests.rb +0 -14
- data/tests/models/cdn/streaming_distribution_tests.rb +0 -15
- data/tests/models/cdn/streaming_distributions_tests.rb +0 -15
- data/tests/models/cloud_watch/alarm_data_tests.rb +0 -42
- data/tests/models/cloud_watch/alarm_history_tests.rb +0 -22
- data/tests/models/cloud_watch/metric_statistics_tests.rb +0 -51
- data/tests/models/cloud_watch/metrics_tests.rb +0 -32
- data/tests/models/compute/address_tests.rb +0 -43
- data/tests/models/compute/addresses_tests.rb +0 -5
- data/tests/models/compute/dhcp_option_tests.rb +0 -3
- data/tests/models/compute/dhcp_options_tests.rb +0 -3
- data/tests/models/compute/internet_gateway_tests.rb +0 -3
- data/tests/models/compute/internet_gateways_tests.rb +0 -3
- data/tests/models/compute/key_pair_tests.rb +0 -26
- data/tests/models/compute/key_pairs_tests.rb +0 -5
- data/tests/models/compute/network_acl_tests.rb +0 -109
- data/tests/models/compute/network_acls_tests.rb +0 -20
- data/tests/models/compute/network_interfaces_test.rb +0 -12
- data/tests/models/compute/security_group_tests.rb +0 -98
- data/tests/models/compute/security_groups_tests.rb +0 -5
- data/tests/models/compute/server_tests.rb +0 -94
- data/tests/models/compute/snapshot_tests.rb +0 -10
- data/tests/models/compute/snapshots_tests.rb +0 -10
- data/tests/models/compute/subnet_tests.rb +0 -13
- data/tests/models/compute/subnets_tests.rb +0 -5
- data/tests/models/compute/volume_tests.rb +0 -65
- data/tests/models/compute/volumes_tests.rb +0 -5
- data/tests/models/compute/vpc_tests.rb +0 -26
- data/tests/models/compute/vpcs_tests.rb +0 -19
- data/tests/models/data_pipeline/pipeline_tests.rb +0 -8
- data/tests/models/data_pipeline/pipelines_tests.rb +0 -8
- data/tests/models/dns/record_tests.rb +0 -33
- data/tests/models/dns/records_tests.rb +0 -41
- data/tests/models/dns/zone_tests.rb +0 -4
- data/tests/models/dns/zones_tests.rb +0 -4
- data/tests/models/efs/file_system_tests.rb +0 -12
- data/tests/models/efs/mount_target_tests.rb +0 -45
- data/tests/models/efs/mount_targets_tests.rb +0 -30
- data/tests/models/elasticache/cluster_tests.rb +0 -30
- data/tests/models/elasticache/parameter_groups_tests.rb +0 -15
- data/tests/models/elasticache/security_groups_tests.rb +0 -52
- data/tests/models/elasticache/subnet_groups_tests.rb +0 -43
- data/tests/models/elb/model_tests.rb +0 -360
- data/tests/models/elb/tagging_tests.rb +0 -15
- data/tests/models/glacier/model_tests.rb +0 -47
- data/tests/models/iam/access_keys_tests.rb +0 -53
- data/tests/models/iam/groups_tests.rb +0 -59
- data/tests/models/iam/instance_profile_tests.rb +0 -18
- data/tests/models/iam/managed_policies_tests.rb +0 -89
- data/tests/models/iam/policies_tests.rb +0 -57
- data/tests/models/iam/roles_tests.rb +0 -71
- data/tests/models/iam/users_tests.rb +0 -119
- data/tests/models/rds/cluster_tests.rb +0 -54
- data/tests/models/rds/clusters_tests.rb +0 -5
- data/tests/models/rds/event_subscription_tests.rb +0 -9
- data/tests/models/rds/event_subscriptions_tests.rb +0 -6
- data/tests/models/rds/helper.rb +0 -25
- data/tests/models/rds/instance_option_tests.rb +0 -14
- data/tests/models/rds/parameter_group_tests.rb +0 -24
- data/tests/models/rds/parameter_groups_tests.rb +0 -8
- data/tests/models/rds/security_group_tests.rb +0 -77
- data/tests/models/rds/security_groups_tests.rb +0 -5
- data/tests/models/rds/server_tests.rb +0 -131
- data/tests/models/rds/servers_tests.rb +0 -24
- data/tests/models/rds/snapshot_tests.rb +0 -12
- data/tests/models/rds/snapshots_tests.rb +0 -12
- data/tests/models/rds/tagging_tests.rb +0 -20
- data/tests/models/sns/topic_tests.rb +0 -15
- data/tests/models/sns/topics_tests.rb +0 -6
- data/tests/models/storage/directory_tests.rb +0 -91
- data/tests/models/storage/file_tests.rb +0 -129
- data/tests/models/storage/files_tests.rb +0 -90
- data/tests/models/storage/url_tests.rb +0 -25
- data/tests/models/storage/version_tests.rb +0 -52
- data/tests/models/storage/versions_tests.rb +0 -51
- data/tests/models/support/trusted_advisor_tests.rb +0 -25
- data/tests/parsers/compute/describe_images_tests.rb +0 -33
- data/tests/parsers/elb/describe_load_balancers.rb +0 -65
- data/tests/parsers/elbv2/create_load_balancer_tests.rb +0 -48
- data/tests/parsers/elbv2/describe_listeners_tests.rb +0 -76
- data/tests/parsers/elbv2/describe_load_balancers_tests.rb +0 -54
- data/tests/parsers/elbv2/describe_tags_tests.rb +0 -35
- data/tests/requests/auto_scaling/auto_scaling_tests.rb +0 -111
- data/tests/requests/auto_scaling/describe_types_tests.rb +0 -102
- data/tests/requests/auto_scaling/helper.rb +0 -229
- data/tests/requests/auto_scaling/model_tests.rb +0 -235
- data/tests/requests/auto_scaling/notification_configuration_tests.rb +0 -124
- data/tests/requests/auto_scaling/tag_tests.rb +0 -63
- data/tests/requests/beanstalk/application_tests.rb +0 -140
- data/tests/requests/beanstalk/solution_stack_tests.rb +0 -22
- data/tests/requests/cdn/cdn_tests.rb +0 -252
- data/tests/requests/cloud_formation/stack_tests.rb +0 -167
- data/tests/requests/cloud_watch/get_metric_statistics_tests.rb +0 -28
- data/tests/requests/cloud_watch/list_metrics_test.rb +0 -64
- data/tests/requests/cloud_watch/put_metric_data_tests.rb +0 -36
- data/tests/requests/compute/address_tests.rb +0 -144
- data/tests/requests/compute/assign_private_ip_tests.rb +0 -55
- data/tests/requests/compute/availability_zone_tests.rb +0 -25
- data/tests/requests/compute/client_tests.rb +0 -25
- data/tests/requests/compute/dhcp_options_tests.rb +0 -39
- data/tests/requests/compute/helper.rb +0 -27
- data/tests/requests/compute/image_tests.rb +0 -169
- data/tests/requests/compute/instance_attrib_tests.rb +0 -168
- data/tests/requests/compute/instance_tests.rb +0 -338
- data/tests/requests/compute/internet_gateway_tests.rb +0 -49
- data/tests/requests/compute/key_pair_tests.rb +0 -67
- data/tests/requests/compute/network_acl_tests.rb +0 -112
- data/tests/requests/compute/network_interface_tests.rb +0 -239
- data/tests/requests/compute/placement_group_tests.rb +0 -48
- data/tests/requests/compute/region_tests.rb +0 -52
- data/tests/requests/compute/route_tests.rb +0 -341
- data/tests/requests/compute/security_group_tests.rb +0 -446
- data/tests/requests/compute/snapshot_tests.rb +0 -77
- data/tests/requests/compute/spot_datafeed_subscription_tests.rb +0 -47
- data/tests/requests/compute/spot_instance_tests.rb +0 -55
- data/tests/requests/compute/spot_price_history_tests.rb +0 -23
- data/tests/requests/compute/subnet_tests.rb +0 -87
- data/tests/requests/compute/tag_tests.rb +0 -101
- data/tests/requests/compute/volume_tests.rb +0 -263
- data/tests/requests/compute/vpc_tests.rb +0 -222
- data/tests/requests/data_pipeline/helper.rb +0 -78
- data/tests/requests/data_pipeline/pipeline_tests.rb +0 -80
- data/tests/requests/dns/change_resource_record_sets_tests.rb +0 -34
- data/tests/requests/dns/dns_tests.rb +0 -240
- data/tests/requests/dns/health_check_tests.rb +0 -159
- data/tests/requests/dns/helper.rb +0 -21
- data/tests/requests/dynamodb/item_tests.rb +0 -137
- data/tests/requests/dynamodb/table_tests.rb +0 -99
- data/tests/requests/ecs/cluster_tests.rb +0 -112
- data/tests/requests/ecs/container_instance_tests.rb +0 -119
- data/tests/requests/ecs/helper.rb +0 -276
- data/tests/requests/ecs/sample_task_definition1.json +0 -56
- data/tests/requests/ecs/service_tests.rb +0 -132
- data/tests/requests/ecs/task_definitions_tests.rb +0 -97
- data/tests/requests/ecs/task_tests.rb +0 -145
- data/tests/requests/efs/file_system_tests.rb +0 -152
- data/tests/requests/efs/helper.rb +0 -44
- data/tests/requests/elasticache/cache_cluster_tests.rb +0 -137
- data/tests/requests/elasticache/describe_events.rb +0 -17
- data/tests/requests/elasticache/describe_reserved_cache_nodes.rb +0 -17
- data/tests/requests/elasticache/helper.rb +0 -103
- data/tests/requests/elasticache/parameter_group_tests.rb +0 -105
- data/tests/requests/elasticache/security_group_tests.rb +0 -108
- data/tests/requests/elasticache/subnet_group_tests.rb +0 -52
- data/tests/requests/elb/helper.rb +0 -91
- data/tests/requests/elb/listener_tests.rb +0 -68
- data/tests/requests/elb/load_balancer_tests.rb +0 -89
- data/tests/requests/elb/policy_tests.rb +0 -132
- data/tests/requests/elbv2/helper.rb +0 -66
- data/tests/requests/elbv2/load_balancer_tests.rb +0 -50
- data/tests/requests/emr/helper.rb +0 -167
- data/tests/requests/emr/instance_group_tests.rb +0 -106
- data/tests/requests/emr/job_flow_tests.rb +0 -88
- data/tests/requests/federation/get_signin_token_tests.rb +0 -11
- data/tests/requests/glacier/archive_tests.rb +0 -13
- data/tests/requests/glacier/multipart_upload_tests.rb +0 -29
- data/tests/requests/glacier/tree_hash_tests.rb +0 -91
- data/tests/requests/glacier/vault_tests.rb +0 -35
- data/tests/requests/iam/access_key_tests.rb +0 -53
- data/tests/requests/iam/account_policy_tests.rb +0 -20
- data/tests/requests/iam/account_tests.rb +0 -34
- data/tests/requests/iam/group_policy_tests.rb +0 -48
- data/tests/requests/iam/group_tests.rb +0 -44
- data/tests/requests/iam/helper.rb +0 -154
- data/tests/requests/iam/instance_profile_tests.rb +0 -44
- data/tests/requests/iam/login_profile_tests.rb +0 -62
- data/tests/requests/iam/managed_policy_tests.rb +0 -110
- data/tests/requests/iam/mfa_tests.rb +0 -23
- data/tests/requests/iam/role_tests.rb +0 -156
- data/tests/requests/iam/server_certificate_tests.rb +0 -130
- data/tests/requests/iam/user_policy_tests.rb +0 -45
- data/tests/requests/iam/user_tests.rb +0 -78
- data/tests/requests/iam/versioned_managed_policy_tests.rb +0 -105
- data/tests/requests/kinesis/helper.rb +0 -111
- data/tests/requests/kinesis/stream_tests.rb +0 -169
- data/tests/requests/kms/helper.rb +0 -27
- data/tests/requests/kms/key_tests.rb +0 -23
- data/tests/requests/lambda/function_sample_1.js +0 -9
- data/tests/requests/lambda/function_sample_2.js +0 -9
- data/tests/requests/lambda/function_tests.rb +0 -460
- data/tests/requests/lambda/helper.rb +0 -81
- data/tests/requests/rds/cluster_snapshot_tests.rb +0 -43
- data/tests/requests/rds/cluster_tests.rb +0 -37
- data/tests/requests/rds/db_engine_versions.rb +0 -7
- data/tests/requests/rds/db_snapshot_tests.rb +0 -62
- data/tests/requests/rds/describe_events.rb +0 -16
- data/tests/requests/rds/event_subscription_tests.rb +0 -30
- data/tests/requests/rds/helper.rb +0 -406
- data/tests/requests/rds/instance_option_tests.rb +0 -27
- data/tests/requests/rds/instance_tests.rb +0 -149
- data/tests/requests/rds/log_file_tests.rb +0 -19
- data/tests/requests/rds/parameter_group_tests.rb +0 -62
- data/tests/requests/rds/parameter_request_tests.rb +0 -32
- data/tests/requests/rds/security_group_tests.rb +0 -101
- data/tests/requests/rds/subnet_groups_tests.rb +0 -52
- data/tests/requests/rds/tagging_tests.rb +0 -78
- data/tests/requests/redshift/cluster_parameter_group_tests.rb +0 -76
- data/tests/requests/redshift/cluster_security_group_tests.rb +0 -42
- data/tests/requests/redshift/cluster_snapshot_tests.rb +0 -73
- data/tests/requests/redshift/cluster_tests.rb +0 -80
- data/tests/requests/ses/helper.rb +0 -9
- data/tests/requests/ses/verified_domain_identity_tests.rb +0 -16
- data/tests/requests/ses/verified_email_address_tests.rb +0 -27
- data/tests/requests/simpledb/attributes_tests.rb +0 -86
- data/tests/requests/simpledb/domain_tests.rb +0 -51
- data/tests/requests/simpledb/helper.rb +0 -10
- data/tests/requests/sns/helper.rb +0 -9
- data/tests/requests/sns/subscription_tests.rb +0 -86
- data/tests/requests/sns/topic_tests.rb +0 -53
- data/tests/requests/sqs/helper.rb +0 -9
- data/tests/requests/sqs/message_tests.rb +0 -51
- data/tests/requests/sqs/queue_tests.rb +0 -50
- data/tests/requests/storage/acl_utils_tests.rb +0 -209
- data/tests/requests/storage/bucket_tests.rb +0 -416
- data/tests/requests/storage/cors_utils_tests.rb +0 -108
- data/tests/requests/storage/delete_multiple_objects_tests.rb +0 -12
- data/tests/requests/storage/multipart_copy_tests.rb +0 -93
- data/tests/requests/storage/multipart_upload_tests.rb +0 -121
- data/tests/requests/storage/object_tests.rb +0 -269
- data/tests/requests/storage/versioning_tests.rb +0 -262
- data/tests/requests/sts/assume_role_tests.rb +0 -19
- data/tests/requests/sts/assume_role_with_saml_tests.rb +0 -18
- data/tests/requests/sts/assume_role_with_web_identity_tests.rb +0 -28
- data/tests/requests/sts/get_federation_token_tests.rb +0 -20
- data/tests/requests/sts/session_token_tests.rb +0 -16
- data/tests/requests/support/helper.rb +0 -43
- data/tests/requests/support/trusted_advisor_check_tests.rb +0 -16
- data/tests/signaturev4_tests.rb +0 -106
- data/tests/signed_params_tests.rb +0 -17
- data/tests/storage_tests.rb +0 -7
@@ -1,66 +0,0 @@
|
|
1
|
-
class AWS
|
2
|
-
module ELBV2
|
3
|
-
module Formats
|
4
|
-
BASIC = {
|
5
|
-
'ResponseMetadata' => {'RequestId' => String}
|
6
|
-
}
|
7
|
-
|
8
|
-
LOAD_BALANCER = {
|
9
|
-
"AvailabilityZones" => [{
|
10
|
-
"SubnetId" => String, "ZoneName" => String,
|
11
|
-
"LoadBalancerAddresses" => [Fog::Nullable::Hash]
|
12
|
-
}],
|
13
|
-
"LoadBalancerArn" => String,
|
14
|
-
"DNSName" => String,
|
15
|
-
"CreatedTime" => Time,
|
16
|
-
"LoadBalancerName" => String,
|
17
|
-
"VpcId" => String,
|
18
|
-
"CanonicalHostedZoneId" => String,
|
19
|
-
"Scheme" => String,
|
20
|
-
"Type" => String,
|
21
|
-
"State" => {"Code" => String},
|
22
|
-
"SecurityGroups" => [Fog::Nullable::String]
|
23
|
-
}
|
24
|
-
|
25
|
-
DESCRIBE_LOAD_BALANCERS = BASIC.merge({
|
26
|
-
'DescribeLoadBalancersResult' => {'LoadBalancers' => [LOAD_BALANCER], 'NextMarker' => Fog::Nullable::String}
|
27
|
-
})
|
28
|
-
|
29
|
-
CREATE_LOAD_BALANCER = BASIC.merge({
|
30
|
-
'CreateLoadBalancerResult' => {'LoadBalancers' => [LOAD_BALANCER]}
|
31
|
-
})
|
32
|
-
|
33
|
-
LISTENER_DEFAULT_ACTIONS = [{
|
34
|
-
"Type" => String,
|
35
|
-
"Order" => String,
|
36
|
-
"TargetGroupArn" => String,
|
37
|
-
"RedirectConfig" => Fog::Nullable::Hash,
|
38
|
-
"ForwardConfig" => Fog::Nullable::Hash,
|
39
|
-
"FixedResponseConfig" => Fog::Nullable::Hash
|
40
|
-
}]
|
41
|
-
|
42
|
-
LISTENER = {
|
43
|
-
"LoadBalancerArn" => String,
|
44
|
-
"Protocol" => String,
|
45
|
-
"Port" => String,
|
46
|
-
"ListenerArn" => String,
|
47
|
-
"SslPolicy" => String,
|
48
|
-
"DefaultActions" => LISTENER_DEFAULT_ACTIONS,
|
49
|
-
"Certificates" => [{"CertificateArn" => String}]
|
50
|
-
}
|
51
|
-
|
52
|
-
DESCRIBE_LISTENERS = BASIC.merge({
|
53
|
-
'DescribeListenersResult' => {'Listeners' => [LISTENER], 'NextMarker' => Fog::Nullable::String}
|
54
|
-
})
|
55
|
-
|
56
|
-
TAG_DESCRIPTIONS = [{
|
57
|
-
"Tags" => Hash,
|
58
|
-
"ResourceArn" => String
|
59
|
-
}]
|
60
|
-
|
61
|
-
DESCRIBE_TAGS = BASIC.merge({
|
62
|
-
'DescribeTagsResult' => {'TagDescriptions' => TAG_DESCRIPTIONS}
|
63
|
-
})
|
64
|
-
end
|
65
|
-
end
|
66
|
-
end
|
@@ -1,50 +0,0 @@
|
|
1
|
-
Shindo.tests('AWS::ELBV2 | load_balancer_tests', ['aws', 'elb']) do
|
2
|
-
@load_balancer_id = 'fog-test-elb'
|
3
|
-
@key_name = 'fog-test'
|
4
|
-
vpc = Fog::Compute[:aws].create_vpc('10.255.254.64/28').body['vpcSet'].first
|
5
|
-
@subnet_id = Fog::Compute[:aws].create_subnet(vpc['vpcId'], vpc['cidrBlock']).body['subnet']['subnetId']
|
6
|
-
@tags = { 'test1' => 'Value1', 'test2' => 'Value2' }
|
7
|
-
|
8
|
-
tests('success') do
|
9
|
-
tests('#create_load_balancer').formats(AWS::ELBV2::Formats::CREATE_LOAD_BALANCER) do
|
10
|
-
options = {
|
11
|
-
subnets: [@subnet_id]
|
12
|
-
}
|
13
|
-
load_balancer = Fog::AWS[:elbv2].create_load_balancer(@load_balancer_id, options).body
|
14
|
-
@load_balancer_arn = load_balancer['CreateLoadBalancerResult']['LoadBalancers'].first['LoadBalancerArn']
|
15
|
-
load_balancer
|
16
|
-
end
|
17
|
-
|
18
|
-
tests('#describe_load_balancers').formats(AWS::ELBV2::Formats::DESCRIBE_LOAD_BALANCERS) do
|
19
|
-
Fog::AWS[:elbv2].describe_load_balancers.body
|
20
|
-
end
|
21
|
-
|
22
|
-
tests('#describe_load_balancers with bad name') do
|
23
|
-
raises(Fog::AWS::ELBV2::NotFound) { Fog::AWS[:elbv2].describe_load_balancers('LoadBalancerNames' => 'none-such-lb') }
|
24
|
-
end
|
25
|
-
|
26
|
-
tests("#add_tags('#{@load_balancer_arn}', #{@tags})").formats(AWS::ELBV2::Formats::BASIC) do
|
27
|
-
Fog::AWS[:elbv2].add_tags(@load_balancer_arn, @tags).body
|
28
|
-
end
|
29
|
-
|
30
|
-
tests('#describe_tags').formats(AWS::ELBV2::Formats::DESCRIBE_TAGS) do
|
31
|
-
Fog::AWS[:elbv2].describe_tags(@load_balancer_arn).body
|
32
|
-
end
|
33
|
-
|
34
|
-
tests('#describe_tags with at least one wrong arn') do
|
35
|
-
raises(Fog::AWS::ELBV2::NotFound) { Fog::AWS[:elbv2].describe_tags([@load_balancer_arn, 'wrong_arn']) }
|
36
|
-
end
|
37
|
-
|
38
|
-
tests("#describe_tags(#{@load_balancer_arn})").returns(@tags) do
|
39
|
-
Fog::AWS[:elbv2].describe_tags(@load_balancer_arn).body['DescribeTagsResult']['TagDescriptions'].first['Tags']
|
40
|
-
end
|
41
|
-
|
42
|
-
tests("#remove_tags('#{@load_balancer_arn}', #{@tags.keys})").formats(AWS::ELBV2::Formats::BASIC) do
|
43
|
-
Fog::AWS[:elbv2].remove_tags(@load_balancer_arn, @tags.keys).body
|
44
|
-
end
|
45
|
-
|
46
|
-
tests("#describe_tags(#{@load_balancer_arn})").returns({}) do
|
47
|
-
Fog::AWS[:elbv2].describe_tags(@load_balancer_arn).body['DescribeTagsResult']['TagDescriptions'].first['Tags']
|
48
|
-
end
|
49
|
-
end
|
50
|
-
end
|
@@ -1,167 +0,0 @@
|
|
1
|
-
class AWS
|
2
|
-
module EMR
|
3
|
-
module Formats
|
4
|
-
BASIC = {
|
5
|
-
'RequestId' => String
|
6
|
-
}
|
7
|
-
|
8
|
-
RUN_JOB_FLOW = BASIC.merge({
|
9
|
-
'JobFlowId' => String
|
10
|
-
})
|
11
|
-
|
12
|
-
ADD_INSTANCE_GROUPS = {
|
13
|
-
'JobFlowId' => String,
|
14
|
-
'InstanceGroupIds' => Array
|
15
|
-
}
|
16
|
-
|
17
|
-
SIMPLE_DESCRIBE_JOB_FLOW = {
|
18
|
-
'JobFlows' => [{
|
19
|
-
'Name' => String,
|
20
|
-
'BootstrapActions' => {
|
21
|
-
'ScriptBootstrapActionConfig' => {
|
22
|
-
'Args' => Array
|
23
|
-
}
|
24
|
-
},
|
25
|
-
'ExecutionStatusDetail' => {
|
26
|
-
'CreationDateTime' => String,
|
27
|
-
'State' => String,
|
28
|
-
'LastStateChangeReason' => String
|
29
|
-
},
|
30
|
-
'Steps' => [{
|
31
|
-
'ActionOnFailure' => String,
|
32
|
-
'Name' => String,
|
33
|
-
'StepConfig' => {
|
34
|
-
'HadoopJarStepConfig' => {
|
35
|
-
'MainClass' => String,
|
36
|
-
'Jar' => String,
|
37
|
-
'Args' => Array,
|
38
|
-
'Properties' => Array
|
39
|
-
}
|
40
|
-
},
|
41
|
-
'ExecutionStatusDetail' => {
|
42
|
-
'CreationDateTime' => String,
|
43
|
-
'State' => String
|
44
|
-
}
|
45
|
-
}],
|
46
|
-
'JobFlowId' => String,
|
47
|
-
'Instances' => {
|
48
|
-
'InstanceCount' => String,
|
49
|
-
'NormalizedInstanceHours' => String,
|
50
|
-
'KeepJobFlowAliveWhenNoSteps' => String,
|
51
|
-
'Placement' => {
|
52
|
-
'AvailabilityZone' => String
|
53
|
-
},
|
54
|
-
'MasterInstanceType' => String,
|
55
|
-
'SlaveInstanceType' => String,
|
56
|
-
'InstanceGroups' => Array,
|
57
|
-
'TerminationProtected' => String,
|
58
|
-
'HadoopVersion' => String
|
59
|
-
}
|
60
|
-
}]
|
61
|
-
}
|
62
|
-
|
63
|
-
JOB_FLOW_WITHOUT_CHANGE = {
|
64
|
-
'JobFlows' => [{
|
65
|
-
'Name' => String,
|
66
|
-
'BootstrapActions' => {
|
67
|
-
'ScriptBootstrapActionConfig' => {
|
68
|
-
'Args' => Array
|
69
|
-
}
|
70
|
-
},
|
71
|
-
'ExecutionStatusDetail' => {
|
72
|
-
'CreationDateTime' => String,
|
73
|
-
'State' => String,
|
74
|
-
'LastStateChangeReason' => NilClass
|
75
|
-
},
|
76
|
-
'Steps' => [{
|
77
|
-
'ActionOnFailure' => String,
|
78
|
-
'Name' => String,
|
79
|
-
'StepConfig' => {
|
80
|
-
'HadoopJarStepConfig' => {
|
81
|
-
'MainClass' => String,
|
82
|
-
'Jar' => String,
|
83
|
-
'Args' => Array,
|
84
|
-
'Properties' => Array
|
85
|
-
}
|
86
|
-
},
|
87
|
-
'ExecutionStatusDetail' => {
|
88
|
-
'CreationDateTime' => String,
|
89
|
-
'State' => String
|
90
|
-
}
|
91
|
-
}],
|
92
|
-
'JobFlowId' => String,
|
93
|
-
'Instances' => {
|
94
|
-
'InstanceCount' => String,
|
95
|
-
'NormalizedInstanceHours' => String,
|
96
|
-
'KeepJobFlowAliveWhenNoSteps' => String,
|
97
|
-
'Placement' => {
|
98
|
-
'AvailabilityZone' => String
|
99
|
-
},
|
100
|
-
'MasterInstanceType' => String,
|
101
|
-
'SlaveInstanceType' => String,
|
102
|
-
'InstanceGroups' => Array,
|
103
|
-
'TerminationProtected' => String,
|
104
|
-
'HadoopVersion' => String
|
105
|
-
}
|
106
|
-
}]
|
107
|
-
}
|
108
|
-
|
109
|
-
DESCRIBE_JOB_FLOW_WITH_INSTANCE_GROUPS = {
|
110
|
-
'JobFlows' => [{
|
111
|
-
'Name' => String,
|
112
|
-
'BootstrapActions' => {
|
113
|
-
'ScriptBootstrapActionConfig' => {
|
114
|
-
'Args' => Array
|
115
|
-
}
|
116
|
-
},
|
117
|
-
'ExecutionStatusDetail' => {
|
118
|
-
'CreationDateTime' => String,
|
119
|
-
'State' => String,
|
120
|
-
'LastStateChangeReason' => NilClass
|
121
|
-
},
|
122
|
-
'Steps' => [{
|
123
|
-
'ActionOnFailure' => String,
|
124
|
-
'Name' => String,
|
125
|
-
'StepConfig' => {
|
126
|
-
'HadoopJarStepConfig' => {
|
127
|
-
'MainClass' => String,
|
128
|
-
'Jar' => String,
|
129
|
-
'Args' => Array,
|
130
|
-
'Properties' => Array
|
131
|
-
}
|
132
|
-
},
|
133
|
-
'ExecutionStatusDetail' => {
|
134
|
-
'CreationDateTime' => String,
|
135
|
-
'State' => String
|
136
|
-
}
|
137
|
-
}],
|
138
|
-
'JobFlowId' => String,
|
139
|
-
'Instances' => {
|
140
|
-
'InstanceCount' => String,
|
141
|
-
'NormalizedInstanceHours' => String,
|
142
|
-
'KeepJobFlowAliveWhenNoSteps' => String,
|
143
|
-
'Placement' => {
|
144
|
-
'AvailabilityZone' => String
|
145
|
-
},
|
146
|
-
'InstanceGroups' => [{
|
147
|
-
'Name' => String,
|
148
|
-
'InstanceRole' => String,
|
149
|
-
'CreationDateTime' => String,
|
150
|
-
'LastStateChangeReason' => nil,
|
151
|
-
'InstanceGroupId' => String,
|
152
|
-
'Market' => String,
|
153
|
-
'InstanceType' => String,
|
154
|
-
'State' => String,
|
155
|
-
'InstanceRunningCount' => String,
|
156
|
-
'InstanceRequestCount' => String
|
157
|
-
}],
|
158
|
-
'MasterInstanceType' => String,
|
159
|
-
'SlaveInstanceType' => String,
|
160
|
-
'TerminationProtected' => String,
|
161
|
-
'HadoopVersion' => String
|
162
|
-
}
|
163
|
-
}]
|
164
|
-
}
|
165
|
-
end
|
166
|
-
end
|
167
|
-
end
|
@@ -1,106 +0,0 @@
|
|
1
|
-
Shindo.tests('AWS::EMR | instance groups', ['aws', 'emr']) do
|
2
|
-
|
3
|
-
pending if Fog.mocking?
|
4
|
-
|
5
|
-
@job_flow_name = "fog_job_flow_#{Time.now.to_f.to_s.gsub('.','')}"
|
6
|
-
|
7
|
-
@job_flow_options = {
|
8
|
-
'Instances' => {
|
9
|
-
'MasterInstanceType' => 'm1.small',
|
10
|
-
'SlaveInstanceType' => 'm1.small',
|
11
|
-
'InstanceCount' => 2,
|
12
|
-
'Placement' => {
|
13
|
-
'AvailabilityZone' => 'us-east-1a'
|
14
|
-
},
|
15
|
-
'KeepJobFlowAliveWhenNoSteps' => false,
|
16
|
-
'TerminationProtected' => false,
|
17
|
-
'HadoopVersion' => '0.20'
|
18
|
-
}
|
19
|
-
}
|
20
|
-
|
21
|
-
@job_flow_steps = {
|
22
|
-
'Steps' => [{
|
23
|
-
'Name' => 'Dummy streaming job',
|
24
|
-
'ActionOnFailure' => 'CONTINUE',
|
25
|
-
'HadoopJarStep' => {
|
26
|
-
'Jar' => '/home/hadoop/contrib/streaming/hadoop-streaming.jar',
|
27
|
-
'MainClass' => nil,
|
28
|
-
'Args' => %w(-input s3n://elasticmapreduce/samples/wordcount/input -output hdfs:///examples/output/2011-11-03T090856 -mapper s3n://elasticmapreduce/samples/wordcount/wordSplitter.py -reducer aggregate)
|
29
|
-
}
|
30
|
-
}]
|
31
|
-
}
|
32
|
-
|
33
|
-
@instance_group_name = "fog_instance_group_#{Time.now.to_f.to_s.gsub('.','')}"
|
34
|
-
@instance_groups = {
|
35
|
-
'InstanceGroups' => [{
|
36
|
-
'Name' => @instance_group_name,
|
37
|
-
'InstanceRole' => 'TASK',
|
38
|
-
'InstanceType' => 'm1.small',
|
39
|
-
'InstanceCount' => 2
|
40
|
-
}]
|
41
|
-
}
|
42
|
-
|
43
|
-
result = Fog::AWS[:emr].run_job_flow(@job_flow_name, @job_flow_options).body
|
44
|
-
@job_flow_id = result['JobFlowId']
|
45
|
-
|
46
|
-
tests('success') do
|
47
|
-
|
48
|
-
tests("#add_instance_groups").formats(AWS::EMR::Formats::ADD_INSTANCE_GROUPS) do
|
49
|
-
pending if Fog.mocking?
|
50
|
-
|
51
|
-
result = Fog::AWS[:emr].add_instance_groups(@job_flow_id, @instance_groups).body
|
52
|
-
|
53
|
-
@instance_group_id = result['InstanceGroupIds'].first
|
54
|
-
|
55
|
-
result
|
56
|
-
end
|
57
|
-
|
58
|
-
tests("#describe_job_flows_with_instance_groups").formats(AWS::EMR::Formats::DESCRIBE_JOB_FLOW_WITH_INSTANCE_GROUPS) do
|
59
|
-
pending if Fog.mocking?
|
60
|
-
|
61
|
-
result = Fog::AWS[:emr].describe_job_flows('JobFlowIds' => [@job_flow_id]).body
|
62
|
-
|
63
|
-
result
|
64
|
-
end
|
65
|
-
|
66
|
-
tests("#modify_instance_groups").formats(AWS::EMR::Formats::BASIC) do
|
67
|
-
pending if Fog.mocking?
|
68
|
-
|
69
|
-
# Add a step so the state doesn't go directly from STARTING to SHUTTING_DOWN
|
70
|
-
Fog::AWS[:emr].add_job_flow_steps(@job_flow_id, @job_flow_steps)
|
71
|
-
|
72
|
-
# Wait until job has started before modifying the instance group
|
73
|
-
begin
|
74
|
-
sleep 10
|
75
|
-
|
76
|
-
result = Fog::AWS[:emr].describe_job_flows('JobFlowIds' => [@job_flow_id]).body
|
77
|
-
job_flow = result['JobFlows'].first
|
78
|
-
state = job_flow['ExecutionStatusDetail']['State']
|
79
|
-
print "."
|
80
|
-
end while(state == 'STARTING')
|
81
|
-
|
82
|
-
# Check results
|
83
|
-
result = Fog::AWS[:emr].modify_instance_groups('InstanceGroups' => [{'InstanceGroupId' => @instance_group_id, 'InstanceCount' => 4}]).body
|
84
|
-
|
85
|
-
# Check the it actually modified the instance count
|
86
|
-
tests("modify worked?") do
|
87
|
-
ig_res = Fog::AWS[:emr].describe_job_flows('JobFlowIds' => [@job_flow_id]).body
|
88
|
-
|
89
|
-
matched = false
|
90
|
-
jf = ig_res['JobFlows'].first
|
91
|
-
jf['Instances']['InstanceGroups'].each do | ig |
|
92
|
-
if ig['InstanceGroupId'] == @instance_group_id
|
93
|
-
matched = true if ig['InstanceRequestCount'].to_i == 4
|
94
|
-
end
|
95
|
-
end
|
96
|
-
|
97
|
-
matched
|
98
|
-
end
|
99
|
-
|
100
|
-
result
|
101
|
-
end
|
102
|
-
|
103
|
-
end
|
104
|
-
|
105
|
-
Fog::AWS[:emr].terminate_job_flows('JobFlowIds' => [@job_flow_id])
|
106
|
-
end
|
@@ -1,88 +0,0 @@
|
|
1
|
-
Shindo.tests('AWS::EMR | job flows', ['aws', 'emr']) do
|
2
|
-
|
3
|
-
pending if Fog.mocking?
|
4
|
-
|
5
|
-
@job_flow_name = "fog_job_flow_#{Time.now.to_f.to_s.gsub('.','')}"
|
6
|
-
|
7
|
-
@job_flow_options = {
|
8
|
-
'Instances' => {
|
9
|
-
'MasterInstanceType' => 'm1.small',
|
10
|
-
'SlaveInstanceType' => 'm1.small',
|
11
|
-
'InstanceCount' => 2,
|
12
|
-
'Placement' => {
|
13
|
-
'AvailabilityZone' => 'us-east-1a'
|
14
|
-
},
|
15
|
-
'KeepJobFlowAliveWhenNoSteps' => false,
|
16
|
-
'TerminationProtected' => false,
|
17
|
-
'HadoopVersion' => '0.20'
|
18
|
-
}
|
19
|
-
}
|
20
|
-
|
21
|
-
@step_name = "fog_job_flow_step_#{Time.now.to_f.to_s.gsub('.','')}"
|
22
|
-
|
23
|
-
@job_flow_steps = {
|
24
|
-
'Steps' => [{
|
25
|
-
'Name' => @step_name,
|
26
|
-
'ActionOnFailure' => 'CONTINUE',
|
27
|
-
'HadoopJarStep' => {
|
28
|
-
'Jar' => 'FakeJar',
|
29
|
-
'MainClass' => 'FakeMainClass',
|
30
|
-
'Args' => ['arg1', 'arg2']
|
31
|
-
}
|
32
|
-
}]
|
33
|
-
}
|
34
|
-
|
35
|
-
@job_flow_id = nil
|
36
|
-
|
37
|
-
tests('success') do
|
38
|
-
|
39
|
-
tests("#run_job_flow").formats(AWS::EMR::Formats::RUN_JOB_FLOW) do
|
40
|
-
pending if Fog.mocking?
|
41
|
-
|
42
|
-
result = Fog::AWS[:emr].run_job_flow(@job_flow_name, @job_flow_options).body
|
43
|
-
@job_flow_id = result['JobFlowId']
|
44
|
-
|
45
|
-
result
|
46
|
-
end
|
47
|
-
|
48
|
-
tests("#add_job_flow_steps").formats(AWS::EMR::Formats::BASIC) do
|
49
|
-
pending if Fog.mocking?
|
50
|
-
|
51
|
-
result = Fog::AWS[:emr].add_job_flow_steps(@job_flow_id, @job_flow_steps).body
|
52
|
-
|
53
|
-
result
|
54
|
-
end
|
55
|
-
|
56
|
-
tests("#set_termination_protection").formats(AWS::EMR::Formats::BASIC) do
|
57
|
-
|
58
|
-
result = Fog::AWS[:emr].set_termination_protection(true, 'JobFlowIds' => [@job_flow_id]).body
|
59
|
-
|
60
|
-
test("protected?") do
|
61
|
-
res = Fog::AWS[:emr].describe_job_flows('JobFlowIds' => [@job_flow_id]).body
|
62
|
-
jf = res['JobFlows'].first
|
63
|
-
|
64
|
-
jf['Instances']['TerminationProtected'] == 'true'
|
65
|
-
end
|
66
|
-
|
67
|
-
result
|
68
|
-
end
|
69
|
-
|
70
|
-
tests("#terminate_job_flow").formats(AWS::EMR::Formats::BASIC) do
|
71
|
-
pending if Fog.mocking?
|
72
|
-
Fog::AWS[:emr].set_termination_protection(false, 'JobFlowIds' => [@job_flow_id])
|
73
|
-
|
74
|
-
result = Fog::AWS[:emr].terminate_job_flows('JobFlowIds' => [@job_flow_id]).body
|
75
|
-
|
76
|
-
result
|
77
|
-
end
|
78
|
-
|
79
|
-
tests("#describe_job_flows").formats(AWS::EMR::Formats::SIMPLE_DESCRIBE_JOB_FLOW) do
|
80
|
-
pending if Fog.mocking?
|
81
|
-
|
82
|
-
result = Fog::AWS[:emr].describe_job_flows('JobFlowIds' => [@job_flow_id]).body
|
83
|
-
|
84
|
-
result
|
85
|
-
end
|
86
|
-
|
87
|
-
end
|
88
|
-
end
|
@@ -1,11 +0,0 @@
|
|
1
|
-
Shindo.tests('AWS::Federation | signin tokens', ['aws']) do
|
2
|
-
@signin_token_format = {
|
3
|
-
'SigninToken' => String
|
4
|
-
}
|
5
|
-
|
6
|
-
tests("#get_signin_token").formats(@signin_token_format) do
|
7
|
-
pending unless Fog.mocking?
|
8
|
-
|
9
|
-
Fog::AWS[:federation].get_signin_token("test_policy")
|
10
|
-
end
|
11
|
-
end
|
@@ -1,13 +0,0 @@
|
|
1
|
-
Shindo.tests('AWS::Glacier | glacier archive tests', ['aws']) do
|
2
|
-
pending if Fog.mocking?
|
3
|
-
|
4
|
-
Fog::AWS[:glacier].create_vault('Fog-Test-Vault-upload')
|
5
|
-
|
6
|
-
tests('single part upload') do
|
7
|
-
id = Fog::AWS[:glacier].create_archive('Fog-Test-Vault-upload', 'data body').headers['x-amz-archive-id']
|
8
|
-
Fog::AWS[:glacier].delete_archive('Fog-Test-Vault-upload', id)
|
9
|
-
end
|
10
|
-
|
11
|
-
#amazon won't let us delete the vault because it has been written to in the past day
|
12
|
-
|
13
|
-
end
|
@@ -1,29 +0,0 @@
|
|
1
|
-
Shindo.tests('AWS::Glacier | glacier archive tests', ['aws']) do
|
2
|
-
pending if Fog.mocking?
|
3
|
-
|
4
|
-
Fog::AWS[:glacier].create_vault('Fog-Test-Vault-upload')
|
5
|
-
|
6
|
-
tests('initiate and abort') do
|
7
|
-
id = Fog::AWS[:glacier].initiate_multipart_upload('Fog-Test-Vault-upload', 1024*1024).headers['x-amz-multipart-upload-id']
|
8
|
-
returns(true){ Fog::AWS[:glacier].list_multipart_uploads('Fog-Test-Vault-upload').body['UploadsList'].map {|item| item['MultipartUploadId']}.include?(id)}
|
9
|
-
Fog::AWS[:glacier].abort_multipart_upload('Fog-Test-Vault-upload', id)
|
10
|
-
returns(false){ Fog::AWS[:glacier].list_multipart_uploads('Fog-Test-Vault-upload').body['UploadsList'].map {|item| item['MultipartUploadId']}.include?(id)}
|
11
|
-
end
|
12
|
-
|
13
|
-
tests('do multipart upload') do
|
14
|
-
hash = Fog::AWS::Glacier::TreeHash.new
|
15
|
-
id = Fog::AWS[:glacier].initiate_multipart_upload('Fog-Test-Vault-upload', 1024*1024).headers['x-amz-multipart-upload-id']
|
16
|
-
part = 't'*1024*1024
|
17
|
-
hash_for_part = hash.add_part(part)
|
18
|
-
Fog::AWS[:glacier].upload_part('Fog-Test-Vault-upload', id, part, 0, hash_for_part)
|
19
|
-
|
20
|
-
part_2 = 'u'*1024*1024
|
21
|
-
hash_for_part_2 = hash.add_part(part_2)
|
22
|
-
Fog::AWS[:glacier].upload_part('Fog-Test-Vault-upload', id, part_2, 1024*1024, hash_for_part_2)
|
23
|
-
|
24
|
-
archive = Fog::AWS[:glacier].complete_multipart_upload('Fog-Test-Vault-upload', id, 2*1024*1024, hash.hexdigest).headers['x-amz-archive-id']
|
25
|
-
|
26
|
-
Fog::AWS[:glacier].delete_archive('Fog-Test-Vault-upload', archive)
|
27
|
-
#amazon won't let us delete the vault because it has been written to in the past day
|
28
|
-
end
|
29
|
-
end
|
@@ -1,91 +0,0 @@
|
|
1
|
-
Shindo.tests('AWS::Glacier | glacier tree hash calcuation', ['aws']) do
|
2
|
-
|
3
|
-
tests('tree_hash(single part < 1MB)') do
|
4
|
-
returns(OpenSSL::Digest::SHA256.hexdigest('')) { Fog::AWS::Glacier::TreeHash.digest('')}
|
5
|
-
end
|
6
|
-
|
7
|
-
tests('tree_hash(multibyte characters)') do
|
8
|
-
body = ("\xC2\xA1" * 1024*1024)
|
9
|
-
body.force_encoding('UTF-8') if body.respond_to? :encoding
|
10
|
-
|
11
|
-
expected = OpenSSL::Digest::SHA256.hexdigest(
|
12
|
-
OpenSSL::Digest::SHA256.digest("\xC2\xA1" * 1024*512) + OpenSSL::Digest::SHA256.digest("\xC2\xA1" * 1024*512)
|
13
|
-
)
|
14
|
-
returns(expected) { Fog::AWS::Glacier::TreeHash.digest(body)}
|
15
|
-
end
|
16
|
-
|
17
|
-
tests('tree_hash(power of 2 number of parts)') do
|
18
|
-
body = ('x' * 1024*1024) + ('y'*1024*1024) + ('z'*1024*1024) + ('t'*1024*1024)
|
19
|
-
expected = OpenSSL::Digest::SHA256.hexdigest(
|
20
|
-
OpenSSL::Digest::SHA256.digest(
|
21
|
-
OpenSSL::Digest::SHA256.digest('x' * 1024*1024) + OpenSSL::Digest::SHA256.digest('y' * 1024*1024)
|
22
|
-
) +
|
23
|
-
OpenSSL::Digest::SHA256.digest(
|
24
|
-
OpenSSL::Digest::SHA256.digest('z' * 1024*1024) + OpenSSL::Digest::SHA256.digest('t' * 1024*1024)
|
25
|
-
)
|
26
|
-
)
|
27
|
-
|
28
|
-
returns(expected) { Fog::AWS::Glacier::TreeHash.digest(body)}
|
29
|
-
end
|
30
|
-
|
31
|
-
tests('tree_hash(non power of 2 number of parts)') do
|
32
|
-
body = ('x' * 1024*1024) + ('y'*1024*1024) + ('z'*1024*1024)
|
33
|
-
expected = OpenSSL::Digest::SHA256.hexdigest(
|
34
|
-
OpenSSL::Digest::SHA256.digest(
|
35
|
-
OpenSSL::Digest::SHA256.digest('x' * 1024*1024) + OpenSSL::Digest::SHA256.digest('y' * 1024*1024)
|
36
|
-
) +
|
37
|
-
OpenSSL::Digest::SHA256.digest('z' * 1024*1024)
|
38
|
-
)
|
39
|
-
|
40
|
-
returns(expected) { Fog::AWS::Glacier::TreeHash.digest(body)}
|
41
|
-
end
|
42
|
-
|
43
|
-
tests('multipart') do
|
44
|
-
tree_hash = Fog::AWS::Glacier::TreeHash.new
|
45
|
-
part = ('x' * 1024*1024) + ('y'*1024*1024)
|
46
|
-
returns(Fog::AWS::Glacier::TreeHash.digest(part)) { tree_hash.add_part part }
|
47
|
-
|
48
|
-
tree_hash.add_part('z'* 1024*1024 + 't'*1024*1024)
|
49
|
-
|
50
|
-
expected = OpenSSL::Digest::SHA256.hexdigest(
|
51
|
-
OpenSSL::Digest::SHA256.digest(
|
52
|
-
OpenSSL::Digest::SHA256.digest('x' * 1024*1024) + OpenSSL::Digest::SHA256.digest('y' * 1024*1024)
|
53
|
-
) +
|
54
|
-
OpenSSL::Digest::SHA256.digest(
|
55
|
-
OpenSSL::Digest::SHA256.digest('z' * 1024*1024) + OpenSSL::Digest::SHA256.digest('t' * 1024*1024)
|
56
|
-
)
|
57
|
-
)
|
58
|
-
returns(expected) { tree_hash.hexdigest}
|
59
|
-
|
60
|
-
end
|
61
|
-
|
62
|
-
# Aligned is used in general sense of https://en.wikipedia.org/wiki/Data_structure_alignment
|
63
|
-
# except we are not dealing with data in memory, but with parts in "virtual" space of whole file.
|
64
|
-
# Tests for https://github.com/fog/fog-aws/issues/520 and https://github.com/fog/fog-aws/issues/521
|
65
|
-
tests('multipart with unaligned parts') do
|
66
|
-
tree_hash = Fog::AWS::Glacier::TreeHash.new
|
67
|
-
part = ('x' * 512*1024)
|
68
|
-
returns(Fog::AWS::Glacier::TreeHash.digest(part)) { tree_hash.add_part part }
|
69
|
-
|
70
|
-
# At this point, we have 0.5MB in tree_hash. That means that the next part we add will not be aligned,
|
71
|
-
# because it will start on 0.5MB which is not 1MB boundary.
|
72
|
-
part2 = ('x' * 512*1024) + ('y'*1024*1024) + ('z'* 512*1024)
|
73
|
-
returns(Fog::AWS::Glacier::TreeHash.digest(part + part2)) { tree_hash.add_part part2 ; tree_hash.hexdigest }
|
74
|
-
|
75
|
-
# Here we are adding another 1.5MB to tree_hash which has size of 3.5MB. Again, 3.5MB is not on 1MB boundary,
|
76
|
-
# so this is another unaligned part. It does test different part of code, though.
|
77
|
-
tree_hash.add_part('z'* 512*1024 + 't'*1024*1024)
|
78
|
-
|
79
|
-
expected = OpenSSL::Digest::SHA256.hexdigest(
|
80
|
-
OpenSSL::Digest::SHA256.digest(
|
81
|
-
OpenSSL::Digest::SHA256.digest('x' * 1024*1024) + OpenSSL::Digest::SHA256.digest('y' * 1024*1024)
|
82
|
-
) +
|
83
|
-
OpenSSL::Digest::SHA256.digest(
|
84
|
-
OpenSSL::Digest::SHA256.digest('z' * 1024*1024) + OpenSSL::Digest::SHA256.digest('t' * 1024*1024)
|
85
|
-
)
|
86
|
-
)
|
87
|
-
returns(expected) { tree_hash.hexdigest}
|
88
|
-
|
89
|
-
end
|
90
|
-
|
91
|
-
end
|
@@ -1,35 +0,0 @@
|
|
1
|
-
Shindo.tests('AWS::Glacier | glacier vault requests', ['aws']) do
|
2
|
-
pending if Fog.mocking?
|
3
|
-
|
4
|
-
topic_arn = Fog::AWS[:sns].create_topic( 'fog_test_glacier_topic').body['TopicArn']
|
5
|
-
Fog::AWS[:glacier].create_vault('Fog-Test-Vault')
|
6
|
-
|
7
|
-
tests('list_vaults') do
|
8
|
-
returns(true){Fog::AWS[:glacier].list_vaults.body['VaultList'].map {|data| data['VaultName']}.include?('Fog-Test-Vault')}
|
9
|
-
end
|
10
|
-
|
11
|
-
tests('describe_vault') do
|
12
|
-
returns('Fog-Test-Vault'){Fog::AWS[:glacier].describe_vault('Fog-Test-Vault').body['VaultName']}
|
13
|
-
end
|
14
|
-
|
15
|
-
tests('set_vault_notification_configuration') do
|
16
|
-
Fog::AWS[:glacier].set_vault_notification_configuration 'Fog-Test-Vault', topic_arn, ['ArchiveRetrievalCompleted']
|
17
|
-
end
|
18
|
-
|
19
|
-
tests('get_vault_notification_configuration') do
|
20
|
-
returns('SNSTopic' => topic_arn, 'Events' => ['ArchiveRetrievalCompleted']){ Fog::AWS[:glacier].get_vault_notification_configuration( 'Fog-Test-Vault').body}
|
21
|
-
end
|
22
|
-
|
23
|
-
tests('delete_vault_notification_configuration') do
|
24
|
-
Fog::AWS[:glacier].delete_vault_notification_configuration( 'Fog-Test-Vault')
|
25
|
-
raises(Excon::Errors::NotFound){Fog::AWS[:glacier].get_vault_notification_configuration( 'Fog-Test-Vault')}
|
26
|
-
end
|
27
|
-
|
28
|
-
tests('delete_vault') do
|
29
|
-
Fog::AWS[:glacier].delete_vault( 'Fog-Test-Vault')
|
30
|
-
raises(Excon::Errors::NotFound){Fog::AWS[:glacier].describe_vault( 'Fog-Test-Vault')}
|
31
|
-
end
|
32
|
-
|
33
|
-
Fog::AWS[:sns].delete_topic topic_arn
|
34
|
-
|
35
|
-
end
|