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,145 +0,0 @@
1
- require 'fog/json'
2
-
3
- Shindo.tests('AWS::ECS | task requests', ['aws', 'ecs']) do
4
-
5
- Fog::AWS[:ecs].reset_data
6
-
7
- tests('success') do
8
-
9
- tests("#list_tasks").formats(AWS::ECS::Formats::LIST_TASKS) do
10
- result = Fog::AWS[:ecs].list_tasks.body
11
- list_instances_arns = result['ListTasksResult']['taskArns']
12
- returns(true) { list_instances_arns.empty? }
13
- result
14
- end
15
-
16
- tests("#run_task").formats(AWS::ECS::Formats::RUN_TASK) do
17
- task_def_params = Fog::JSON.decode(IO.read(AWS::ECS::Samples::TASK_DEFINITION_1))
18
- result1 = Fog::AWS[:ecs].register_task_definition(task_def_params).body
19
- task_def = result1['RegisterTaskDefinitionResult']['taskDefinition']
20
- task_def_arn = task_def['taskDefinitionArn']
21
-
22
- result2 = Fog::AWS[:ecs].run_task('taskDefinition' => task_def_arn).body
23
- task = result2['RunTaskResult']['tasks'].first
24
- returns(true) { task.has_key?('containerInstanceArn') }
25
- returns(true) { task['containers'].size.eql?(2) }
26
- returns(true) { task['desiredStatus'].eql?('RUNNING') }
27
- returns(true) { task['taskDefinitionArn'].eql?(task_def_arn) }
28
- result2
29
- end
30
-
31
- tests("#describe_tasks").formats(AWS::ECS::Formats::DESCRIBE_TASKS) do
32
- result1 = Fog::AWS[:ecs].list_tasks.body
33
- task_arn = result1['ListTasksResult']['taskArns'].first
34
-
35
- result2 = Fog::AWS[:ecs].describe_tasks('tasks' => task_arn).body
36
- task = result2['DescribeTasksResult']['tasks'].first
37
- returns(true) { task['taskArn'].eql?(task_arn) }
38
- returns(true) { task['containers'].size.eql?(2) }
39
- returns(true) { task['desiredStatus'].eql?('RUNNING') }
40
- result2
41
- end
42
-
43
- tests("#list_tasks").formats(AWS::ECS::Formats::LIST_TASKS) do
44
- result = Fog::AWS[:ecs].list_tasks.body
45
- list_instances_arns = result['ListTasksResult']['taskArns']
46
- returns(false) { list_instances_arns.empty? }
47
- result
48
- end
49
-
50
- tests("#stop_task").formats(AWS::ECS::Formats::STOP_TASK) do
51
- result1 = Fog::AWS[:ecs].list_tasks.body
52
- task_arn = result1['ListTasksResult']['taskArns'].first
53
-
54
- result2 = Fog::AWS[:ecs].stop_task('task' => task_arn).body
55
- task = result2['StopTaskResult']['task']
56
- returns(true) { task['taskArn'].eql?(task_arn) }
57
- returns(true) { task['containers'].size.eql?(2) }
58
- returns(true) { task['desiredStatus'].eql?('STOPPED') }
59
- result2
60
- end
61
-
62
- tests("#start_task").formats(AWS::ECS::Formats::START_TASK) do
63
- owner_id = Fog::AWS::Mock.owner_id
64
- container_instance_path = "container-instance/#{Fog::UUID.uuid}"
65
- region = "us-east-1"
66
- container_instance_arn = Fog::AWS::Mock.arn('ecs', owner_id, container_instance_path, region)
67
-
68
- task_def_params = Fog::JSON.decode(IO.read(AWS::ECS::Samples::TASK_DEFINITION_1))
69
- result1 = Fog::AWS[:ecs].register_task_definition(task_def_params).body
70
- task_def = result1['RegisterTaskDefinitionResult']['taskDefinition']
71
- task_def_arn = task_def['taskDefinitionArn']
72
-
73
- result2 = Fog::AWS[:ecs].start_task(
74
- 'taskDefinition' => task_def_arn,
75
- 'containerInstances' => container_instance_arn
76
- ).body
77
- task = result2['StartTaskResult']['tasks'].first
78
-
79
- returns(true) { task['containerInstanceArn'].eql?(container_instance_arn) }
80
- returns(true) { task['containers'].size.eql?(2) }
81
- returns(true) { task['desiredStatus'].eql?('RUNNING') }
82
- returns(true) { task['taskDefinitionArn'].eql?(task_def_arn) }
83
-
84
- result2
85
- end
86
-
87
- tests("#list_tasks").formats(AWS::ECS::Formats::LIST_TASKS) do
88
- result = Fog::AWS[:ecs].list_tasks.body
89
- list_instances_arns = result['ListTasksResult']['taskArns']
90
- returns(false) { list_instances_arns.empty? }
91
- result
92
- end
93
-
94
- end
95
-
96
- tests('failures') do
97
-
98
- tests("#describe_tasks nonexistent") do
99
- task_arn = "arn:aws:ecs:us-west-2:938269302734:task/6893440f-2165-47aa-8cfa-b2f413a26f00"
100
- result = Fog::AWS[:ecs].describe_tasks('tasks' => task_arn).body
101
- end
102
-
103
- tests('describe_tasks without params').raises(Fog::AWS::ECS::Error) do
104
- response = Fog::AWS[:ecs].describe_tasks.body
105
- end
106
-
107
- tests('#run_task without params').raises(Fog::AWS::ECS::Error) do
108
- response = Fog::AWS[:ecs].run_task.body
109
- end
110
-
111
- tests('#run_task nonexistent').raises(Fog::AWS::ECS::Error) do
112
- task_def_arn = "arn:aws:ecs:us-west-2:539573770077:task-definition/foo-xanadu-app-static:33"
113
- response = Fog::AWS[:ecs].run_task('taskDefinition' => task_def_arn).body
114
- end
115
-
116
- tests('#start_task without params').raises(Fog::AWS::ECS::Error) do
117
- response = Fog::AWS[:ecs].start_task.body
118
- end
119
-
120
- tests('#start_task with missing params').raises(Fog::AWS::ECS::Error) do
121
- task_def_arn = "arn:aws:ecs:us-west-2:539573770077:task-definition/foo-xanadu-app-static:33"
122
- response = Fog::AWS[:ecs].start_task('taskDefinition' => task_def_arn).body
123
- end
124
-
125
- tests('#start_task nonexistent').raises(Fog::AWS::ECS::Error) do
126
- task_def_arn = "arn:aws:ecs:us-west-2:539573770077:task-definition/foo-xanadu-app-static:33"
127
- container_instance_arn = "arn:aws:ecs:us-west-2:938269302734:container-instance/6893440f-2165-47aa-8cfa-b2f413a26f00"
128
- response = Fog::AWS[:ecs].start_task(
129
- 'taskDefinition' => task_def_arn,
130
- 'containerInstances' => container_instance_arn
131
- ).body
132
- end
133
-
134
- tests('#stop_task without params').raises(Fog::AWS::ECS::Error) do
135
- response = Fog::AWS[:ecs].stop_task.body
136
- end
137
-
138
- tests('#stop_task nonexistent params').raises(Fog::AWS::ECS::Error) do
139
- task_arn = "arn:aws:ecs:us-west-2:938269302734:task/6893440f-2165-47aa-8cfa-b2f413a26f00"
140
- response = Fog::AWS[:ecs].stop_task('task' => task_arn).body
141
- end
142
-
143
- end
144
-
145
- end
@@ -1,152 +0,0 @@
1
- Shindo.tests('AWS::EFS | file systems', ['aws', 'efs']) do
2
- suffix = rand(65535).to_s(16)
3
-
4
- @creation_token = "fogtest#{suffix}"
5
-
6
- tests('success') do
7
- tests("#create_file_system('#{@creation_token}')").formats(AWS::EFS::Formats::FILE_SYSTEM_FORMAT) do
8
- result = Fog::AWS[:efs].create_file_system(@creation_token).body
9
- returns('creating') { result['LifeCycleState'] }
10
- result
11
- end
12
-
13
- tests("#describe_file_systems").formats(AWS::EFS::Formats::DESCRIBE_FILE_SYSTEMS_RESULT) do
14
- Fog::AWS[:efs].describe_file_systems.body
15
- end
16
-
17
- tests("#describe_file_systems(creation_token: #{@creation_token})").formats(AWS::EFS::Formats::DESCRIBE_FILE_SYSTEMS_RESULT) do
18
- result = Fog::AWS[:efs].describe_file_systems(:creation_token => @creation_token).body
19
- returns(@creation_token) { result["FileSystems"].first["CreationToken"] }
20
- result
21
- end
22
-
23
- file_system_id = Fog::AWS[:efs].describe_file_systems(:creation_token => @creation_token).body["FileSystems"].first["FileSystemId"]
24
- file_system = Fog::AWS[:efs].file_systems.get(file_system_id)
25
-
26
- tests("#describe_file_systems(id: #{file_system_id})").formats(AWS::EFS::Formats::DESCRIBE_FILE_SYSTEMS_RESULT) do
27
- Fog::AWS[:efs].describe_file_systems(:id => file_system_id).body
28
- end
29
-
30
- if Fog.mocking?
31
- vpc = Fog::Compute[:aws].vpcs.create(:cidr_block => "10.0.0.0/16")
32
- subnet = Fog::Compute[:aws].subnets.create(
33
- :vpc_id => vpc.id,
34
- :cidr_block => "10.0.1.0/24"
35
- )
36
- default_security_group = Fog::Compute[:aws].security_groups.detect { |sg| sg.description == 'default_elb security group' }
37
- else
38
- vpc = Fog::Compute[:aws].vpcs.first
39
- subnet = vpc.subnets.first
40
- default_security_group = Fog::Compute[:aws].security_groups.detect { |sg| sg.description == 'default VPC security group' }
41
- end
42
-
43
- security_group = Fog::Compute[:aws].security_groups.create(
44
- :vpc_id => vpc.id,
45
- :name => "fog#{suffix}",
46
- :description => "fog#{suffix}"
47
- )
48
-
49
- raises(Fog::AWS::EFS::InvalidSubnet, "invalid subnet ID: foobar#{suffix}") do
50
- Fog::AWS[:efs].create_mount_target(file_system_id, "foobar#{suffix}")
51
- end
52
-
53
- raises(Fog::AWS::EFS::NotFound, "invalid file system ID: foobar#{suffix}") do
54
- Fog::AWS[:efs].create_mount_target("foobar#{suffix}", subnet.identity)
55
- end
56
-
57
- if Fog.mocking?
58
- tests("#create_mount_target") do
59
- Fog::AWS[:efs].data[:file_systems][file_system_id]["LifeCycleState"] = 'creating'
60
- raises(Fog::AWS::EFS::IncorrectFileSystemLifeCycleState) do
61
- Fog::AWS[:efs].create_mount_target(file_system_id, subnet.identity)
62
- end
63
-
64
- Fog::AWS[:efs].data[:file_systems][file_system_id]["LifeCycleState"] = 'available'
65
- end
66
- end
67
-
68
- raises(Fog::AWS::EFS::NotFound, "invalid security group ID: foobar#{suffix}") do
69
- Fog::AWS[:efs].create_mount_target(file_system_id, subnet.identity, 'SecurityGroups' => ["foobar#{suffix}"])
70
- end
71
-
72
- tests("#create_mount_target(#{file_system_id}, #{subnet.identity})").formats(AWS::EFS::Formats::MOUNT_TARGET_FORMAT) do
73
- Fog::AWS[:efs].create_mount_target(file_system_id, subnet.identity).body
74
- end
75
-
76
- tests("#describe_mount_targets(file_system_id: #{file_system_id})").formats(AWS::EFS::Formats::DESCRIBE_MOUNT_TARGETS_RESULT) do
77
- Fog::AWS[:efs].describe_mount_targets(:file_system_id => file_system_id).body
78
- end
79
-
80
- mount_target_id = Fog::AWS[:efs].describe_mount_targets(:file_system_id => file_system_id).body["MountTargets"].first["MountTargetId"]
81
-
82
- tests("#describe_mount_target_security_groups(#{mount_target_id})").formats(AWS::EFS::Formats::DESCRIBE_MOUNT_TARGET_SECURITY_GROUPS_FORMAT) do
83
- result = Fog::AWS[:efs].describe_mount_target_security_groups(mount_target_id).body
84
- returns([default_security_group.group_id]) { result["SecurityGroups"] }
85
- result
86
- end
87
-
88
- raises(Fog::AWS::EFS::Error, 'Must provide at least one security group.') do
89
- Fog::AWS[:efs].modify_mount_target_security_groups(mount_target_id, [])
90
- end
91
-
92
- tests("#modify_mount_target_security_groups(#{mount_target_id}, [#{security_group.group_id}])") do
93
- returns(204) do
94
- Fog::AWS[:efs].modify_mount_target_security_groups(mount_target_id, [security_group.group_id]).status
95
- end
96
- end
97
-
98
- Fog.wait_for { Fog::AWS[:efs].describe_mount_target_security_groups(mount_target_id).body["SecurityGroups"] != [default_security_group.group_id] }
99
-
100
- tests("#describe_mount_target_security_groups(#{mount_target_id})").formats(AWS::EFS::Formats::DESCRIBE_MOUNT_TARGET_SECURITY_GROUPS_FORMAT) do
101
- result = Fog::AWS[:efs].describe_mount_target_security_groups(mount_target_id).body
102
- returns([security_group.group_id]) { result["SecurityGroups"] }
103
- result
104
- end
105
-
106
- tests("#describe_mount_targets(id: #{mount_target_id})").formats(AWS::EFS::Formats::DESCRIBE_MOUNT_TARGETS_RESULT) do
107
- Fog::AWS[:efs].describe_mount_targets(:id => mount_target_id).body
108
- end
109
-
110
- raises(Fog::AWS::EFS::NotFound, 'Mount target does not exist.') do
111
- Fog::AWS[:efs].describe_mount_targets(:id => "foobar")
112
- end
113
-
114
- raises(Fog::AWS::EFS::Error, 'file system ID or mount target ID must be specified') do
115
- Fog::AWS[:efs].describe_mount_targets
116
- end
117
-
118
- raises(Fog::AWS::EFS::NotFound, "invalid mount target id: foobar#{suffix}") do
119
- Fog::AWS[:efs].delete_mount_target("foobar#{suffix}")
120
- end
121
-
122
- tests("#delete_mount_target(id: #{mount_target_id})") do
123
- returns(true) do
124
- result = Fog::AWS[:efs].delete_mount_target(mount_target_id)
125
- result.body.empty?
126
- end
127
- end
128
-
129
- file_system.wait_for { number_of_mount_targets == 0 }
130
-
131
- if Fog.mocking?
132
- Fog::AWS[:efs].data[:file_systems][file_system_id]["NumberOfMountTargets"] = 1
133
- raises(Fog::AWS::EFS::FileSystemInUse) do
134
- Fog::AWS[:efs].delete_file_system(file_system_id)
135
- end
136
- Fog::AWS[:efs].data[:file_systems][file_system_id]["NumberOfMountTargets"] = 0
137
- end
138
-
139
- raises(Fog::AWS::EFS::NotFound, "invalid file system ID: foobar#{suffix}") do
140
- Fog::AWS[:efs].delete_file_system("foobar#{suffix}")
141
- end
142
-
143
- tests("#delete_file_system") do
144
- returns(true) do
145
- result = Fog::AWS[:efs].delete_file_system(file_system_id)
146
- result.body.empty?
147
- end
148
- end
149
-
150
- security_group.destroy
151
- end
152
- end
@@ -1,44 +0,0 @@
1
- class AWS
2
- module EFS
3
- module Formats
4
- FILE_SYSTEM_FORMAT = {
5
- "CreationTime" => Float,
6
- "CreationToken" => String,
7
- "FileSystemId" => String,
8
- "LifeCycleState" => String,
9
- "Name" => Fog::Nullable::String,
10
- "NumberOfMountTargets" => Integer,
11
- "OwnerId" => String,
12
- "PerformanceMode" => String,
13
- "Encrypted" => Fog::Nullable::Boolean,
14
- "KmsKeyId" => Fog::Nullable::String,
15
- "SizeInBytes" => {
16
- "Timestamp" => Fog::Nullable::Float,
17
- "Value" => Integer
18
- }
19
- }
20
-
21
- MOUNT_TARGET_FORMAT = {
22
- "FileSystemId" => String,
23
- "IpAddress" => String,
24
- "LifeCycleState" => String,
25
- "MountTargetId" => String,
26
- "NetworkInterfaceId" => String,
27
- "OwnerId" => String,
28
- "SubnetId" => String
29
- }
30
-
31
- DESCRIBE_FILE_SYSTEMS_RESULT = {
32
- "FileSystems" => [FILE_SYSTEM_FORMAT]
33
- }
34
-
35
- DESCRIBE_MOUNT_TARGETS_RESULT = {
36
- "MountTargets" => [MOUNT_TARGET_FORMAT]
37
- }
38
-
39
- DESCRIBE_MOUNT_TARGET_SECURITY_GROUPS_FORMAT = {
40
- "SecurityGroups" => Array
41
- }
42
- end
43
- end
44
- end
@@ -1,137 +0,0 @@
1
- Shindo.tests('AWS::Elasticache | cache cluster requests', ['aws', 'elasticache']) do
2
-
3
- tests('success') do
4
-
5
- # Randomize the cluster ID so tests can be fequently re-run
6
- CLUSTER_ID = "fog-test-cluster-#{rand(999).to_s}" # 20 chars max!
7
- NUM_NODES = 2 # Must be > 1, because one of the tests reomves a node!
8
-
9
- tests(
10
- '#create_cache_cluster'
11
- ).formats(AWS::Elasticache::Formats::SINGLE_CACHE_CLUSTER) do
12
- body = Fog::AWS[:elasticache].create_cache_cluster(CLUSTER_ID,
13
- :num_nodes => NUM_NODES
14
- ).body
15
- cluster = body['CacheCluster']
16
- returns(CLUSTER_ID) { cluster['CacheClusterId'] }
17
- returns('creating') { cluster['CacheClusterStatus'] }
18
- body
19
- end
20
-
21
- tests(
22
- '#describe_cache_clusters without options'
23
- ).formats(AWS::Elasticache::Formats::DESCRIBE_CACHE_CLUSTERS) do
24
- body = Fog::AWS[:elasticache].describe_cache_clusters.body
25
- returns(true, "has #{CLUSTER_ID}") do
26
- body['CacheClusters'].any? do |cluster|
27
- cluster['CacheClusterId'] == CLUSTER_ID
28
- end
29
- end
30
- # The DESCRIBE_CACHE_CLUSTERS format must include only one cluster
31
- # So remove all but the relevant cluster from the response body
32
- test_cluster = body['CacheClusters'].delete_if do |cluster|
33
- cluster['CacheClusterId'] != CLUSTER_ID
34
- end
35
- body
36
- end
37
-
38
- tests(
39
- '#describe_cache_clusters with cluster ID'
40
- ).formats(AWS::Elasticache::Formats::DESCRIBE_CACHE_CLUSTERS) do
41
- body = Fog::AWS[:elasticache].describe_cache_clusters(CLUSTER_ID).body
42
- returns(1, "size of 1") { body['CacheClusters'].size }
43
- returns(CLUSTER_ID, "has #{CLUSTER_ID}") do
44
- body['CacheClusters'].first['CacheClusterId']
45
- end
46
- body
47
- end
48
-
49
- Fog::Formatador.display_line "Waiting for cluster #{CLUSTER_ID}..."
50
- Fog::AWS[:elasticache].clusters.get(CLUSTER_ID).wait_for {ready?}
51
-
52
- tests(
53
- '#describe_cache_clusters with node info'
54
- ).formats(AWS::Elasticache::Formats::CACHE_CLUSTER_RUNNING) do
55
- cluster = Fog::AWS[:elasticache].describe_cache_clusters(CLUSTER_ID,
56
- :show_node_info => true
57
- ).body['CacheClusters'].first
58
- returns(NUM_NODES, "has #{NUM_NODES} nodes") do
59
- cluster['CacheNodes'].count
60
- end
61
- cluster
62
- end
63
-
64
- tests(
65
- '#modify_cache_cluster - change a non-pending cluster attribute'
66
- ).formats(AWS::Elasticache::Formats::CACHE_CLUSTER_RUNNING) do
67
- body = Fog::AWS[:elasticache].modify_cache_cluster(CLUSTER_ID,
68
- :auto_minor_version_upgrade => false
69
- ).body
70
- # now check that parameter change is in place
71
- returns('false') { body['CacheCluster']['AutoMinorVersionUpgrade'] }
72
- body['CacheCluster']
73
- end
74
-
75
- tests(
76
- '#reboot_cache_cluster - reboot a node'
77
- ).formats(AWS::Elasticache::Formats::CACHE_CLUSTER_RUNNING) do
78
- c = Fog::AWS[:elasticache].clusters.get(CLUSTER_ID)
79
- node_id = c.nodes.last['CacheNodeId']
80
- Fog::Formatador.display_line "Rebooting node #{node_id}..."
81
- body = Fog::AWS[:elasticache].reboot_cache_cluster(c.id, [ node_id ]).body
82
- returns('rebooting cache cluster nodes') do
83
- body['CacheCluster']['CacheClusterStatus']
84
- end
85
- body['CacheCluster']
86
- end
87
-
88
- Fog::Formatador.display_line "Waiting for cluster #{CLUSTER_ID}..."
89
- Fog::AWS[:elasticache].clusters.get(CLUSTER_ID).wait_for {ready?}
90
-
91
- tests(
92
- '#modify_cache_cluster - remove a node'
93
- ).formats(AWS::Elasticache::Formats::CACHE_CLUSTER_RUNNING) do
94
- c = Fog::AWS[:elasticache].clusters.get(CLUSTER_ID)
95
- node_id = c.nodes.last['CacheNodeId']
96
- Fog::Formatador.display_line "Removing node #{node_id}..."
97
- body = Fog::AWS[:elasticache].modify_cache_cluster(c.id,
98
- {
99
- :num_nodes => NUM_NODES - 1,
100
- :nodes_to_remove => [node_id],
101
- :apply_immediately => true,
102
- }).body
103
- returns(node_id) {
104
- body['CacheCluster']['PendingModifiedValues']['CacheNodeId']
105
- }
106
- body['CacheCluster']
107
- end
108
-
109
- Fog::Formatador.display_line "Waiting for cluster #{CLUSTER_ID}..."
110
- Fog::AWS[:elasticache].clusters.get(CLUSTER_ID).wait_for {ready?}
111
-
112
- tests(
113
- '#delete_cache_clusters'
114
- ).formats(AWS::Elasticache::Formats::CACHE_CLUSTER_RUNNING) do
115
- body = Fog::AWS[:elasticache].delete_cache_cluster(CLUSTER_ID).body
116
- # make sure this particular cluster is in the returned list
117
- returns(true, "has #{CLUSTER_ID}") do
118
- body['CacheClusters'].any? do |cluster|
119
- cluster['CacheClusterId'] == CLUSTER_ID
120
- end
121
- end
122
- # now check that it reports itself as 'deleting'
123
- cluster = body['CacheClusters'].find do |cluster|
124
- cluster['CacheClusterId'] == CLUSTER_ID
125
- end
126
- returns('deleting') { cluster['CacheClusterStatus'] }
127
- cluster
128
- end
129
- end
130
-
131
- tests('failure') do
132
- # TODO:
133
- # Create a duplicate cluster ID
134
- # List a missing cache cluster
135
- # Delete a missing cache cluster
136
- end
137
- end
@@ -1,17 +0,0 @@
1
- Shindo.tests('AWS::Elasticache | describe cache cluster events',
2
- ['aws', 'elasticache']) do
3
-
4
- tests('success') do
5
- pending if Fog.mocking?
6
-
7
- tests(
8
- '#describe_events'
9
- ).formats(AWS::Elasticache::Formats::EVENT_LIST) do
10
- Fog::AWS[:elasticache].describe_events().body['Events']
11
- end
12
- end
13
-
14
- tests('failure') do
15
- # TODO:
16
- end
17
- end
@@ -1,17 +0,0 @@
1
- Shindo.tests('AWS::Elasticache | describe reserved cache nodes',
2
- ['aws', 'elasticache']) do
3
-
4
- tests('success') do
5
- pending if Fog.mocking?
6
-
7
- tests(
8
- '#describe_reserved_cache_nodes'
9
- ).formats(AWS::Elasticache::Formats::RESERVED_CACHE_NODES) do
10
- Fog::AWS[:elasticache].describe_reserved_cache_nodes().body['ReservedCacheNodes']
11
- end
12
- end
13
-
14
- tests('failure') do
15
- # TODO:
16
- end
17
- end
@@ -1,103 +0,0 @@
1
- class AWS
2
- module Elasticache
3
- module Formats
4
- BASIC = {
5
- 'ResponseMetadata' => {'RequestId' => String}
6
- }
7
-
8
- # Cache Security Groups
9
- SECURITY_GROUP = {
10
- 'EC2SecurityGroups' => Array,
11
- 'CacheSecurityGroupName' => String,
12
- 'Description' => String,
13
- 'OwnerId' => String,
14
- }
15
- SINGLE_SECURITY_GROUP = BASIC.merge('CacheSecurityGroup' => SECURITY_GROUP)
16
- DESCRIBE_SECURITY_GROUPS = {'CacheSecurityGroups' => [SECURITY_GROUP]}
17
-
18
- CACHE_SUBNET_GROUP = {
19
- 'CacheSubnetGroupName' => String,
20
- 'CacheSubnetGroupDescription' => String,
21
- 'VpcId' => String,
22
- 'Subnets' => [String]
23
- }
24
-
25
- CREATE_CACHE_SUBNET_GROUP = BASIC.merge({
26
- 'CreateCacheSubnetGroupResult' => {
27
- 'CacheSubnetGroup' => CACHE_SUBNET_GROUP
28
- }
29
- })
30
-
31
- DESCRIBE_CACHE_SUBNET_GROUPS = BASIC.merge({
32
- 'DescribeCacheSubnetGroupsResult' => {
33
- 'CacheSubnetGroups' => [CACHE_SUBNET_GROUP]
34
- }
35
- })
36
-
37
- # Cache Parameter Groups
38
- PARAMETER_GROUP = {
39
- 'CacheParameterGroupFamily' => String,
40
- 'CacheParameterGroupName' => String,
41
- 'Description' => String,
42
- }
43
- SINGLE_PARAMETER_GROUP = BASIC.merge('CacheParameterGroup' => PARAMETER_GROUP)
44
- DESCRIBE_PARAMETER_GROUPS = BASIC.merge('CacheParameterGroups' => [PARAMETER_GROUP])
45
- MODIFY_PARAMETER_GROUP = {'CacheParameterGroupName' => String }
46
- PARAMETER_SET = {
47
- 'Parameters' => Array,
48
- 'CacheNodeTypeSpecificParameters' => Array,
49
- }
50
- ENGINE_DEFAULTS = PARAMETER_SET.merge('CacheParameterGroupFamily' => String)
51
- # Cache Clusters - more parameters get added as the lifecycle progresses
52
- CACHE_CLUSTER = {
53
- 'AutoMinorVersionUpgrade' => String, # actually TrueClass or FalseClass
54
- 'CacheSecurityGroups' => Array,
55
- 'CacheClusterId' => String,
56
- 'CacheClusterStatus' => String,
57
- 'CacheNodeType' => String,
58
- 'Engine' => String,
59
- 'EngineVersion' => String,
60
- 'CacheParameterGroup' => Hash,
61
- 'NumCacheNodes' => Integer,
62
- 'PreferredMaintenanceWindow' => String,
63
- 'CacheNodes' => Array,
64
- 'PendingModifiedValues' => Hash,
65
- }
66
- CACHE_CLUSTER_RUNNING = CACHE_CLUSTER.merge({
67
- 'CacheClusterCreateTime' => DateTime,
68
- 'PreferredAvailabilityZone' => String,
69
- })
70
- CACHE_CLUSTER_MODIFIED = CACHE_CLUSTER_RUNNING.merge({
71
- 'NotificationConfiguration' => Hash,
72
- 'PendingModifiedValues' => Hash,
73
- })
74
- SINGLE_CACHE_CLUSTER = BASIC.merge('CacheCluster' => CACHE_CLUSTER)
75
- DESCRIBE_CACHE_CLUSTERS = BASIC.merge('CacheClusters' => [CACHE_CLUSTER])
76
-
77
- EVENT = {
78
- 'Date' => DateTime,
79
- 'Message' => String,
80
- 'SourceIdentifier' => String,
81
- 'SourceType' => String,
82
- }
83
- EVENT_LIST = [EVENT]
84
-
85
- RESERVED_CACHE_CLUSTER = {
86
- 'CacheNodeCount' => Integer,
87
- 'CacheNodeType' => String,
88
- 'Duration' => Integer,
89
- 'FixedPrice' => Float,
90
- 'OfferingType' => String,
91
- 'ProductDescription' => String,
92
- 'RecurringCharges' => Array,
93
- 'ReservedCacheNodeId' => String,
94
- 'ReservedCacheNodesOfferingId' => String,
95
- 'StartTime' => DateTime,
96
- 'State' => String,
97
- 'UsagePrice' => Float
98
- }
99
- RESERVED_CACHE_CLUSTER_LIST = [RESERVED_CACHE_CLUSTER]
100
-
101
- end
102
- end
103
- end