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,262 +0,0 @@
1
- # encoding: utf-8
2
-
3
- Shindo.tests('AWS::Storage | object requests', ['aws']) do
4
- @directory = Fog::Storage[:aws].directories.create(:key => 'fogobjecttests-' + Time.now.to_i.to_s(32))
5
- @aws_owner = Fog::Storage[:aws].get_bucket_acl(@directory.key).body['Owner']
6
-
7
- tests('success') do
8
-
9
- @multiple_delete_format = {
10
- 'DeleteResult' => [{
11
- 'Deleted' => {
12
- 'Key' => String
13
- }
14
- }]
15
- }
16
-
17
- tests("#put_object('#{@directory.identity}', 'fog_object', lorem_file)").succeeds do
18
- Fog::Storage[:aws].put_object(@directory.identity, 'fog_object', lorem_file)
19
- end
20
-
21
- tests("#copy_object('#{@directory.identity}', 'fog_object', '#{@directory.identity}', 'fog_other_object')").succeeds do
22
- Fog::Storage[:aws].copy_object(@directory.identity, 'fog_object', @directory.identity, 'fog_other_object')
23
- end
24
-
25
- @directory.files.get('fog_other_object').destroy
26
-
27
- tests("#get_object('#{@directory.identity}', 'fog_object')").returns(lorem_file.read) do
28
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object').body
29
- end
30
-
31
- tests("#get_object('#{@directory.identity}', 'fog_object', &block)").returns(lorem_file.read) do
32
- data = ''
33
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object') do |chunk, remaining_bytes, total_bytes|
34
- data << chunk
35
- end
36
- data
37
- end
38
-
39
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file) })").returns(lorem_file.read) do
40
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) }).body
41
- end
42
-
43
- tests("#get_object('#{@directory.identity}', 'fog_object', {'Range' => 'bytes=0-20'})").returns(lorem_file.read[0..20]) do
44
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', {'Range' => 'bytes=0-20'}).body
45
- end
46
-
47
- tests("#get_object('#{@directory.identity}', 'fog_object', {'Range' => 'bytes=0-0'})").returns(lorem_file.read[0..0]) do
48
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', {'Range' => 'bytes=0-0'}).body
49
- end
50
-
51
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) })").returns(lorem_file.read) do
52
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) }).body
53
- end
54
-
55
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Modified-Since' => Time.now - 60 })").returns(lorem_file.read) do
56
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Modified-Since' => Time.now - 60 }).body
57
- end
58
-
59
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-None-Match' => 'invalid_etag' })").returns(lorem_file.read) do
60
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-None-Match' => 'invalid_etag' }).body
61
- end
62
-
63
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Unmodified-Since' => Time.now + 60 })").returns(lorem_file.read) do
64
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Unmodified-Since' => Time.now + 60 }).body
65
- end
66
-
67
- tests("#head_object('#{@directory.identity}', 'fog_object')").succeeds do
68
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object')
69
- end
70
-
71
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) })").succeeds do
72
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) })
73
- end
74
-
75
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Modified-Since' => Time.now - 60 })").succeeds do
76
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Modified-Since' => Time.now - 60 })
77
- end
78
-
79
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-None-Match' => 'invalid_etag' })").succeeds do
80
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-None-Match' => 'invalid_etag' })
81
- end
82
-
83
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Unmodified-Since' => Time.now + 60 })").succeeds do
84
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Unmodified-Since' => Time.now + 60 })
85
- end
86
-
87
- tests("#post_object_restore('#{@directory.identity}', 'fog_object')").succeeds do
88
- pending unless Fog.mocking?
89
- Fog::Storage[:aws].post_object_restore(@directory.identity, 'fog_object')
90
- end
91
-
92
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', 'private')").succeeds do
93
- Fog::Storage[:aws].put_object_acl(@directory.identity, 'fog_object', 'private')
94
- end
95
-
96
- acl = {
97
- 'Owner' => @aws_owner,
98
- 'AccessControlList' => [
99
- {
100
- 'Grantee' => @aws_owner,
101
- 'Permission' => "FULL_CONTROL"
102
- }
103
- ]}
104
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', hash with id)").returns(acl) do
105
- Fog::Storage[:aws].put_object_acl(@directory.identity, 'fog_object', acl)
106
- Fog::Storage[:aws].get_object_acl(@directory.identity, 'fog_object').body
107
- end
108
-
109
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', hash with email)").returns({
110
- 'Owner' => @aws_owner,
111
- 'AccessControlList' => [
112
- {
113
- 'Grantee' => { 'ID' => 'f62f0218873cfa5d56ae9429ae75a592fec4fd22a5f24a20b1038a7db9a8f150', 'DisplayName' => 'mtd' },
114
- 'Permission' => "FULL_CONTROL"
115
- }
116
- ]}) do
117
- pending if Fog.mocking?
118
- Fog::Storage[:aws].put_object_acl(@directory.identity, 'fog_object', {
119
- 'Owner' => @aws_owner,
120
- 'AccessControlList' => [
121
- {
122
- 'Grantee' => { 'EmailAddress' => 'mtd@amazon.com' },
123
- 'Permission' => "FULL_CONTROL"
124
- }
125
- ]})
126
- Fog::Storage[:aws].get_object_acl(@directory.identity, 'fog_object').body
127
- end
128
-
129
- acl = {
130
- 'Owner' => @aws_owner,
131
- 'AccessControlList' => [
132
- {
133
- 'Grantee' => { 'URI' => 'http://acs.amazonaws.com/groups/global/AllUsers' },
134
- 'Permission' => "FULL_CONTROL"
135
- }
136
- ]}
137
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', hash with uri)").returns(acl) do
138
- Fog::Storage[:aws].put_object_acl(@directory.identity, 'fog_object', acl)
139
- Fog::Storage[:aws].get_object_acl(@directory.identity, 'fog_object').body
140
- end
141
-
142
- tests("#delete_object('#{@directory.identity}', 'fog_object')").succeeds do
143
- Fog::Storage[:aws].delete_object(@directory.identity, 'fog_object')
144
- end
145
-
146
- tests("#get_object_http_url('#{@directory.identity}', 'fog_object', expiration timestamp)").returns(true) do
147
- object_url = Fog::Storage[:aws].get_object_http_url(@directory.identity, 'fog_object', (Time.now + 60))
148
- (object_url =~ /http:\/\/#{Regexp.quote(@directory.identity)}\.s3\.amazonaws\.com\/fog_object/) != nil
149
- end
150
-
151
- tests("#head_object_url('#{@directory.identity}', 'fog_object', expiration timestamp)").returns(true) do
152
- object_url = Fog::Storage[:aws].head_object_url(@directory.identity, 'fog_object', (Time.now + 60))
153
- (object_url =~ /https:\/\/#{Regexp.quote(@directory.identity)}\.s3\.amazonaws\.com\/fog_object/) != nil
154
- end
155
-
156
- tests("delete_multiple_objects('#{@directory.identity}', ['fog_object', 'fog_other_object'])").formats(@multiple_delete_format) do
157
- Fog::Storage[:aws].delete_multiple_objects(@directory.identity, ['fog_object', 'fog_other_object']).body
158
- end
159
-
160
- tests("#delete_multiple_objects('#{@directory.identity}', 'fØg_öbjèct', UTF-8)").succeeds do
161
- Fog::Storage[:aws].delete_multiple_objects(@directory.identity, ['fØg_öbjèct'])
162
- end
163
-
164
- end
165
-
166
- fognonbucket = uniq_id('fognonbucket')
167
-
168
- tests('failure') do
169
-
170
- tests("#put_object('#{fognonbucket}', 'fog_non_object', lorem_file)").raises(Excon::Errors::NotFound) do
171
- Fog::Storage[:aws].put_object(fognonbucket, 'fog_non_object', lorem_file)
172
- end
173
-
174
- tests("#put_object('#{@directory.identity}', 'fog_object', lorem_file, {'x-amz-meta-json' => 'ä'}").raises(Excon::Errors::BadRequest) do
175
- Fog::Storage[:aws].put_object(@directory.identity, 'fog_object', lorem_file, {'x-amz-meta-json' => 'ä'})
176
- end
177
-
178
- tests("#copy_object('#{fognonbucket}', 'fog_object', '#{@directory.identity}', 'fog_other_object')").raises(Excon::Errors::NotFound) do
179
- Fog::Storage[:aws].copy_object(fognonbucket, 'fog_object', @directory.identity, 'fog_other_object')
180
- end
181
-
182
- tests("#copy_object('#{@directory.identity}', 'fog_non_object', '#{@directory.identity}', 'fog_other_object')").raises(Excon::Errors::NotFound) do
183
- Fog::Storage[:aws].copy_object(@directory.identity, 'fog_non_object', @directory.identity, 'fog_other_object')
184
- end
185
-
186
- tests("#copy_object('#{@directory.identity}', 'fog_object', 'fognonbucket', 'fog_other_object')").raises(Excon::Errors::NotFound) do
187
- Fog::Storage[:aws].copy_object(@directory.identity, 'fog_object', fognonbucket, 'fog_other_object')
188
- end
189
-
190
- tests("#get_object('#{fognonbucket}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
191
- Fog::Storage[:aws].get_object(fognonbucket, 'fog_non_object')
192
- end
193
-
194
- tests("#get_object('#{@directory.identity}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
195
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_non_object')
196
- end
197
-
198
- Fog::Storage[:aws].put_object(@directory.identity, 'fog_object', lorem_file)
199
-
200
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Match' => 'invalid_etag' })").raises(Excon::Errors::PreconditionFailed) do
201
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Match' => 'invalid_etag' })
202
- end
203
-
204
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Modified-Since' => Time.now })").raises(Excon::Errors::NotModified) do
205
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Modified-Since' => Time.now })
206
- end
207
-
208
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-None-Match' => Digest::MD5.hexdigest(lorem_file.read) })").raises(Excon::Errors::NotModified) do
209
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-None-Match' => Digest::MD5.hexdigest(lorem_file.read) })
210
- end
211
-
212
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Unmodified-Since' => Time.now - 60 })").raises(Excon::Errors::PreconditionFailed) do
213
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Unmodified-Since' => Time.now - 60 })
214
- end
215
-
216
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Match' => 'invalid_etag' })").raises(Excon::Errors::PreconditionFailed) do
217
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Match' => 'invalid_etag' })
218
- end
219
-
220
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Modified-Since' => Time.now })").raises(Excon::Errors::NotModified) do
221
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Modified-Since' => Time.now })
222
- end
223
-
224
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-None-Match' => Digest::MD5.hexdigest(lorem_file.read) })").raises(Excon::Errors::NotModified) do
225
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-None-Match' => Digest::MD5.hexdigest(lorem_file.read) })
226
- end
227
-
228
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Unmodified-Since' => Time.now - 60 })").raises(Excon::Errors::PreconditionFailed) do
229
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Unmodified-Since' => Time.now - 60 })
230
- end
231
-
232
- Fog::Storage[:aws].delete_object(@directory.identity, 'fog_object')
233
-
234
- tests("#head_object(fognonbucket, 'fog_non_object')").raises(Excon::Errors::NotFound) do
235
- Fog::Storage[:aws].head_object(fognonbucket, 'fog_non_object')
236
- end
237
-
238
- tests("#head_object('#{@directory.identity}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
239
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_non_object')
240
- end
241
-
242
- tests("#delete_object('#{fognonbucket}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
243
- Fog::Storage[:aws].delete_object(fognonbucket, 'fog_non_object')
244
- end
245
-
246
- tests("#delete_multiple_objects('#{fognonbucket}', ['fog_non_object'])").raises(Excon::Errors::NotFound) do
247
- pending if Fog.mocking?
248
- Fog::Storage[:aws].delete_multiple_objects(fognonbucket, ['fog_non_object'])
249
- end
250
-
251
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', 'invalid')").raises(Excon::Errors::BadRequest) do
252
- Fog::Storage[:aws].put_object_acl('#{@directory.identity}', 'fog_object', 'invalid')
253
- end
254
-
255
- tests("#post_object_restore('#{@directory.identity}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
256
- Fog::Storage[:aws].post_object_restore(@directory.identity, 'fog_non_object')
257
- end
258
- end
259
-
260
- @directory.destroy
261
-
262
- end
@@ -1,262 +0,0 @@
1
- def clear_bucket
2
- Fog::Storage[:aws].get_bucket_object_versions(@aws_bucket_name).body['Versions'].each do |version|
3
- object = version[version.keys.first]
4
- Fog::Storage[:aws].delete_object(@aws_bucket_name, object['Key'], 'versionId' => object['VersionId'])
5
- end
6
- end
7
-
8
- def create_versioned_bucket
9
- @aws_bucket_name = 'fogbuckettests-' + Fog::Mock.random_hex(16)
10
- Fog::Storage[:aws].put_bucket(@aws_bucket_name)
11
- Fog::Storage[:aws].put_bucket_versioning(@aws_bucket_name, 'Enabled')
12
- end
13
-
14
- def delete_bucket
15
- Fog::Storage[:aws].get_bucket_object_versions(@aws_bucket_name).body['Versions'].each do |version|
16
- object = version[version.keys.first]
17
- Fog::Storage[:aws].delete_object(@aws_bucket_name, object['Key'], 'versionId' => object['VersionId'])
18
- end
19
-
20
- Fog::Storage[:aws].delete_bucket(@aws_bucket_name)
21
- end
22
-
23
- Shindo.tests('Fog::Storage[:aws] | versioning', ["aws"]) do
24
- tests('success') do
25
- tests("#put_bucket_versioning") do
26
- @aws_bucket_name = 'fogbuckettests-' + Fog::Mock.random_hex(16)
27
- Fog::Storage[:aws].put_bucket(@aws_bucket_name)
28
-
29
- tests("#put_bucket_versioning('#{@aws_bucket_name}', 'Enabled')").succeeds do
30
- Fog::Storage[:aws].put_bucket_versioning(@aws_bucket_name, 'Enabled')
31
- end
32
-
33
- tests("#put_bucket_versioning('#{@aws_bucket_name}', 'Suspended')").succeeds do
34
- Fog::Storage[:aws].put_bucket_versioning(@aws_bucket_name, 'Suspended')
35
- end
36
-
37
- delete_bucket
38
- end
39
-
40
- tests("#get_bucket_versioning('#{@aws_bucket_name}')") do
41
- @aws_bucket_name = 'fogbuckettests-' + Fog::Mock.random_hex(16)
42
- Fog::Storage[:aws].put_bucket(@aws_bucket_name)
43
-
44
- tests("#get_bucket_versioning('#{@aws_bucket_name}') without versioning").returns({}) do
45
- Fog::Storage[:aws].get_bucket_versioning(@aws_bucket_name).body['VersioningConfiguration']
46
- end
47
-
48
- tests("#get_bucket_versioning('#{@aws_bucket_name}') with versioning enabled").returns('Enabled') do
49
- Fog::Storage[:aws].put_bucket_versioning(@aws_bucket_name, 'Enabled')
50
- Fog::Storage[:aws].get_bucket_versioning(@aws_bucket_name).body['VersioningConfiguration']['Status']
51
- end
52
-
53
- tests("#get_bucket_versioning('#{@aws_bucket_name}') with versioning suspended").returns('Suspended') do
54
- Fog::Storage[:aws].put_bucket_versioning(@aws_bucket_name, 'Suspended')
55
- Fog::Storage[:aws].get_bucket_versioning(@aws_bucket_name).body['VersioningConfiguration']['Status']
56
- end
57
-
58
- delete_bucket
59
- end
60
-
61
- tests("#get_bucket_object_versions('#{@aws_bucket_name}')") do
62
-
63
- create_versioned_bucket
64
-
65
- before do
66
- @versions = Fog::Storage[:aws].get_bucket_object_versions(@aws_bucket_name)
67
- end
68
-
69
- v1 = Fog::Storage[:aws].directories.get(@aws_bucket_name).files.create(:body => 'a', :key => 'file')
70
- v2 = Fog::Storage[:aws].directories.get(@aws_bucket_name).files.create(:body => 'ab', :key => v1.key)
71
- v3 = Fog::Storage[:aws].directories.get(@aws_bucket_name).files.create(:body => 'abc', :key => v1.key)
72
- v4 = Fog::Storage[:aws].directories.get(@aws_bucket_name).files.create(:body => 'abcd', :key => v1.key)
73
-
74
- tests("versions").returns([v4.version, v3.version, v2.version, v1.version]) do
75
- @versions.body['Versions'].map {|v| v['Version']['VersionId']}
76
- end
77
-
78
- tests("version sizes").returns([4, 3, 2, 1]) do
79
- @versions.body['Versions'].map {|v| v['Version']['Size']}
80
- end
81
-
82
- tests("latest version").returns(v4.version) do
83
- latest = @versions.body['Versions'].find {|v| v['Version']['IsLatest']}
84
- latest['Version']['VersionId']
85
- end
86
- end
87
-
88
- tests("get_object('#{@aws_bucket_name}', 'file')") do
89
- clear_bucket
90
-
91
- v1 = Fog::Storage[:aws].directories.get(@aws_bucket_name).files.create(:body => 'a', :key => 'file')
92
- v2 = Fog::Storage[:aws].directories.get(@aws_bucket_name).files.create(:body => 'ab', :key => v1.key)
93
-
94
- tests("get_object('#{@aws_bucket_name}', '#{v2.key}') returns the latest version").returns(v2.version) do
95
- res = Fog::Storage[:aws].get_object(@aws_bucket_name, v2.key)
96
- res.headers['x-amz-version-id']
97
- end
98
-
99
- tests("get_object('#{@aws_bucket_name}', '#{v1.key}', 'versionId' => '#{v1.version}') returns the specified version").returns(v1.version) do
100
- res = Fog::Storage[:aws].get_object(@aws_bucket_name, v1.key, 'versionId' => v1.version)
101
- res.headers['x-amz-version-id']
102
- end
103
-
104
- v2.destroy
105
-
106
- tests("get_object('#{@aws_bucket_name}', '#{v2.key}') raises exception if delete marker is latest version").raises(Excon::Errors::NotFound) do
107
- Fog::Storage[:aws].get_object(@aws_bucket_name, v2.key)
108
- end
109
- end
110
-
111
- tests("delete_object('#{@aws_bucket_name}', 'file')") do
112
- clear_bucket
113
-
114
- file = Fog::Storage[:aws].directories.get(@aws_bucket_name).files.create(:body => 'a', :key => 'file')
115
-
116
- tests("deleting an object just stores a delete marker").returns(true) do
117
- file.destroy
118
- versions = Fog::Storage[:aws].get_bucket_object_versions(@aws_bucket_name)
119
- versions.body['Versions'].first.key?('DeleteMarker')
120
- end
121
-
122
- tests("there are two versions: the original and the delete marker").returns(2) do
123
- versions = Fog::Storage[:aws].get_bucket_object_versions(@aws_bucket_name)
124
- versions.body['Versions'].size
125
- end
126
-
127
- tests("deleting the delete marker makes the object available again").returns(file.version) do
128
- versions = Fog::Storage[:aws].get_bucket_object_versions(@aws_bucket_name)
129
- delete_marker = versions.body['Versions'].find { |v| v.key?('DeleteMarker') }
130
- Fog::Storage[:aws].delete_object(@aws_bucket_name, file.key, 'versionId' => delete_marker['DeleteMarker']['VersionId'])
131
-
132
- res = Fog::Storage[:aws].get_object(@aws_bucket_name, file.key)
133
- res.headers['x-amz-version-id']
134
- end
135
- end
136
-
137
- tests("deleting_multiple_objects('#{@aws_bucket_name}", 'file') do
138
- clear_bucket
139
-
140
- bucket = Fog::Storage[:aws].directories.get(@aws_bucket_name)
141
-
142
- file_count = 5
143
- file_names = []
144
- files = {}
145
- file_count.times do |id|
146
- file_names << "file_#{id}"
147
- files[file_names.last] = bucket.files.create(:body => 'a',
148
- :key => file_names.last)
149
- end
150
-
151
- tests("deleting an object just stores a delete marker").returns(true) do
152
- Fog::Storage[:aws].delete_multiple_objects(@aws_bucket_name,
153
- file_names)
154
- versions = Fog::Storage[:aws].get_bucket_object_versions(
155
- @aws_bucket_name)
156
- all_versions = {}
157
- versions.body['Versions'].each do |version|
158
- object = version[version.keys.first]
159
- next if file_names.index(object['Key']).nil?
160
- if !all_versions.key?(object['Key'])
161
- all_versions[object['Key']] = version.key?('DeleteMarker')
162
- else
163
- all_versions[object['Key']] |= version.key?('DeleteMarker')
164
- end
165
- end
166
- all_true = true
167
- all_versions.values.each do |marker|
168
- all_true = false if !marker
169
- end
170
- all_true
171
- end
172
-
173
- tests("there are two versions: the original and the delete marker").
174
- returns(file_count*2) do
175
- versions = Fog::Storage[:aws].get_bucket_object_versions(
176
- @aws_bucket_name)
177
- versions.body['Versions'].size
178
- end
179
-
180
- tests("deleting the delete marker makes the object available again").
181
- returns(true) do
182
- versions = Fog::Storage[:aws].get_bucket_object_versions(
183
- @aws_bucket_name)
184
- delete_markers = []
185
- file_versions = {}
186
- versions.body['Versions'].each do |version|
187
- object = version[version.keys.first]
188
- next if object['VersionId'] == files[object['Key']].version
189
- file_versions[object['Key']] = object['VersionId']
190
- end
191
-
192
- Fog::Storage[:aws].delete_multiple_objects(@aws_bucket_name,
193
- file_names,
194
- 'versionId' => file_versions)
195
- all_true = true
196
- file_names.each do |file|
197
- res = Fog::Storage[:aws].get_object(@aws_bucket_name, file)
198
- all_true = false if res.headers['x-amz-version-id'] !=
199
- files[file].version
200
- end
201
- all_true
202
- end
203
-
204
- end
205
-
206
- tests("get_bucket('#{@aws_bucket_name}'") do
207
- clear_bucket
208
-
209
- file = Fog::Storage[:aws].directories.get(@aws_bucket_name).files.create(:body => 'a', :key => 'file')
210
-
211
- tests("includes a non-DeleteMarker object").returns(1) do
212
- Fog::Storage[:aws].get_bucket(@aws_bucket_name).body['Contents'].size
213
- end
214
-
215
- file.destroy
216
-
217
- tests("does not include a DeleteMarker object").returns(0) do
218
- Fog::Storage[:aws].get_bucket(@aws_bucket_name).body['Contents'].size
219
- end
220
- end
221
-
222
- delete_bucket
223
- end
224
-
225
- tests('failure') do
226
- create_versioned_bucket
227
-
228
- tests("#put_bucket_versioning('#{@aws_bucket_name}', 'bad_value')").raises(Excon::Errors::BadRequest) do
229
- Fog::Storage[:aws].put_bucket_versioning(@aws_bucket_name, 'bad_value')
230
- end
231
-
232
- tests("#get_bucket_object_versions('#{@aws_bucket_name}', { 'version-id-marker' => 'foo' })").raises(Excon::Errors::BadRequest) do
233
- Fog::Storage[:aws].get_bucket_object_versions(@aws_bucket_name, { 'version-id-marker' => 'foo' })
234
- end
235
-
236
- tests("#put_bucket_versioning('fognonbucket', 'Enabled')").raises(Excon::Errors::NotFound) do
237
- Fog::Storage[:aws].put_bucket_versioning('fognonbucket', 'Enabled')
238
- end
239
-
240
- tests("#get_bucket_versioning('fognonbucket')").raises(Excon::Errors::NotFound) do
241
- Fog::Storage[:aws].get_bucket_versioning('fognonbucket')
242
- end
243
-
244
- tests("#get_bucket_object_versions('fognonbucket')").raises(Excon::Errors::NotFound) do
245
- Fog::Storage[:aws].get_bucket_object_versions('fognonbucket')
246
- end
247
-
248
- file = Fog::Storage[:aws].directories.get(@aws_bucket_name).files.create(:body => 'y', :key => 'x')
249
-
250
- tests("#get_object('#{@aws_bucket_name}', '#{file.key}', 'versionId' => 'bad_version'").raises(Excon::Errors::BadRequest) do
251
- Fog::Storage[:aws].get_object(@aws_bucket_name, file.key, 'versionId' => '-1')
252
- end
253
-
254
- tests("#delete_object('#{@aws_bucket_name}', '#{file.key}', 'versionId' => 'bad_version'").raises(Excon::Errors::BadRequest) do
255
- Fog::Storage[:aws].delete_object(@aws_bucket_name, file.key, 'versionId' => '-1')
256
- end
257
-
258
- end
259
-
260
- # don't keep the bucket around
261
- delete_bucket
262
- end
@@ -1,19 +0,0 @@
1
- Shindo.tests('AWS::STS | assume role', ['aws']) do
2
-
3
- @policy = {"Statement" => [{"Effect" => "Allow", "Action" => "*", "Resource" => "*"}]}
4
-
5
- @response_format = {
6
- 'SessionToken' => String,
7
- 'SecretAccessKey' => String,
8
- 'Expiration' => String,
9
- 'AccessKeyId' => String,
10
- 'Arn' => String,
11
- 'RequestId' => String
12
- }
13
-
14
- tests("#assume_role('rolename', 'assumed_role_session', 'external_id', #{@policy.inspect}, 900)").formats(@response_format) do
15
- pending if Fog.mocking?
16
- Fog::AWS[:sts].assume_role("rolename","assumed_role_session","external_id", @policy, 900).body
17
- end
18
-
19
- end
@@ -1,18 +0,0 @@
1
- Shindo.tests('AWS::STS | assume role with SAML', ['aws']) do
2
-
3
- @policy = {"Statement" => [{"Effect" => "Allow", "Action" => "*", "Resource" => "*"}]}
4
-
5
- @response_format = {
6
- 'SessionToken' => String,
7
- 'SecretAccessKey' => String,
8
- 'Expiration' => String,
9
- 'AccessKeyId' => String,
10
- 'Arn' => String,
11
- 'RequestId' => String
12
- }
13
-
14
- tests("#assume_role_with_saml('role_arn', 'principal_arn', 'saml_assertion', #{@policy.inspect}, 900)").formats(@response_format) do
15
- pending if Fog.mocking?
16
- Fog::AWS[:sts].assume_role_with_saml("role_arn","principal_arn","saml_assertion", @policy, 900).body
17
- end
18
- end
@@ -1,28 +0,0 @@
1
- Shindo.tests('AWS::STS | assume role with web identity', ['aws']) do
2
- @sts = Fog::AWS[:sts]
3
- @iam = Fog::AWS[:iam]
4
- @role = @iam.create_role('sts', Fog::AWS::IAM::EC2_ASSUME_ROLE_POLICY).body['Role']
5
- @token = Fog::AWS::Mock.key_id
6
-
7
- @response_format = {
8
- 'AssumedRoleUser' => {
9
- 'Arn' => String,
10
- 'AssumedRoleId' => String,
11
- },
12
- 'Audience' => String,
13
- 'Credentials' => {
14
- 'AccessKeyId' => String,
15
- 'Expiration' => Time,
16
- 'SecretAccessKey' => String,
17
- 'SessionToken' => String,
18
- },
19
- 'Provider' => String,
20
- 'SubjectFromWebIdentityToken' => String,
21
- }
22
-
23
- tests("#assume_role_with_web_identity('#{@role['Arn']}', '#{@token}', 'fog')").formats(@response_format) do
24
- @sts.assume_role_with_web_identity(@role['Arn'], @token, 'fog', :iam => @iam).body
25
- end
26
-
27
- @iam.roles.get('sts').destroy
28
- end
@@ -1,20 +0,0 @@
1
- Shindo.tests('AWS::STS | session tokens', ['aws']) do
2
-
3
- @policy = {"Statement" => [{"Effect" => "Allow", "Action" => "*", "Resource" => "*"}]}
4
-
5
- @federation_format = {
6
- 'SessionToken' => String,
7
- 'SecretAccessKey' => String,
8
- 'Expiration' => String,
9
- 'AccessKeyId' => String,
10
- 'Arn' => String,
11
- 'FederatedUserId' => String,
12
- 'PackedPolicySize' => String,
13
- 'RequestId' => String
14
- }
15
-
16
- tests("#get_federation_token('test@fog.io', #{@policy.inspect})").formats(@federation_format) do
17
- Fog::AWS[:sts].get_federation_token("test@fog.io", @policy).body
18
- end
19
-
20
- end
@@ -1,16 +0,0 @@
1
- Shindo.tests('AWS::STS | session tokens', ['aws']) do
2
-
3
- @session_format = {
4
- 'SessionToken' => String,
5
- 'SecretAccessKey' => String,
6
- 'Expiration' => String,
7
- 'AccessKeyId' => String,
8
- 'RequestId' => String
9
- }
10
-
11
- tests("#get_session_token").formats(@session_format) do
12
- pending if Fog.mocking?
13
- Fog::AWS[:sts].get_session_token.body
14
- end
15
-
16
- end