fog-aws 3.5.2 → 3.19.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (333) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +485 -22
  3. data/LICENSE.md +1 -1
  4. data/README.md +117 -7
  5. data/fog-aws.gemspec +8 -8
  6. data/lib/fog/aws/compute.rb +6 -3
  7. data/lib/fog/aws/credential_fetcher.rb +75 -7
  8. data/lib/fog/aws/elasticache.rb +4 -2
  9. data/lib/fog/aws/elb.rb +1 -1
  10. data/lib/fog/aws/elbv2.rb +72 -0
  11. data/lib/fog/aws/kinesis.rb +23 -15
  12. data/lib/fog/aws/models/compute/flavors.rb +2563 -521
  13. data/lib/fog/aws/models/compute/security_group.rb +13 -5
  14. data/lib/fog/aws/models/compute/server.rb +6 -2
  15. data/lib/fog/aws/models/compute/servers.rb +2 -0
  16. data/lib/fog/aws/models/compute/snapshot.rb +7 -6
  17. data/lib/fog/aws/models/compute/vpc.rb +8 -2
  18. data/lib/fog/aws/models/storage/directories.rb +1 -0
  19. data/lib/fog/aws/models/storage/directory.rb +0 -1
  20. data/lib/fog/aws/models/storage/file.rb +164 -20
  21. data/lib/fog/aws/models/storage/files.rb +32 -2
  22. data/lib/fog/aws/parsers/compute/create_snapshot.rb +1 -1
  23. data/lib/fog/aws/parsers/compute/create_subnet.rb +33 -6
  24. data/lib/fog/aws/parsers/compute/describe_security_groups.rb +18 -4
  25. data/lib/fog/aws/parsers/compute/describe_subnets.rb +33 -6
  26. data/lib/fog/aws/parsers/dns/create_hosted_zone.rb +1 -1
  27. data/lib/fog/aws/parsers/dns/get_hosted_zone.rb +3 -3
  28. data/lib/fog/aws/parsers/dns/list_hosted_zones.rb +3 -1
  29. data/lib/fog/aws/parsers/elbv2/create_load_balancer.rb +88 -0
  30. data/lib/fog/aws/parsers/elbv2/describe_listeners.rb +110 -0
  31. data/lib/fog/aws/parsers/elbv2/describe_load_balancers.rb +88 -0
  32. data/lib/fog/aws/parsers/elbv2/describe_tags.rb +53 -0
  33. data/lib/fog/aws/parsers/elbv2/empty.rb +10 -0
  34. data/lib/fog/aws/parsers/iam/get_group_policy.rb +1 -1
  35. data/lib/fog/aws/parsers/iam/get_role_policy.rb +1 -1
  36. data/lib/fog/aws/parsers/iam/get_user_policy.rb +1 -1
  37. data/lib/fog/aws/parsers/iam/policy_version.rb +1 -1
  38. data/lib/fog/aws/parsers/storage/get_object_tagging.rb +33 -0
  39. data/lib/fog/aws/parsers/storage/upload_part_copy_object.rb +18 -0
  40. data/lib/fog/aws/parsers/sts/assume_role_with_web_identity.rb +1 -1
  41. data/lib/fog/aws/requests/compute/authorize_security_group_ingress.rb +15 -0
  42. data/lib/fog/aws/requests/compute/create_network_interface.rb +7 -4
  43. data/lib/fog/aws/requests/compute/create_subnet.rb +3 -3
  44. data/lib/fog/aws/requests/compute/create_vpc.rb +2 -2
  45. data/lib/fog/aws/requests/compute/describe_security_groups.rb +2 -0
  46. data/lib/fog/aws/requests/compute/request_spot_instances.rb +1 -1
  47. data/lib/fog/aws/requests/compute/run_instances.rb +64 -0
  48. data/lib/fog/aws/requests/compute/stop_instances.rb +11 -3
  49. data/lib/fog/aws/requests/elbv2/add_tags.rb +45 -0
  50. data/lib/fog/aws/requests/elbv2/create_load_balancer.rb +160 -0
  51. data/lib/fog/aws/requests/elbv2/describe_listeners.rb +38 -0
  52. data/lib/fog/aws/requests/elbv2/describe_load_balancers.rb +100 -0
  53. data/lib/fog/aws/requests/elbv2/describe_tags.rb +50 -0
  54. data/lib/fog/aws/requests/elbv2/remove_tags.rb +45 -0
  55. data/lib/fog/aws/requests/rds/add_tags_to_resource.rb +12 -10
  56. data/lib/fog/aws/requests/rds/list_tags_for_resource.rb +10 -7
  57. data/lib/fog/aws/requests/rds/remove_tags_from_resource.rb +9 -8
  58. data/lib/fog/aws/requests/storage/delete_multiple_objects.rb +18 -8
  59. data/lib/fog/aws/requests/storage/get_object.rb +1 -1
  60. data/lib/fog/aws/requests/storage/get_object_tagging.rb +41 -0
  61. data/lib/fog/aws/requests/storage/get_service.rb +1 -1
  62. data/lib/fog/aws/requests/storage/put_object_tagging.rb +42 -0
  63. data/lib/fog/aws/requests/storage/shared_mock_methods.rb +1 -0
  64. data/lib/fog/aws/requests/storage/sync_clock.rb +9 -1
  65. data/lib/fog/aws/requests/storage/upload_part_copy.rb +119 -0
  66. data/lib/fog/aws/requests/sts/assume_role_with_web_identity.rb +7 -6
  67. data/lib/fog/aws/storage.rb +56 -5
  68. data/lib/fog/aws/version.rb +1 -1
  69. data/lib/fog/aws.rb +7 -2
  70. metadata +35 -295
  71. data/.gitignore +0 -16
  72. data/.travis.yml +0 -53
  73. data/Gemfile +0 -14
  74. data/Rakefile +0 -14
  75. data/gemfiles/Gemfile-edge +0 -14
  76. data/gemfiles/Gemfile-ruby-2.0 +0 -7
  77. data/stale.yml +0 -17
  78. data/tests/credentials_tests.rb +0 -87
  79. data/tests/helper.rb +0 -29
  80. data/tests/helpers/collection_helper.rb +0 -90
  81. data/tests/helpers/compute/flavors_helper.rb +0 -28
  82. data/tests/helpers/compute/server_helper.rb +0 -23
  83. data/tests/helpers/compute/servers_helper.rb +0 -8
  84. data/tests/helpers/dns_helper.rb +0 -56
  85. data/tests/helpers/formats_helper.rb +0 -100
  86. data/tests/helpers/formats_helper_tests.rb +0 -107
  87. data/tests/helpers/mock_helper.rb +0 -109
  88. data/tests/helpers/model_helper.rb +0 -30
  89. data/tests/helpers/responds_to_helper.rb +0 -11
  90. data/tests/helpers/schema_validator_tests.rb +0 -104
  91. data/tests/helpers/succeeds_helper.rb +0 -9
  92. data/tests/lorem.txt +0 -1
  93. data/tests/models/auto_scaling/activities_tests.rb +0 -6
  94. data/tests/models/auto_scaling/configuration_test.rb +0 -13
  95. data/tests/models/auto_scaling/configurations_tests.rb +0 -11
  96. data/tests/models/auto_scaling/groups_test.rb +0 -27
  97. data/tests/models/auto_scaling/helper.rb +0 -0
  98. data/tests/models/auto_scaling/instance_tests.rb +0 -15
  99. data/tests/models/auto_scaling/instances_tests.rb +0 -6
  100. data/tests/models/beanstalk/application_tests.rb +0 -69
  101. data/tests/models/beanstalk/applications_tests.rb +0 -7
  102. data/tests/models/beanstalk/environment_tests.rb +0 -131
  103. data/tests/models/beanstalk/environments_tests.rb +0 -34
  104. data/tests/models/beanstalk/template_tests.rb +0 -47
  105. data/tests/models/beanstalk/templates_tests.rb +0 -62
  106. data/tests/models/beanstalk/version_tests.rb +0 -66
  107. data/tests/models/beanstalk/versions_tests.rb +0 -60
  108. data/tests/models/cdn/distribution_tests.rb +0 -15
  109. data/tests/models/cdn/distributions_tests.rb +0 -15
  110. data/tests/models/cdn/invalidation_tests.rb +0 -31
  111. data/tests/models/cdn/invalidations_tests.rb +0 -14
  112. data/tests/models/cdn/streaming_distribution_tests.rb +0 -15
  113. data/tests/models/cdn/streaming_distributions_tests.rb +0 -15
  114. data/tests/models/cloud_watch/alarm_data_tests.rb +0 -42
  115. data/tests/models/cloud_watch/alarm_history_tests.rb +0 -22
  116. data/tests/models/cloud_watch/metric_statistics_tests.rb +0 -51
  117. data/tests/models/cloud_watch/metrics_tests.rb +0 -32
  118. data/tests/models/compute/address_tests.rb +0 -43
  119. data/tests/models/compute/addresses_tests.rb +0 -5
  120. data/tests/models/compute/dhcp_option_tests.rb +0 -3
  121. data/tests/models/compute/dhcp_options_tests.rb +0 -3
  122. data/tests/models/compute/internet_gateway_tests.rb +0 -3
  123. data/tests/models/compute/internet_gateways_tests.rb +0 -3
  124. data/tests/models/compute/key_pair_tests.rb +0 -26
  125. data/tests/models/compute/key_pairs_tests.rb +0 -5
  126. data/tests/models/compute/network_acl_tests.rb +0 -109
  127. data/tests/models/compute/network_acls_tests.rb +0 -20
  128. data/tests/models/compute/network_interfaces_test.rb +0 -12
  129. data/tests/models/compute/security_group_tests.rb +0 -98
  130. data/tests/models/compute/security_groups_tests.rb +0 -5
  131. data/tests/models/compute/server_tests.rb +0 -94
  132. data/tests/models/compute/snapshot_tests.rb +0 -10
  133. data/tests/models/compute/snapshots_tests.rb +0 -10
  134. data/tests/models/compute/subnet_tests.rb +0 -13
  135. data/tests/models/compute/subnets_tests.rb +0 -5
  136. data/tests/models/compute/volume_tests.rb +0 -65
  137. data/tests/models/compute/volumes_tests.rb +0 -5
  138. data/tests/models/compute/vpc_tests.rb +0 -26
  139. data/tests/models/compute/vpcs_tests.rb +0 -19
  140. data/tests/models/data_pipeline/pipeline_tests.rb +0 -8
  141. data/tests/models/data_pipeline/pipelines_tests.rb +0 -8
  142. data/tests/models/dns/record_tests.rb +0 -33
  143. data/tests/models/dns/records_tests.rb +0 -41
  144. data/tests/models/dns/zone_tests.rb +0 -4
  145. data/tests/models/dns/zones_tests.rb +0 -4
  146. data/tests/models/efs/file_system_tests.rb +0 -12
  147. data/tests/models/efs/mount_target_tests.rb +0 -45
  148. data/tests/models/efs/mount_targets_tests.rb +0 -30
  149. data/tests/models/elasticache/cluster_tests.rb +0 -30
  150. data/tests/models/elasticache/parameter_groups_tests.rb +0 -15
  151. data/tests/models/elasticache/security_groups_tests.rb +0 -52
  152. data/tests/models/elasticache/subnet_groups_tests.rb +0 -43
  153. data/tests/models/elb/model_tests.rb +0 -360
  154. data/tests/models/elb/tagging_tests.rb +0 -15
  155. data/tests/models/glacier/model_tests.rb +0 -47
  156. data/tests/models/iam/access_keys_tests.rb +0 -53
  157. data/tests/models/iam/groups_tests.rb +0 -59
  158. data/tests/models/iam/instance_profile_tests.rb +0 -18
  159. data/tests/models/iam/managed_policies_tests.rb +0 -89
  160. data/tests/models/iam/policies_tests.rb +0 -57
  161. data/tests/models/iam/roles_tests.rb +0 -71
  162. data/tests/models/iam/users_tests.rb +0 -119
  163. data/tests/models/rds/cluster_tests.rb +0 -54
  164. data/tests/models/rds/clusters_tests.rb +0 -5
  165. data/tests/models/rds/event_subscription_tests.rb +0 -9
  166. data/tests/models/rds/event_subscriptions_tests.rb +0 -6
  167. data/tests/models/rds/helper.rb +0 -25
  168. data/tests/models/rds/instance_option_tests.rb +0 -14
  169. data/tests/models/rds/parameter_group_tests.rb +0 -24
  170. data/tests/models/rds/parameter_groups_tests.rb +0 -8
  171. data/tests/models/rds/security_group_tests.rb +0 -77
  172. data/tests/models/rds/security_groups_tests.rb +0 -5
  173. data/tests/models/rds/server_tests.rb +0 -131
  174. data/tests/models/rds/servers_tests.rb +0 -24
  175. data/tests/models/rds/snapshot_tests.rb +0 -12
  176. data/tests/models/rds/snapshots_tests.rb +0 -12
  177. data/tests/models/rds/tagging_tests.rb +0 -20
  178. data/tests/models/sns/topic_tests.rb +0 -15
  179. data/tests/models/sns/topics_tests.rb +0 -6
  180. data/tests/models/storage/directory_tests.rb +0 -91
  181. data/tests/models/storage/file_tests.rb +0 -129
  182. data/tests/models/storage/files_tests.rb +0 -58
  183. data/tests/models/storage/url_tests.rb +0 -25
  184. data/tests/models/storage/version_tests.rb +0 -52
  185. data/tests/models/storage/versions_tests.rb +0 -51
  186. data/tests/models/support/trusted_advisor_tests.rb +0 -25
  187. data/tests/parsers/compute/describe_images_tests.rb +0 -33
  188. data/tests/parsers/elb/describe_load_balancers.rb +0 -65
  189. data/tests/requests/auto_scaling/auto_scaling_tests.rb +0 -111
  190. data/tests/requests/auto_scaling/describe_types_tests.rb +0 -102
  191. data/tests/requests/auto_scaling/helper.rb +0 -229
  192. data/tests/requests/auto_scaling/model_tests.rb +0 -235
  193. data/tests/requests/auto_scaling/notification_configuration_tests.rb +0 -124
  194. data/tests/requests/auto_scaling/tag_tests.rb +0 -63
  195. data/tests/requests/beanstalk/application_tests.rb +0 -140
  196. data/tests/requests/beanstalk/solution_stack_tests.rb +0 -22
  197. data/tests/requests/cdn/cdn_tests.rb +0 -252
  198. data/tests/requests/cloud_formation/stack_tests.rb +0 -167
  199. data/tests/requests/cloud_watch/get_metric_statistics_tests.rb +0 -28
  200. data/tests/requests/cloud_watch/list_metrics_test.rb +0 -64
  201. data/tests/requests/cloud_watch/put_metric_data_tests.rb +0 -36
  202. data/tests/requests/compute/address_tests.rb +0 -144
  203. data/tests/requests/compute/assign_private_ip_tests.rb +0 -55
  204. data/tests/requests/compute/availability_zone_tests.rb +0 -25
  205. data/tests/requests/compute/client_tests.rb +0 -25
  206. data/tests/requests/compute/dhcp_options_tests.rb +0 -39
  207. data/tests/requests/compute/helper.rb +0 -27
  208. data/tests/requests/compute/image_tests.rb +0 -169
  209. data/tests/requests/compute/instance_attrib_tests.rb +0 -168
  210. data/tests/requests/compute/instance_tests.rb +0 -338
  211. data/tests/requests/compute/internet_gateway_tests.rb +0 -49
  212. data/tests/requests/compute/key_pair_tests.rb +0 -67
  213. data/tests/requests/compute/network_acl_tests.rb +0 -112
  214. data/tests/requests/compute/network_interface_tests.rb +0 -239
  215. data/tests/requests/compute/placement_group_tests.rb +0 -48
  216. data/tests/requests/compute/region_tests.rb +0 -52
  217. data/tests/requests/compute/route_tests.rb +0 -341
  218. data/tests/requests/compute/security_group_tests.rb +0 -446
  219. data/tests/requests/compute/snapshot_tests.rb +0 -77
  220. data/tests/requests/compute/spot_datafeed_subscription_tests.rb +0 -47
  221. data/tests/requests/compute/spot_instance_tests.rb +0 -55
  222. data/tests/requests/compute/spot_price_history_tests.rb +0 -23
  223. data/tests/requests/compute/subnet_tests.rb +0 -87
  224. data/tests/requests/compute/tag_tests.rb +0 -101
  225. data/tests/requests/compute/volume_tests.rb +0 -263
  226. data/tests/requests/compute/vpc_tests.rb +0 -216
  227. data/tests/requests/data_pipeline/helper.rb +0 -78
  228. data/tests/requests/data_pipeline/pipeline_tests.rb +0 -80
  229. data/tests/requests/dns/change_resource_record_sets_tests.rb +0 -34
  230. data/tests/requests/dns/dns_tests.rb +0 -240
  231. data/tests/requests/dns/health_check_tests.rb +0 -159
  232. data/tests/requests/dns/helper.rb +0 -21
  233. data/tests/requests/dynamodb/item_tests.rb +0 -137
  234. data/tests/requests/dynamodb/table_tests.rb +0 -99
  235. data/tests/requests/ecs/cluster_tests.rb +0 -112
  236. data/tests/requests/ecs/container_instance_tests.rb +0 -119
  237. data/tests/requests/ecs/helper.rb +0 -276
  238. data/tests/requests/ecs/sample_task_definition1.json +0 -56
  239. data/tests/requests/ecs/service_tests.rb +0 -132
  240. data/tests/requests/ecs/task_definitions_tests.rb +0 -97
  241. data/tests/requests/ecs/task_tests.rb +0 -145
  242. data/tests/requests/efs/file_system_tests.rb +0 -152
  243. data/tests/requests/efs/helper.rb +0 -44
  244. data/tests/requests/elasticache/cache_cluster_tests.rb +0 -137
  245. data/tests/requests/elasticache/describe_events.rb +0 -17
  246. data/tests/requests/elasticache/describe_reserved_cache_nodes.rb +0 -17
  247. data/tests/requests/elasticache/helper.rb +0 -103
  248. data/tests/requests/elasticache/parameter_group_tests.rb +0 -105
  249. data/tests/requests/elasticache/security_group_tests.rb +0 -108
  250. data/tests/requests/elasticache/subnet_group_tests.rb +0 -52
  251. data/tests/requests/elb/helper.rb +0 -91
  252. data/tests/requests/elb/listener_tests.rb +0 -68
  253. data/tests/requests/elb/load_balancer_tests.rb +0 -89
  254. data/tests/requests/elb/policy_tests.rb +0 -132
  255. data/tests/requests/emr/helper.rb +0 -167
  256. data/tests/requests/emr/instance_group_tests.rb +0 -106
  257. data/tests/requests/emr/job_flow_tests.rb +0 -88
  258. data/tests/requests/federation/get_signin_token_tests.rb +0 -11
  259. data/tests/requests/glacier/archive_tests.rb +0 -13
  260. data/tests/requests/glacier/multipart_upload_tests.rb +0 -29
  261. data/tests/requests/glacier/tree_hash_tests.rb +0 -91
  262. data/tests/requests/glacier/vault_tests.rb +0 -35
  263. data/tests/requests/iam/access_key_tests.rb +0 -53
  264. data/tests/requests/iam/account_policy_tests.rb +0 -20
  265. data/tests/requests/iam/account_tests.rb +0 -34
  266. data/tests/requests/iam/group_policy_tests.rb +0 -48
  267. data/tests/requests/iam/group_tests.rb +0 -44
  268. data/tests/requests/iam/helper.rb +0 -154
  269. data/tests/requests/iam/instance_profile_tests.rb +0 -44
  270. data/tests/requests/iam/login_profile_tests.rb +0 -62
  271. data/tests/requests/iam/managed_policy_tests.rb +0 -110
  272. data/tests/requests/iam/mfa_tests.rb +0 -23
  273. data/tests/requests/iam/role_tests.rb +0 -156
  274. data/tests/requests/iam/server_certificate_tests.rb +0 -130
  275. data/tests/requests/iam/user_policy_tests.rb +0 -45
  276. data/tests/requests/iam/user_tests.rb +0 -78
  277. data/tests/requests/iam/versioned_managed_policy_tests.rb +0 -105
  278. data/tests/requests/kinesis/helper.rb +0 -111
  279. data/tests/requests/kinesis/stream_tests.rb +0 -169
  280. data/tests/requests/kms/helper.rb +0 -27
  281. data/tests/requests/kms/key_tests.rb +0 -23
  282. data/tests/requests/lambda/function_sample_1.js +0 -9
  283. data/tests/requests/lambda/function_sample_2.js +0 -9
  284. data/tests/requests/lambda/function_tests.rb +0 -460
  285. data/tests/requests/lambda/helper.rb +0 -81
  286. data/tests/requests/rds/cluster_snapshot_tests.rb +0 -43
  287. data/tests/requests/rds/cluster_tests.rb +0 -37
  288. data/tests/requests/rds/db_engine_versions.rb +0 -7
  289. data/tests/requests/rds/db_snapshot_tests.rb +0 -62
  290. data/tests/requests/rds/describe_events.rb +0 -16
  291. data/tests/requests/rds/event_subscription_tests.rb +0 -30
  292. data/tests/requests/rds/helper.rb +0 -406
  293. data/tests/requests/rds/instance_option_tests.rb +0 -27
  294. data/tests/requests/rds/instance_tests.rb +0 -149
  295. data/tests/requests/rds/log_file_tests.rb +0 -19
  296. data/tests/requests/rds/parameter_group_tests.rb +0 -62
  297. data/tests/requests/rds/parameter_request_tests.rb +0 -32
  298. data/tests/requests/rds/security_group_tests.rb +0 -101
  299. data/tests/requests/rds/subnet_groups_tests.rb +0 -52
  300. data/tests/requests/rds/tagging_tests.rb +0 -78
  301. data/tests/requests/redshift/cluster_parameter_group_tests.rb +0 -76
  302. data/tests/requests/redshift/cluster_security_group_tests.rb +0 -42
  303. data/tests/requests/redshift/cluster_snapshot_tests.rb +0 -73
  304. data/tests/requests/redshift/cluster_tests.rb +0 -80
  305. data/tests/requests/ses/helper.rb +0 -9
  306. data/tests/requests/ses/verified_domain_identity_tests.rb +0 -16
  307. data/tests/requests/ses/verified_email_address_tests.rb +0 -27
  308. data/tests/requests/simpledb/attributes_tests.rb +0 -86
  309. data/tests/requests/simpledb/domain_tests.rb +0 -51
  310. data/tests/requests/simpledb/helper.rb +0 -10
  311. data/tests/requests/sns/helper.rb +0 -9
  312. data/tests/requests/sns/subscription_tests.rb +0 -86
  313. data/tests/requests/sns/topic_tests.rb +0 -53
  314. data/tests/requests/sqs/helper.rb +0 -9
  315. data/tests/requests/sqs/message_tests.rb +0 -51
  316. data/tests/requests/sqs/queue_tests.rb +0 -50
  317. data/tests/requests/storage/acl_utils_tests.rb +0 -209
  318. data/tests/requests/storage/bucket_tests.rb +0 -416
  319. data/tests/requests/storage/cors_utils_tests.rb +0 -108
  320. data/tests/requests/storage/delete_multiple_objects_tests.rb +0 -12
  321. data/tests/requests/storage/multipart_upload_tests.rb +0 -121
  322. data/tests/requests/storage/object_tests.rb +0 -262
  323. data/tests/requests/storage/versioning_tests.rb +0 -262
  324. data/tests/requests/sts/assume_role_tests.rb +0 -19
  325. data/tests/requests/sts/assume_role_with_saml_tests.rb +0 -18
  326. data/tests/requests/sts/assume_role_with_web_identity_tests.rb +0 -28
  327. data/tests/requests/sts/get_federation_token_tests.rb +0 -20
  328. data/tests/requests/sts/session_token_tests.rb +0 -16
  329. data/tests/requests/support/helper.rb +0 -43
  330. data/tests/requests/support/trusted_advisor_check_tests.rb +0 -16
  331. data/tests/signaturev4_tests.rb +0 -106
  332. data/tests/signed_params_tests.rb +0 -17
  333. data/tests/storage_tests.rb +0 -7
