fog-aws 3.12.0 → 3.13.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (273) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +29 -3
  3. data/fog-aws.gemspec +3 -4
  4. data/lib/fog/aws/iam/default_policies.json +1574 -0
  5. data/lib/fog/aws/iam/default_policy_versions.json +3373 -0
  6. data/lib/fog/aws/models/storage/file.rb +8 -7
  7. data/lib/fog/aws/requests/compute/create_network_interface.rb +7 -4
  8. data/lib/fog/aws/requests/compute/create_subnet.rb +3 -3
  9. data/lib/fog/aws/version.rb +1 -1
  10. metadata +5 -280
  11. data/tests/credentials_tests.rb +0 -190
  12. data/tests/helper.rb +0 -29
  13. data/tests/helpers/collection_helper.rb +0 -90
  14. data/tests/helpers/compute/flavors_helper.rb +0 -28
  15. data/tests/helpers/compute/server_helper.rb +0 -23
  16. data/tests/helpers/compute/servers_helper.rb +0 -8
  17. data/tests/helpers/dns_helper.rb +0 -56
  18. data/tests/helpers/formats_helper.rb +0 -100
  19. data/tests/helpers/formats_helper_tests.rb +0 -107
  20. data/tests/helpers/mock_helper.rb +0 -109
  21. data/tests/helpers/model_helper.rb +0 -30
  22. data/tests/helpers/responds_to_helper.rb +0 -11
  23. data/tests/helpers/schema_validator_tests.rb +0 -104
  24. data/tests/helpers/succeeds_helper.rb +0 -9
  25. data/tests/lorem.txt +0 -1
  26. data/tests/models/auto_scaling/activities_tests.rb +0 -6
  27. data/tests/models/auto_scaling/configuration_test.rb +0 -13
  28. data/tests/models/auto_scaling/configurations_tests.rb +0 -11
  29. data/tests/models/auto_scaling/groups_test.rb +0 -27
  30. data/tests/models/auto_scaling/helper.rb +0 -0
  31. data/tests/models/auto_scaling/instance_tests.rb +0 -15
  32. data/tests/models/auto_scaling/instances_tests.rb +0 -6
  33. data/tests/models/beanstalk/application_tests.rb +0 -69
  34. data/tests/models/beanstalk/applications_tests.rb +0 -7
  35. data/tests/models/beanstalk/environment_tests.rb +0 -131
  36. data/tests/models/beanstalk/environments_tests.rb +0 -34
  37. data/tests/models/beanstalk/template_tests.rb +0 -47
  38. data/tests/models/beanstalk/templates_tests.rb +0 -62
  39. data/tests/models/beanstalk/version_tests.rb +0 -66
  40. data/tests/models/beanstalk/versions_tests.rb +0 -60
  41. data/tests/models/cdn/distribution_tests.rb +0 -15
  42. data/tests/models/cdn/distributions_tests.rb +0 -15
  43. data/tests/models/cdn/invalidation_tests.rb +0 -31
  44. data/tests/models/cdn/invalidations_tests.rb +0 -14
  45. data/tests/models/cdn/streaming_distribution_tests.rb +0 -15
  46. data/tests/models/cdn/streaming_distributions_tests.rb +0 -15
  47. data/tests/models/cloud_watch/alarm_data_tests.rb +0 -42
  48. data/tests/models/cloud_watch/alarm_history_tests.rb +0 -22
  49. data/tests/models/cloud_watch/metric_statistics_tests.rb +0 -51
  50. data/tests/models/cloud_watch/metrics_tests.rb +0 -32
  51. data/tests/models/compute/address_tests.rb +0 -43
  52. data/tests/models/compute/addresses_tests.rb +0 -5
  53. data/tests/models/compute/dhcp_option_tests.rb +0 -3
  54. data/tests/models/compute/dhcp_options_tests.rb +0 -3
  55. data/tests/models/compute/internet_gateway_tests.rb +0 -3
  56. data/tests/models/compute/internet_gateways_tests.rb +0 -3
  57. data/tests/models/compute/key_pair_tests.rb +0 -26
  58. data/tests/models/compute/key_pairs_tests.rb +0 -5
  59. data/tests/models/compute/network_acl_tests.rb +0 -109
  60. data/tests/models/compute/network_acls_tests.rb +0 -20
  61. data/tests/models/compute/network_interfaces_test.rb +0 -12
  62. data/tests/models/compute/security_group_tests.rb +0 -98
  63. data/tests/models/compute/security_groups_tests.rb +0 -5
  64. data/tests/models/compute/server_tests.rb +0 -94
  65. data/tests/models/compute/snapshot_tests.rb +0 -10
  66. data/tests/models/compute/snapshots_tests.rb +0 -10
  67. data/tests/models/compute/subnet_tests.rb +0 -13
  68. data/tests/models/compute/subnets_tests.rb +0 -5
  69. data/tests/models/compute/volume_tests.rb +0 -65
  70. data/tests/models/compute/volumes_tests.rb +0 -5
  71. data/tests/models/compute/vpc_tests.rb +0 -26
  72. data/tests/models/compute/vpcs_tests.rb +0 -19
  73. data/tests/models/data_pipeline/pipeline_tests.rb +0 -8
  74. data/tests/models/data_pipeline/pipelines_tests.rb +0 -8
  75. data/tests/models/dns/record_tests.rb +0 -33
  76. data/tests/models/dns/records_tests.rb +0 -41
  77. data/tests/models/dns/zone_tests.rb +0 -4
  78. data/tests/models/dns/zones_tests.rb +0 -4
  79. data/tests/models/efs/file_system_tests.rb +0 -12
  80. data/tests/models/efs/mount_target_tests.rb +0 -45
  81. data/tests/models/efs/mount_targets_tests.rb +0 -30
  82. data/tests/models/elasticache/cluster_tests.rb +0 -30
  83. data/tests/models/elasticache/parameter_groups_tests.rb +0 -15
  84. data/tests/models/elasticache/security_groups_tests.rb +0 -52
  85. data/tests/models/elasticache/subnet_groups_tests.rb +0 -43
  86. data/tests/models/elb/model_tests.rb +0 -360
  87. data/tests/models/elb/tagging_tests.rb +0 -15
  88. data/tests/models/glacier/model_tests.rb +0 -47
  89. data/tests/models/iam/access_keys_tests.rb +0 -53
  90. data/tests/models/iam/groups_tests.rb +0 -59
  91. data/tests/models/iam/instance_profile_tests.rb +0 -18
  92. data/tests/models/iam/managed_policies_tests.rb +0 -89
  93. data/tests/models/iam/policies_tests.rb +0 -57
  94. data/tests/models/iam/roles_tests.rb +0 -71
  95. data/tests/models/iam/users_tests.rb +0 -119
  96. data/tests/models/rds/cluster_tests.rb +0 -54
  97. data/tests/models/rds/clusters_tests.rb +0 -5
  98. data/tests/models/rds/event_subscription_tests.rb +0 -9
  99. data/tests/models/rds/event_subscriptions_tests.rb +0 -6
  100. data/tests/models/rds/helper.rb +0 -25
  101. data/tests/models/rds/instance_option_tests.rb +0 -14
  102. data/tests/models/rds/parameter_group_tests.rb +0 -24
  103. data/tests/models/rds/parameter_groups_tests.rb +0 -8
  104. data/tests/models/rds/security_group_tests.rb +0 -77
  105. data/tests/models/rds/security_groups_tests.rb +0 -5
  106. data/tests/models/rds/server_tests.rb +0 -131
  107. data/tests/models/rds/servers_tests.rb +0 -24
  108. data/tests/models/rds/snapshot_tests.rb +0 -12
  109. data/tests/models/rds/snapshots_tests.rb +0 -12
  110. data/tests/models/rds/tagging_tests.rb +0 -20
  111. data/tests/models/sns/topic_tests.rb +0 -15
  112. data/tests/models/sns/topics_tests.rb +0 -6
  113. data/tests/models/storage/directory_tests.rb +0 -202
  114. data/tests/models/storage/file_tests.rb +0 -129
  115. data/tests/models/storage/files_tests.rb +0 -90
  116. data/tests/models/storage/url_tests.rb +0 -25
  117. data/tests/models/storage/version_tests.rb +0 -52
  118. data/tests/models/storage/versions_tests.rb +0 -51
  119. data/tests/models/support/trusted_advisor_tests.rb +0 -25
  120. data/tests/parsers/compute/describe_images_tests.rb +0 -33
  121. data/tests/parsers/elb/describe_load_balancers.rb +0 -65
  122. data/tests/parsers/elbv2/create_load_balancer_tests.rb +0 -48
  123. data/tests/parsers/elbv2/describe_listeners_tests.rb +0 -76
  124. data/tests/parsers/elbv2/describe_load_balancers_tests.rb +0 -54
  125. data/tests/parsers/elbv2/describe_tags_tests.rb +0 -35
  126. data/tests/requests/auto_scaling/auto_scaling_tests.rb +0 -111
  127. data/tests/requests/auto_scaling/describe_types_tests.rb +0 -102
  128. data/tests/requests/auto_scaling/helper.rb +0 -229
  129. data/tests/requests/auto_scaling/model_tests.rb +0 -235
  130. data/tests/requests/auto_scaling/notification_configuration_tests.rb +0 -124
  131. data/tests/requests/auto_scaling/tag_tests.rb +0 -63
  132. data/tests/requests/beanstalk/application_tests.rb +0 -140
  133. data/tests/requests/beanstalk/solution_stack_tests.rb +0 -22
  134. data/tests/requests/cdn/cdn_tests.rb +0 -252
  135. data/tests/requests/cloud_formation/stack_tests.rb +0 -167
  136. data/tests/requests/cloud_watch/get_metric_statistics_tests.rb +0 -28
  137. data/tests/requests/cloud_watch/list_metrics_test.rb +0 -64
  138. data/tests/requests/cloud_watch/put_metric_data_tests.rb +0 -36
  139. data/tests/requests/compute/address_tests.rb +0 -144
  140. data/tests/requests/compute/assign_private_ip_tests.rb +0 -55
  141. data/tests/requests/compute/availability_zone_tests.rb +0 -25
  142. data/tests/requests/compute/client_tests.rb +0 -25
  143. data/tests/requests/compute/dhcp_options_tests.rb +0 -39
  144. data/tests/requests/compute/helper.rb +0 -27
  145. data/tests/requests/compute/image_tests.rb +0 -169
  146. data/tests/requests/compute/instance_attrib_tests.rb +0 -168
  147. data/tests/requests/compute/instance_tests.rb +0 -338
  148. data/tests/requests/compute/internet_gateway_tests.rb +0 -49
  149. data/tests/requests/compute/key_pair_tests.rb +0 -67
  150. data/tests/requests/compute/network_acl_tests.rb +0 -112
  151. data/tests/requests/compute/network_interface_tests.rb +0 -239
  152. data/tests/requests/compute/placement_group_tests.rb +0 -48
  153. data/tests/requests/compute/region_tests.rb +0 -52
  154. data/tests/requests/compute/route_tests.rb +0 -341
  155. data/tests/requests/compute/security_group_tests.rb +0 -457
  156. data/tests/requests/compute/snapshot_tests.rb +0 -77
  157. data/tests/requests/compute/spot_datafeed_subscription_tests.rb +0 -47
  158. data/tests/requests/compute/spot_instance_tests.rb +0 -55
  159. data/tests/requests/compute/spot_price_history_tests.rb +0 -23
  160. data/tests/requests/compute/subnet_tests.rb +0 -87
  161. data/tests/requests/compute/tag_tests.rb +0 -101
  162. data/tests/requests/compute/volume_tests.rb +0 -263
  163. data/tests/requests/compute/vpc_tests.rb +0 -222
  164. data/tests/requests/data_pipeline/helper.rb +0 -78
  165. data/tests/requests/data_pipeline/pipeline_tests.rb +0 -80
  166. data/tests/requests/dns/change_resource_record_sets_tests.rb +0 -34
  167. data/tests/requests/dns/dns_tests.rb +0 -240
  168. data/tests/requests/dns/health_check_tests.rb +0 -159
  169. data/tests/requests/dns/helper.rb +0 -21
  170. data/tests/requests/dynamodb/item_tests.rb +0 -137
  171. data/tests/requests/dynamodb/table_tests.rb +0 -99
  172. data/tests/requests/ecs/cluster_tests.rb +0 -112
  173. data/tests/requests/ecs/container_instance_tests.rb +0 -119
  174. data/tests/requests/ecs/helper.rb +0 -276
  175. data/tests/requests/ecs/sample_task_definition1.json +0 -56
  176. data/tests/requests/ecs/service_tests.rb +0 -132
  177. data/tests/requests/ecs/task_definitions_tests.rb +0 -97
  178. data/tests/requests/ecs/task_tests.rb +0 -145
  179. data/tests/requests/efs/file_system_tests.rb +0 -152
  180. data/tests/requests/efs/helper.rb +0 -44
  181. data/tests/requests/elasticache/cache_cluster_tests.rb +0 -137
  182. data/tests/requests/elasticache/describe_events.rb +0 -17
  183. data/tests/requests/elasticache/describe_reserved_cache_nodes.rb +0 -17
  184. data/tests/requests/elasticache/helper.rb +0 -103
  185. data/tests/requests/elasticache/parameter_group_tests.rb +0 -105
  186. data/tests/requests/elasticache/security_group_tests.rb +0 -108
  187. data/tests/requests/elasticache/subnet_group_tests.rb +0 -52
  188. data/tests/requests/elb/helper.rb +0 -91
  189. data/tests/requests/elb/listener_tests.rb +0 -68
  190. data/tests/requests/elb/load_balancer_tests.rb +0 -89
  191. data/tests/requests/elb/policy_tests.rb +0 -132
  192. data/tests/requests/elbv2/helper.rb +0 -66
  193. data/tests/requests/elbv2/load_balancer_tests.rb +0 -50
  194. data/tests/requests/emr/helper.rb +0 -167
  195. data/tests/requests/emr/instance_group_tests.rb +0 -106
  196. data/tests/requests/emr/job_flow_tests.rb +0 -88
  197. data/tests/requests/federation/get_signin_token_tests.rb +0 -11
  198. data/tests/requests/glacier/archive_tests.rb +0 -13
  199. data/tests/requests/glacier/multipart_upload_tests.rb +0 -29
  200. data/tests/requests/glacier/tree_hash_tests.rb +0 -91
  201. data/tests/requests/glacier/vault_tests.rb +0 -35
  202. data/tests/requests/iam/access_key_tests.rb +0 -53
  203. data/tests/requests/iam/account_policy_tests.rb +0 -20
  204. data/tests/requests/iam/account_tests.rb +0 -34
  205. data/tests/requests/iam/group_policy_tests.rb +0 -48
  206. data/tests/requests/iam/group_tests.rb +0 -44
  207. data/tests/requests/iam/helper.rb +0 -154
  208. data/tests/requests/iam/instance_profile_tests.rb +0 -44
  209. data/tests/requests/iam/login_profile_tests.rb +0 -62
  210. data/tests/requests/iam/managed_policy_tests.rb +0 -110
  211. data/tests/requests/iam/mfa_tests.rb +0 -23
  212. data/tests/requests/iam/role_tests.rb +0 -156
  213. data/tests/requests/iam/server_certificate_tests.rb +0 -130
  214. data/tests/requests/iam/user_policy_tests.rb +0 -45
  215. data/tests/requests/iam/user_tests.rb +0 -78
  216. data/tests/requests/iam/versioned_managed_policy_tests.rb +0 -105
  217. data/tests/requests/kinesis/helper.rb +0 -111
  218. data/tests/requests/kinesis/stream_tests.rb +0 -169
  219. data/tests/requests/kms/helper.rb +0 -27
  220. data/tests/requests/kms/key_tests.rb +0 -23
  221. data/tests/requests/lambda/function_sample_1.js +0 -9
  222. data/tests/requests/lambda/function_sample_2.js +0 -9
  223. data/tests/requests/lambda/function_tests.rb +0 -460
  224. data/tests/requests/lambda/helper.rb +0 -81
  225. data/tests/requests/rds/cluster_snapshot_tests.rb +0 -43
  226. data/tests/requests/rds/cluster_tests.rb +0 -37
  227. data/tests/requests/rds/db_engine_versions.rb +0 -7
  228. data/tests/requests/rds/db_snapshot_tests.rb +0 -62
  229. data/tests/requests/rds/describe_events.rb +0 -16
  230. data/tests/requests/rds/event_subscription_tests.rb +0 -30
  231. data/tests/requests/rds/helper.rb +0 -406
  232. data/tests/requests/rds/instance_option_tests.rb +0 -27
  233. data/tests/requests/rds/instance_tests.rb +0 -149
  234. data/tests/requests/rds/log_file_tests.rb +0 -19
  235. data/tests/requests/rds/parameter_group_tests.rb +0 -62
  236. data/tests/requests/rds/parameter_request_tests.rb +0 -32
  237. data/tests/requests/rds/security_group_tests.rb +0 -101
  238. data/tests/requests/rds/subnet_groups_tests.rb +0 -52
  239. data/tests/requests/rds/tagging_tests.rb +0 -78
  240. data/tests/requests/redshift/cluster_parameter_group_tests.rb +0 -76
  241. data/tests/requests/redshift/cluster_security_group_tests.rb +0 -42
  242. data/tests/requests/redshift/cluster_snapshot_tests.rb +0 -73
  243. data/tests/requests/redshift/cluster_tests.rb +0 -80
  244. data/tests/requests/ses/helper.rb +0 -9
  245. data/tests/requests/ses/verified_domain_identity_tests.rb +0 -16
  246. data/tests/requests/ses/verified_email_address_tests.rb +0 -27
  247. data/tests/requests/simpledb/attributes_tests.rb +0 -86
  248. data/tests/requests/simpledb/domain_tests.rb +0 -51
  249. data/tests/requests/simpledb/helper.rb +0 -10
  250. data/tests/requests/sns/helper.rb +0 -9
  251. data/tests/requests/sns/subscription_tests.rb +0 -86
  252. data/tests/requests/sns/topic_tests.rb +0 -53
  253. data/tests/requests/sqs/helper.rb +0 -9
  254. data/tests/requests/sqs/message_tests.rb +0 -51
  255. data/tests/requests/sqs/queue_tests.rb +0 -50
  256. data/tests/requests/storage/acl_utils_tests.rb +0 -209
  257. data/tests/requests/storage/bucket_tests.rb +0 -416
  258. data/tests/requests/storage/cors_utils_tests.rb +0 -108
  259. data/tests/requests/storage/delete_multiple_objects_tests.rb +0 -12
  260. data/tests/requests/storage/multipart_copy_tests.rb +0 -93
  261. data/tests/requests/storage/multipart_upload_tests.rb +0 -121
  262. data/tests/requests/storage/object_tests.rb +0 -269
  263. data/tests/requests/storage/versioning_tests.rb +0 -300
  264. data/tests/requests/sts/assume_role_tests.rb +0 -19
  265. data/tests/requests/sts/assume_role_with_saml_tests.rb +0 -18
  266. data/tests/requests/sts/assume_role_with_web_identity_tests.rb +0 -28
  267. data/tests/requests/sts/get_federation_token_tests.rb +0 -20
  268. data/tests/requests/sts/session_token_tests.rb +0 -16
  269. data/tests/requests/support/helper.rb +0 -43
  270. data/tests/requests/support/trusted_advisor_check_tests.rb +0 -16
  271. data/tests/signaturev4_tests.rb +0 -106
  272. data/tests/signed_params_tests.rb +0 -17
  273. 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