@@ -1,360 +0,0 @@
1
- Shindo.tests('AWS::ELB | models', ['aws', 'elb']) do
2
- Fog::AWS::Compute::Mock.reset if Fog.mocking?
3
- @availability_zones = Fog::Compute[:aws].describe_availability_zones('state' => 'available').body['availabilityZoneInfo'].map{ |az| az['zoneName'] }
4
- @key_name = 'fog-test-model'
5
- @vpc = Fog::Compute[:aws].vpcs.create('cidr_block' => '10.0.10.0/24')
6
- @vpc_id = @vpc.id
7
- @subnet = Fog::Compute[:aws].subnets.create({:vpc_id => @vpc_id, :cidr_block => '10.0.10.0/24'})
8
- @subnet_id = @subnet.subnet_id
9
- @scheme = 'internal'
10
- @igw = Fog::Compute[:aws].internet_gateways.create
11
- @igw_id = @igw.id
12
- @igw.attach(@vpc_id)
13
-
14
- tests('success') do
15
- tests('load_balancers') do
16
- tests('getting a missing elb') do
17
- returns(nil) { Fog::AWS[:elb].load_balancers.get('no-such-elb') }
18
- end
19
- end
20
-
21
- tests('listeners') do
22
- tests("default attributes") do
23
- listener = Fog::AWS[:elb].listeners.new
24
- tests('instance_port is 80').returns(80) { listener.instance_port }
25
- tests('instance_protocol is HTTP').returns('HTTP') { listener.instance_protocol }
26
- tests('lb_port is 80').returns(80) { listener.lb_port }
27
- tests('protocol is HTTP').returns('HTTP') { listener.protocol }
28
- tests('policy_names is empty').returns([]) { listener.policy_names }
29
- end
30
-
31
- tests("specifying attributes") do
32
- attributes = {:instance_port => 2000, :instance_protocol => 'SSL', :lb_port => 2001, :protocol => 'SSL', :policy_names => ['fake'] }
33
- listener = Fog::AWS[:elb].listeners.new(attributes)
34
- tests('instance_port is 2000').returns(2000) { listener.instance_port }
35
- tests('instance_protocol is SSL').returns('SSL') { listener.instance_protocol }
36
- tests('lb_port is 2001').returns(2001) { listener.lb_port }
37
- tests('protocol is SSL').returns('SSL') { listener.protocol }
38
- tests('policy_names is [ fake ]').returns(['fake']) { listener.policy_names }
39
- end
40
- end
41
-
42
- elb = nil
43
- elb_id = 'fog-test'
44
-
45
- tests('create') do
46
- tests('without availability zones') do
47
- elb = Fog::AWS[:elb].load_balancers.create(:id => elb_id, :availability_zones => @availability_zones)
48
- tests("availability zones are correct").returns(@availability_zones.sort) { elb.availability_zones.sort }
49
- tests("dns names is set").returns(true) { elb.dns_name.is_a?(String) }
50
- tests("created_at is set").returns(true) { Time === elb.created_at }
51
- tests("policies is empty").returns([]) { elb.policies }
52
- tests("default listener") do
53
- tests("1 listener").returns(1) { elb.listeners.size }
54
- tests("params").returns(Fog::AWS[:elb].listeners.new.to_params) { elb.listeners.first.to_params }
55
- end
56
- end
57
- tests('with vpc') do
58
- elb2 = Fog::AWS[:elb].load_balancers.create(:id => "#{elb_id}-2", :subnet_ids => [@subnet_id])
59
- tests("elb source group should be default").returns('default') { elb2.source_group["GroupName"] }
60
- tests("subnet ids are correct").returns(@subnet_id) { elb2.subnet_ids.first }
61
- elb2.destroy
62
- end
63
- tests('with vpc internal') do
64
- elb2 = Fog::AWS[:elb].load_balancers.create(:id => "#{elb_id}-2", :subnet_ids => [@subnet_id], :scheme => 'internal')
65
- tests("scheme is internal").returns(@scheme) { elb2.scheme }
66
- elb2.destroy
67
- end
68
- tests('with default vpc') do
69
- Fog::Compute[:aws].disable_ec2_classic if Fog.mocking?
70
-
71
- if Fog::Compute[:aws].supported_platforms.include?("EC2")
72
- Fog::Formatador.display_line("[yellow]Skipping test [bold]with default vpc[/][yellow] due to AWS account having EC2 available[/]")
73
- else
74
- elb2 = Fog::AWS[:elb].load_balancers.create(:id => "#{elb_id}-2", :availability_zones => @availability_zones[0])
75
- tests("elb source group should start with default_elb_").returns(true) { !!(elb2.source_group["GroupName"] =~ /default_elb_/) }
76
- elb2.destroy
77
- end
78
-
79
- Fog::Compute[:aws].enable_ec2_classic if Fog.mocking?
80
- end
81
-
82
- if !Fog.mocking?
83
- @igw.detach(@vpc_id)
84
- @igw.destroy
85
- @subnet.destroy
86
- sleep 5
87
- @vpc.destroy
88
- end
89
-
90
- tests('with availability zones') do
91
- azs = @availability_zones[1..-1]
92
- elb2 = Fog::AWS[:elb].load_balancers.create(:id => "#{elb_id}-2", :availability_zones => azs)
93
- if Fog::Compute[:aws].supported_platforms.include?("EC2")
94
- tests("elb source group should be amazon-elb-sg").returns('amazon-elb-sg') { elb2.source_group["GroupName"] }
95
- else
96
- tests("elb source group should match default_elb_").returns(true) { !!(elb2.source_group["GroupName"] =~ /default_elb_/) }
97
- end
98
- tests("availability zones are correct").returns(azs.sort) { elb2.availability_zones.sort }
99
- elb2.destroy
100
- end
101
-
102
- # Need to sleep here for IAM changes to propgate
103
- tests('with ListenerDescriptions') do
104
- @certificate = Fog::AWS[:iam].upload_server_certificate(AWS::IAM::SERVER_CERT, AWS::IAM::SERVER_CERT_PRIVATE_KEY, @key_name).body['Certificate']
105
- sleep(10) unless Fog.mocking?
106
- listeners = [{
107
- 'Listener' => {
108
- 'LoadBalancerPort' => 2030, 'InstancePort' => 2030, 'Protocol' => 'HTTP'
109
- },
110
- 'PolicyNames' => []
111
- }, {
112
- 'Listener' => {
113
- 'LoadBalancerPort' => 443, 'InstancePort' => 443, 'Protocol' => 'HTTPS', 'InstanceProtocol' => 'HTTPS',
114
- 'SSLCertificateId' => @certificate['Arn']
115
- },
116
- 'PolicyNames' => []
117
- }]
118
- elb3 = Fog::AWS[:elb].load_balancers.create(:id => "#{elb_id}-3", 'ListenerDescriptions' => listeners, :availability_zones => @availability_zones)
119
- tests('there are 2 listeners').returns(2) { elb3.listeners.count }
120
- tests('instance_port is 2030').returns(2030) { elb3.listeners.first.instance_port }
121
- tests('lb_port is 2030').returns(2030) { elb3.listeners.first.lb_port }
122
- tests('protocol is HTTP').returns('HTTP') { elb3.listeners.first.protocol }
123
- tests('protocol is HTTPS').returns('HTTPS') { elb3.listeners.last.protocol }
124
- tests('instance_protocol is HTTPS').returns('HTTPS') { elb3.listeners.last.instance_protocol }
125
- elb3.destroy
126
- end
127
-
128
- tests('with invalid Server Cert ARN').raises(Fog::AWS::IAM::NotFound) do
129
- listeners = [{
130
- 'Listener' => {
131
- 'LoadBalancerPort' => 443, 'InstancePort' => 80, 'Protocol' => 'HTTPS', 'InstanceProtocol' => 'HTTPS', "SSLCertificateId" => "fakecert"}
132
- }]
133
- Fog::AWS[:elb].load_balancers.create(:id => "#{elb_id}-4", "ListenerDescriptions" => listeners, :availability_zones => @availability_zones)
134
- end
135
- end
136
-
137
- tests('all') do
138
- elb_ids = Fog::AWS[:elb].load_balancers.all.map{|e| e.id}
139
- tests("contains elb").returns(true) { elb_ids.include? elb_id }
140
- end
141
-
142
- if Fog.mocking?
143
- tests('all marker support') do
144
- extra_elb_ids = (1..1000).map {|n| Fog::AWS[:elb].load_balancers.create(:id => "#{elb_id}-extra-#{n}").id }
145
- tests('returns all elbs').returns(true) { (extra_elb_ids - Fog::AWS[:elb].load_balancers.all.map {|e| e.id }).empty? }
146
- end
147
- end
148
-
149
- tests('get') do
150
- tests('ids match').returns(elb_id) { Fog::AWS[:elb].load_balancers.get(elb_id).id }
151
- tests('nil id').returns(nil) { Fog::AWS[:elb].load_balancers.get(nil) }
152
- end
153
-
154
- tests('creating a duplicate elb') do
155
- raises(Fog::AWS::ELB::IdentifierTaken) do
156
- Fog::AWS[:elb].load_balancers.create(:id => elb_id, :availability_zones => ['us-east-1d'])
157
- end
158
- end
159
-
160
- tests('registering an invalid instance') do
161
- raises(Fog::AWS::ELB::InvalidInstance) { elb.register_instances('i-00000000') }
162
- end
163
-
164
- tests('deregistering an invalid instance') do
165
- raises(Fog::AWS::ELB::InvalidInstance) { elb.deregister_instances('i-00000000') }
166
- end
167
-
168
- server = Fog::Compute[:aws].servers.create
169
- server.wait_for { ready? }
170
-
171
- tests('register instance') do
172
- begin
173
- elb.register_instances(server.id)
174
- rescue Fog::AWS::ELB::InvalidInstance
175
- # It may take a moment for a newly created instances to be visible to ELB requests
176
- raise if @retried_registered_instance
177
- @retried_registered_instance = true
178
- sleep 1
179
- retry
180
- end
181
-
182
- returns([server.id]) { elb.instances }
183
- end
184
-
185
- tests('instance_health') do
186
- returns('OutOfService') do
187
- elb.instance_health.find{|hash| hash['InstanceId'] == server.id}['State']
188
- end
189
-
190
- returns([server.id]) { elb.instances_out_of_service }
191
- end
192
-
193
- tests('deregister instance') do
194
- elb.deregister_instances(server.id)
195
- returns([]) { elb.instances }
196
- end
197
- server.destroy
198
-
199
- tests('disable_availability_zones') do
200
- elb.disable_availability_zones(@availability_zones[1..-1])
201
- returns(@availability_zones[0..0]) { elb.availability_zones.sort }
202
- end
203
-
204
- tests('enable_availability_zones') do
205
- elb.enable_availability_zones(@availability_zones[1..-1])
206
- returns(@availability_zones) { elb.availability_zones.sort }
207
- end
208
-
209
- tests('connection_draining') do
210
- returns(false) { elb.connection_draining? }
211
- returns(300) { elb.connection_draining_timeout }
212
- elb.set_connection_draining(true, 60)
213
- returns(true) { elb.connection_draining? }
214
- returns(60) { elb.connection_draining_timeout }
215
- end
216
-
217
- tests('cross_zone_load_balancing') do
218
- returns(false) {elb.cross_zone_load_balancing?}
219
- elb.cross_zone_load_balancing = true
220
- returns(true) {elb.cross_zone_load_balancing?}
221
- end
222
-
223
- tests('idle_connection_settings') do
224
- returns(60) { elb.connection_settings_idle_timeout }
225
- elb.set_connection_settings_idle_timeout(180)
226
- returns(180) { elb.connection_settings_idle_timeout }
227
- end
228
-
229
- tests('default health check') do
230
- default_health_check = {
231
- "HealthyThreshold"=>10,
232
- "Timeout"=>5,
233
- "UnhealthyThreshold"=>2,
234
- "Interval"=>30,
235
- "Target"=>"TCP:80"
236
- }
237
- returns(default_health_check) { elb.health_check }
238
- end
239
-
240
- tests('configure_health_check') do
241
- new_health_check = {
242
- "HealthyThreshold"=>5,
243
- "Timeout"=>10,
244
- "UnhealthyThreshold"=>3,
245
- "Interval"=>15,
246
- "Target"=>"HTTP:80/index.html"
247
- }
248
- elb.configure_health_check(new_health_check)
249
- returns(new_health_check) { elb.health_check }
250
- end
251
-
252
- tests('listeners') do
253
- tests('default') do
254
- returns(1) { elb.listeners.size }
255
-
256
- listener = elb.listeners.first
257
- returns([80,80,'HTTP','HTTP', []]) { [listener.instance_port, listener.lb_port, listener.protocol, listener.instance_protocol, listener.policy_names] }
258
- end
259
-
260
- tests('#get') do
261
- returns(80) { elb.listeners.get(80).lb_port }
262
- end
263
-
264
- tests('create') do
265
- elb.listeners.create(:instance_port => 443, :lb_port => 443, :protocol => 'TCP', :instance_protocol => 'TCP')
266
- returns(2) { elb.listeners.size }
267
- returns(443) { elb.listeners.get(443).lb_port }
268
- end
269
-
270
- tests('destroy') do
271
- elb.listeners.get(443).destroy
272
- returns(nil) { elb.listeners.get(443) }
273
- end
274
- end
275
-
276
- tests('policies') do
277
- app_policy_id = 'my-app-policy'
278
-
279
- tests 'are empty' do
280
- returns([]) { elb.policies.to_a }
281
- end
282
-
283
- tests('#all') do
284
- returns([]) { elb.policies.all.to_a }
285
- end
286
-
287
- tests('create app policy') do
288
- elb.policies.create(:id => app_policy_id, :cookie => 'my-app-cookie', :cookie_stickiness => :app)
289
- returns(app_policy_id) { elb.policies.first.id }
290
- returns("my-app-cookie") { elb.policies.get(app_policy_id).cookie }
291
- end
292
-
293
- tests('get policy') do
294
- returns(app_policy_id) { elb.policies.get(app_policy_id).id }
295
- end
296
-
297
- tests('destroy app policy') do
298
- elb.policies.first.destroy
299
- returns([]) { elb.policies.to_a }
300
- end
301
-
302
- lb_policy_id = 'my-lb-policy'
303
- tests('create lb policy') do
304
- elb.policies.create(:id => lb_policy_id, :expiration => 600, :cookie_stickiness => :lb)
305
- returns(lb_policy_id) { elb.policies.first.id }
306
- end
307
-
308
- tests('setting a listener policy') do
309
- elb.set_listener_policy(80, lb_policy_id)
310
- returns([lb_policy_id]) { elb.listeners.get(80).policy_names }
311
- returns(600) { elb.policies.get(lb_policy_id).expiration }
312
- end
313
-
314
- tests('unsetting a listener policy') do
315
- elb.unset_listener_policy(80)
316
- returns([]) { elb.listeners.get(80).policy_names }
317
- end
318
-
319
- public_key_policy_id = 'fog-public-key-policy'
320
- tests('create public key policy') do
321
- elb.policies.create(:id => public_key_policy_id, :type_name => 'PublicKeyPolicyType', :policy_attributes => {'PublicKey' => AWS::IAM::SERVER_CERT_PUBLIC_KEY})
322
- policy = elb.policies.get(public_key_policy_id)
323
-
324
- returns(public_key_policy_id) { policy.id }
325
- returns("PublicKeyPolicyType") { policy.type_name }
326
- returns(AWS::IAM::SERVER_CERT_PUBLIC_KEY) { policy.policy_attributes["PublicKey"] }
327
- end
328
-
329
- tests('a malformed policy') do
330
- raises(ArgumentError) { elb.policies.create(:id => 'foo', :cookie_stickiness => 'invalid stickiness') }
331
- end
332
- end
333
-
334
- tests('backend server descriptions') do
335
- tests('default') do
336
- returns(0) { elb.backend_server_descriptions.size }
337
- end
338
-
339
- tests('with a backend policy') do
340
- policy = "EnableProxyProtocol"
341
- port = 80
342
- elb.policies.create(:id => policy, :type_name => 'ProxyProtocolPolicyType', :policy_attributes => { "ProxyProtocol" => true })
343
- Fog::AWS[:elb].set_load_balancer_policies_for_backend_server(elb.id, port, [policy]).body
344
- elb.reload
345
- returns([policy]) { elb.backend_server_descriptions.get(port).policy_names }
346
- end
347
- end
348
-
349
- tests('setting a new ssl certificate id') do
350
- elb.listeners.create(:instance_port => 443, :lb_port => 443, :protocol => 'HTTPS', :instance_protocol => 'HTTPS', :ssl_id => @certificate['Arn'])
351
- elb.set_listener_ssl_certificate(443, @certificate['Arn'])
352
- end
353
-
354
- tests('destroy') do
355
- elb.destroy
356
- end
357
-
358
- Fog::AWS[:iam].delete_server_certificate(@key_name)
359
- end
360
- end
@@ -1,15 +0,0 @@
1
- Shindo.tests("AWS::ELB | tagging", ['aws', 'elb']) do
2
- @elb5 = Fog::AWS[:elb].load_balancers.create(:id => "fog-test-elb-tagging")
3
- tags1 = {'key1' => 'val1'}
4
- tags2 = {'key2' => 'val2'}
5
-
6
- tests "add and remove tags from an ELB" do
7
- returns({}) { @elb5.tags }
8
- returns(tags1) { @elb5.add_tags tags1 }
9
- returns(tags1.merge tags2) { @elb5.add_tags tags2 }
10
- returns(tags2) { @elb5.remove_tags tags1.keys }
11
- returns(tags2) { @elb5.tags }
12
-
13
- @elb5.destroy
14
- end
15
- end
@@ -1,47 +0,0 @@
1
- Shindo.tests('AWS::Glacier | models', ['aws', 'glacier']) do
2
- pending if Fog.mocking?
3
- tests('success') do
4
- tests('vaults') do
5
- tests('getting a missing vault') do
6
- returns(nil) { Fog::AWS[:glacier].vaults.get('no-such-vault') }
7
- end
8
-
9
- vault = nil
10
- tests('creating a vault') do
11
- vault = Fog::AWS[:glacier].vaults.create :id => 'Fog-Test-Vault'
12
- tests("id is Fog-Test-Vault").returns('Fog-Test-Vault') {vault.id}
13
- end
14
-
15
- tests('all') do
16
- tests('contains vault').returns(true) { Fog::AWS[:glacier].vaults.map {|vault| vault.id}.include?(vault.id)}
17
- end
18
-
19
- tests('destroy') do
20
- vault.destroy
21
- tests('removes vault').returns(nil) {Fog::AWS[:glacier].vaults.get(vault.id)}
22
- end
23
- end
24
-
25
- tests("archives") do
26
- vault = Fog::AWS[:glacier].vaults.create :id => 'Fog-Test-Vault-upload'
27
- tests('create') do
28
- archive = vault.archives.create(:body => 'data')
29
- tests('sets id').returns(true) {!archive.id.nil?}
30
- archive.destroy
31
- end
32
- tests('create multipart') do
33
- body = StringIO.new('x'*1024*1024*2)
34
- body.rewind
35
- archive = vault.archives.create(:body => body, :multipart_chunk_size => 1024*1024)
36
- tests('sets id').returns(true) {!archive.id.nil?}
37
- archive.destroy
38
- end
39
- end
40
-
41
- vault = Fog::AWS[:glacier].vaults.create :id => 'Fog-Test-Vault'
42
- tests("jobs") do
43
- tests('all').returns([]) {vault.jobs}
44
- end
45
- vault.destroy
46
- end
47
- end
@@ -1,53 +0,0 @@
1
- Shindo.tests("Fog::Compute[:iam] | access_keys", ['aws','iam']) do
2
-
3
- iam = Fog::AWS[:iam]
4
-
5
- @username = 'fake_user'
6
- @user = iam.users.create(:id => @username)
7
-
8
-
9
- tests('#all', 'there are no access keys for a new user').succeeds do
10
- @user.access_keys.empty?
11
- end
12
-
13
-
14
- tests('#create','an access key').succeeds do
15
- access_key = @user.access_keys.create
16
- access_key.id =~ /[A-Z0-9]{20}/
17
- access_key.secret_access_key =~ /[\S]{40}/
18
- access_key.status == "Active"
19
- access_key.username == @username
20
- @access_key_id = access_key.id
21
- end
22
-
23
- @user.access_keys.create
24
-
25
- tests('#all','there are two access keys').succeeds do
26
- @user.access_keys.size == 2
27
- end
28
-
29
- tests('#get') do
30
- tests('a valid access key id').succeeds do
31
- access_key = @user.access_keys.get(@access_key_id)
32
- access_key.id == @access_key_id
33
- access_key.secret_access_key == nil
34
- access_key.status == "Active"
35
- access_key.username == @username
36
- end
37
-
38
- tests('an invalid access key').succeeds do
39
- @user.access_keys.get('non-existing') == nil
40
- end
41
- end
42
-
43
- tests('#destroy', 'decrease by one the number of access keys').succeeds do
44
- size = @user.access_keys.size
45
- @user.access_keys.get(@access_key_id).destroy
46
- @user.access_keys.size == ( size - 1 )
47
- end
48
-
49
- # clean up
50
- @user.access_keys.map(&:destroy)
51
- @user.destroy
52
-
53
- end
@@ -1,59 +0,0 @@
1
- Shindo.tests("Fog::Compute[:iam] | groups", ['aws','iam']) do
2
-
3
- service = Fog::AWS[:iam]
4
- group_name = uniq_id('fog-test-group')
5
- policy_name = uniq_id('fog-test-policy')
6
- group = nil
7
- document = {"Statement" => [{"Effect" => "Allow", "Action" => "*", "Resource" => "*"}]}
8
-
9
- tests('#create').succeeds do
10
- group = service.groups.create(:name => group_name)
11
-
12
- group.name == group_name
13
- end
14
-
15
- tests('#all').succeeds do
16
- service.groups.all.map(&:name).include?(group_name)
17
- end
18
-
19
- tests('update').succeeds do
20
- new_path = group.path = "/newpath/"
21
- group.save
22
-
23
- group.reload.path == new_path
24
- end
25
-
26
- tests('group') do
27
- policy = nil
28
-
29
- tests('#policies', '#create') do
30
- policy = group.policies.create(:id => policy_name, :document => document)
31
- end
32
-
33
- tests('#policies', '#get').succeeds do
34
- group.policies.get(policy_name) != nil
35
- end
36
-
37
- tests('#policies', '#all').succeeds do
38
- group.policies.all.map(&:id).include?(policy.id)
39
- end
40
-
41
- tests('#users', 'when none').succeeds do
42
- group.users.empty?
43
- end
44
-
45
- user = nil
46
-
47
- tests('#add_user').succeeds do
48
- user = service.users.create(:id => 'fog-test')
49
-
50
- group.add_user(user)
51
-
52
- group.users.include?(user)
53
- end
54
-
55
- tests('#users').succeeds do
56
- group.reload.users.map(&:identity).include?(user.identity)
57
- end
58
- end
59
- end
@@ -1,18 +0,0 @@
1
- Shindo.tests("Fog::AWS[:iam] | instance_profiles", ['aws', 'iam']) do
2
- model_tests(Fog::AWS[:iam].instance_profiles, {:name => uniq_id('fog-instance-profile')}) do
3
- @role = Fog::AWS[:iam].roles.create(:rolename => uniq_id('fog-role'))
4
-
5
- tests("#add_role('#{@role.rolename}')") do
6
- returns(true) { @instance.add_role(@role.rolename) }
7
- end
8
-
9
- returns(1) { @role.instance_profiles.count }
10
- returns(@instance) { @role.instance_profiles.first }
11
-
12
- tests("#remove_role('#{@role.rolename}')") do
13
- returns(true) { @instance.remove_role(@role.rolename) }
14
- end
15
-
16
- @role.destroy
17
- end
18
- end
@@ -1,89 +0,0 @@
1
- Shindo.tests("Fog::Compute[:iam] | managed_policies", ['aws','iam']) do
2
-
3
- iam = Fog::AWS[:iam]
4
-
5
- tests('#all').succeeds do
6
- iam.managed_policies.size == 100
7
- end
8
-
9
- tests('#each').succeeds do
10
- policies = []
11
-
12
- iam.managed_policies.each { |policy| policies << policy }
13
-
14
- policies.size > 100
15
- end
16
-
17
- policy = iam.managed_policies.get("arn:aws:iam::aws:policy/IAMReadOnlyAccess")
18
-
19
- tests("#document").succeeds do
20
- policy.document == {
21
- "Version" => "2012-10-17",
22
- "Statement" => [
23
- {
24
- "Effect" => "Allow",
25
- "Action" => [ "iam:GenerateCredentialReport", "iam:GenerateServiceLastAccessedDetails", "iam:Get*", "iam:List*" ],
26
- "Resource" => "*"
27
- }
28
- ]
29
- }
30
- end
31
-
32
- tests("users") do
33
- user = iam.users.create(:id => uniq_id("fog-test-user"))
34
-
35
- tests("#attach").succeeds do
36
- user.attach(policy)
37
-
38
- user.attached_policies.map(&:identity) == [policy.identity]
39
- end
40
-
41
- returns(1) { policy.reload.attachments}
42
-
43
- tests("#detach").succeeds do
44
- user.detach(policy)
45
-
46
- user.attached_policies.map(&:identity) == []
47
- end
48
-
49
- user.destroy
50
- end
51
-
52
- tests("groups") do
53
- group = iam.groups.create(:name => uniq_id("fog-test-group"))
54
-
55
- tests("#attach").succeeds do
56
- group.attach(policy)
57
-
58
- group.attached_policies.map(&:identity) == [policy.identity]
59
- end
60
-
61
- returns(1) { policy.reload.attachments}
62
-
63
- tests("#detach").succeeds do
64
- group.detach(policy)
65
-
66
- group.attached_policies.map(&:identity) == []
67
- end
68
-
69
- group.destroy
70
- end
71
-
72
- tests("roles") do
73
- role = iam.roles.create(:rolename => uniq_id("fog-test-role"))
74
-
75
- tests("#attach").succeeds do
76
- role.attach(policy)
77
- role.attached_policies.map(&:identity) == [policy.identity]
78
- end
79
-
80
- returns(1) { policy.reload.attachments}
81
-
82
- tests("#detach").succeeds do
83
- role.detach(policy)
84
- role.attached_policies.map(&:identity) == []
85
- end
86
-
87
- role.destroy
88
- end
89
- end