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,121 +0,0 @@
1
- Shindo.tests('Fog::Storage[:aws] | multipart upload requests', ["aws"]) do
2
-
3
- @directory = Fog::Storage[:aws].directories.create(:key => uniq_id('fogmultipartuploadtests'))
4
-
5
- tests('success') do
6
-
7
- @initiate_multipart_upload_format = {
8
- 'Bucket' => String,
9
- 'Key' => String,
10
- 'UploadId' => String
11
- }
12
-
13
- tests("#initiate_multipart_upload('#{@directory.identity}')", 'fog_multipart_upload').formats(@initiate_multipart_upload_format) do
14
- data = Fog::Storage[:aws].initiate_multipart_upload(@directory.identity, 'fog_multipart_upload').body
15
- @upload_id = data['UploadId']
16
- data
17
- end
18
-
19
- @list_multipart_uploads_format = {
20
- 'Bucket' => String,
21
- 'IsTruncated' => Fog::Boolean,
22
- 'MaxUploads' => Integer,
23
- 'KeyMarker' => NilClass,
24
- 'NextKeyMarker' => String,
25
- 'NextUploadIdMarker' => Fog::Nullable::String,
26
- 'Upload' => [{
27
- 'Initiated' => Time,
28
- 'Initiator' => {
29
- 'DisplayName' => String,
30
- 'ID' => String
31
- },
32
- 'Key' => String,
33
- 'Owner' => {
34
- 'DisplayName' => String,
35
- 'ID' => String
36
- },
37
- 'StorageClass' => String,
38
- 'UploadId' => String
39
- }],
40
- 'UploadIdMarker' => NilClass,
41
- }
42
-
43
- tests("#list_multipart_uploads('#{@directory.identity})").formats(@list_multipart_uploads_format) do
44
- pending if Fog.mocking?
45
- Fog::Storage[:aws].list_multipart_uploads(@directory.identity).body
46
- end
47
-
48
- @parts = []
49
-
50
- tests("#upload_part('#{@directory.identity}', 'fog_multipart_upload', '#{@upload_id}', 1, ('x' * 6 * 1024 * 1024))").succeeds do
51
- data = Fog::Storage[:aws].upload_part(@directory.identity, 'fog_multipart_upload', @upload_id, 1, ('x' * 6 * 1024 * 1024))
52
- @parts << data.headers['ETag']
53
- end
54
-
55
- @list_parts_format = {
56
- 'Bucket' => String,
57
- 'Initiator' => {
58
- 'DisplayName' => String,
59
- 'ID' => String
60
- },
61
- 'IsTruncated' => Fog::Boolean,
62
- 'Key' => String,
63
- 'MaxParts' => Integer,
64
- 'NextPartNumberMarker' => String,
65
- 'Part' => [{
66
- 'ETag' => String,
67
- 'LastModified' => Time,
68
- 'PartNumber' => Integer,
69
- 'Size' => Integer
70
- }],
71
- 'PartNumberMarker' => String,
72
- 'StorageClass' => String,
73
- 'UploadId' => String
74
- }
75
-
76
- tests("#list_parts('#{@directory.identity}', 'fog_multipart_upload', '#{@upload_id}')").formats(@list_parts_format) do
77
- pending if Fog.mocking?
78
- Fog::Storage[:aws].list_parts(@directory.identity, 'fog_multipart_upload', @upload_id).body
79
- end
80
-
81
- @parts << Fog::Storage[:aws].upload_part(@directory.identity, 'fog_multipart_upload', @upload_id, 2, ('x' * 4 * 1024 * 1024)).headers['ETag']
82
-
83
- @complete_multipart_upload_format = {
84
- 'Bucket' => String,
85
- 'ETag' => String,
86
- 'Key' => String,
87
- 'Location' => String
88
- }
89
-
90
- tests("#complete_multipart_upload('#{@directory.identity}', 'fog_multipart_upload', '#{@upload_id}', #{@parts.inspect})").formats(@complete_multipart_upload_format) do
91
- Fog::Storage[:aws].complete_multipart_upload(@directory.identity, 'fog_multipart_upload', @upload_id, @parts).body
92
- end
93
-
94
- tests("#get_object('#{@directory.identity}', 'fog_multipart_upload').body").succeeds do
95
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_multipart_upload').body == ('x' * 10 * 1024 * 1024)
96
- end
97
-
98
- @directory.files.new(:key => 'fog_multipart_upload').destroy
99
-
100
- @upload_id = Fog::Storage[:aws].initiate_multipart_upload(@directory.identity, 'fog_multipart_abort').body['UploadId']
101
-
102
- tests("#abort_multipart_upload('#{@directory.identity}', 'fog_multipart_abort', '#{@upload_id}')").succeeds do
103
- Fog::Storage[:aws].abort_multipart_upload(@directory.identity, 'fog_multipart_abort', @upload_id)
104
- end
105
-
106
- end
107
-
108
- tests('failure') do
109
-
110
- tests("initiate_multipart_upload")
111
- tests("list_multipart_uploads")
112
- tests("upload_part")
113
- tests("list_parts")
114
- tests("complete_multipart_upload")
115
- tests("abort_multipart_upload")
116
-
117
- end
118
-
119
- @directory.destroy
120
-
121
- end
@@ -1,269 +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("#put_object('#{@directory.identity}', 'fog_object', lorem_file at EOF)").returns(lorem_file.read) do
22
- file = lorem_file
23
- file.read
24
- Fog::Storage[:aws].put_object(@directory.identity, 'fog_object', file)
25
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object').body
26
- end
27
-
28
- tests("#copy_object('#{@directory.identity}', 'fog_object', '#{@directory.identity}', 'fog_other_object')").succeeds do
29
- Fog::Storage[:aws].copy_object(@directory.identity, 'fog_object', @directory.identity, 'fog_other_object')
30
- end
31
-
32
- @directory.files.get('fog_other_object').destroy
33
-
34
- tests("#get_object('#{@directory.identity}', 'fog_object')").returns(lorem_file.read) do
35
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object').body
36
- end
37
-
38
- tests("#get_object('#{@directory.identity}', 'fog_object', &block)").returns(lorem_file.read) do
39
- data = ''
40
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object') do |chunk, remaining_bytes, total_bytes|
41
- data << chunk
42
- end
43
- data
44
- end
45
-
46
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file) })").returns(lorem_file.read) do
47
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) }).body
48
- end
49
-
50
- tests("#get_object('#{@directory.identity}', 'fog_object', {'Range' => 'bytes=0-20'})").returns(lorem_file.read[0..20]) do
51
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', {'Range' => 'bytes=0-20'}).body
52
- end
53
-
54
- tests("#get_object('#{@directory.identity}', 'fog_object', {'Range' => 'bytes=0-0'})").returns(lorem_file.read[0..0]) do
55
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', {'Range' => 'bytes=0-0'}).body
56
- end
57
-
58
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) })").returns(lorem_file.read) do
59
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) }).body
60
- end
61
-
62
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Modified-Since' => Time.now - 60 })").returns(lorem_file.read) do
63
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Modified-Since' => Time.now - 60 }).body
64
- end
65
-
66
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-None-Match' => 'invalid_etag' })").returns(lorem_file.read) do
67
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-None-Match' => 'invalid_etag' }).body
68
- end
69
-
70
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Unmodified-Since' => Time.now + 60 })").returns(lorem_file.read) do
71
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Unmodified-Since' => Time.now + 60 }).body
72
- end
73
-
74
- tests("#head_object('#{@directory.identity}', 'fog_object')").succeeds do
75
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object')
76
- end
77
-
78
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) })").succeeds do
79
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Match' => Digest::MD5.hexdigest(lorem_file.read) })
80
- end
81
-
82
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Modified-Since' => Time.now - 60 })").succeeds do
83
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Modified-Since' => Time.now - 60 })
84
- end
85
-
86
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-None-Match' => 'invalid_etag' })").succeeds do
87
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-None-Match' => 'invalid_etag' })
88
- end
89
-
90
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Unmodified-Since' => Time.now + 60 })").succeeds do
91
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Unmodified-Since' => Time.now + 60 })
92
- end
93
-
94
- tests("#post_object_restore('#{@directory.identity}', 'fog_object')").succeeds do
95
- pending unless Fog.mocking?
96
- Fog::Storage[:aws].post_object_restore(@directory.identity, 'fog_object')
97
- end
98
-
99
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', 'private')").succeeds do
100
- Fog::Storage[:aws].put_object_acl(@directory.identity, 'fog_object', 'private')
101
- end
102
-
103
- acl = {
104
- 'Owner' => @aws_owner,
105
- 'AccessControlList' => [
106
- {
107
- 'Grantee' => @aws_owner,
108
- 'Permission' => "FULL_CONTROL"
109
- }
110
- ]}
111
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', hash with id)").returns(acl) do
112
- Fog::Storage[:aws].put_object_acl(@directory.identity, 'fog_object', acl)
113
- Fog::Storage[:aws].get_object_acl(@directory.identity, 'fog_object').body
114
- end
115
-
116
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', hash with email)").returns({
117
- 'Owner' => @aws_owner,
118
- 'AccessControlList' => [
119
- {
120
- 'Grantee' => { 'ID' => 'f62f0218873cfa5d56ae9429ae75a592fec4fd22a5f24a20b1038a7db9a8f150', 'DisplayName' => 'mtd' },
121
- 'Permission' => "FULL_CONTROL"
122
- }
123
- ]}) do
124
- pending if Fog.mocking?
125
- Fog::Storage[:aws].put_object_acl(@directory.identity, 'fog_object', {
126
- 'Owner' => @aws_owner,
127
- 'AccessControlList' => [
128
- {
129
- 'Grantee' => { 'EmailAddress' => 'mtd@amazon.com' },
130
- 'Permission' => "FULL_CONTROL"
131
- }
132
- ]})
133
- Fog::Storage[:aws].get_object_acl(@directory.identity, 'fog_object').body
134
- end
135
-
136
- acl = {
137
- 'Owner' => @aws_owner,
138
- 'AccessControlList' => [
139
- {
140
- 'Grantee' => { 'URI' => 'http://acs.amazonaws.com/groups/global/AllUsers' },
141
- 'Permission' => "FULL_CONTROL"
142
- }
143
- ]}
144
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', hash with uri)").returns(acl) do
145
- Fog::Storage[:aws].put_object_acl(@directory.identity, 'fog_object', acl)
146
- Fog::Storage[:aws].get_object_acl(@directory.identity, 'fog_object').body
147
- end
148
-
149
- tests("#delete_object('#{@directory.identity}', 'fog_object')").succeeds do
150
- Fog::Storage[:aws].delete_object(@directory.identity, 'fog_object')
151
- end
152
-
153
- tests("#get_object_http_url('#{@directory.identity}', 'fog_object', expiration timestamp)").returns(true) do
154
- object_url = Fog::Storage[:aws].get_object_http_url(@directory.identity, 'fog_object', (Time.now + 60))
155
- (object_url =~ /http:\/\/#{Regexp.quote(@directory.identity)}\.s3\.amazonaws\.com\/fog_object/) != nil
156
- end
157
-
158
- tests("#head_object_url('#{@directory.identity}', 'fog_object', expiration timestamp)").returns(true) do
159
- object_url = Fog::Storage[:aws].head_object_url(@directory.identity, 'fog_object', (Time.now + 60))
160
- (object_url =~ /https:\/\/#{Regexp.quote(@directory.identity)}\.s3\.amazonaws\.com\/fog_object/) != nil
161
- end
162
-
163
- tests("delete_multiple_objects('#{@directory.identity}', ['fog_object', 'fog_other_object'])").formats(@multiple_delete_format) do
164
- Fog::Storage[:aws].delete_multiple_objects(@directory.identity, ['fog_object', 'fog_other_object']).body
165
- end
166
-
167
- tests("#delete_multiple_objects('#{@directory.identity}', 'fØg_öbjèct', UTF-8)").succeeds do
168
- Fog::Storage[:aws].delete_multiple_objects(@directory.identity, ['fØg_öbjèct'])
169
- end
170
-
171
- end
172
-
173
- fognonbucket = uniq_id('fognonbucket')
174
-
175
- tests('failure') do
176
-
177
- tests("#put_object('#{fognonbucket}', 'fog_non_object', lorem_file)").raises(Excon::Errors::NotFound) do
178
- Fog::Storage[:aws].put_object(fognonbucket, 'fog_non_object', lorem_file)
179
- end
180
-
181
- tests("#put_object('#{@directory.identity}', 'fog_object', lorem_file, {'x-amz-meta-json' => 'ä'}").raises(Excon::Errors::BadRequest) do
182
- Fog::Storage[:aws].put_object(@directory.identity, 'fog_object', lorem_file, {'x-amz-meta-json' => 'ä'})
183
- end
184
-
185
- tests("#copy_object('#{fognonbucket}', 'fog_object', '#{@directory.identity}', 'fog_other_object')").raises(Excon::Errors::NotFound) do
186
- Fog::Storage[:aws].copy_object(fognonbucket, 'fog_object', @directory.identity, 'fog_other_object')
187
- end
188
-
189
- tests("#copy_object('#{@directory.identity}', 'fog_non_object', '#{@directory.identity}', 'fog_other_object')").raises(Excon::Errors::NotFound) do
190
- Fog::Storage[:aws].copy_object(@directory.identity, 'fog_non_object', @directory.identity, 'fog_other_object')
191
- end
192
-
193
- tests("#copy_object('#{@directory.identity}', 'fog_object', 'fognonbucket', 'fog_other_object')").raises(Excon::Errors::NotFound) do
194
- Fog::Storage[:aws].copy_object(@directory.identity, 'fog_object', fognonbucket, 'fog_other_object')
195
- end
196
-
197
- tests("#get_object('#{fognonbucket}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
198
- Fog::Storage[:aws].get_object(fognonbucket, 'fog_non_object')
199
- end
200
-
201
- tests("#get_object('#{@directory.identity}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
202
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_non_object')
203
- end
204
-
205
- Fog::Storage[:aws].put_object(@directory.identity, 'fog_object', lorem_file)
206
-
207
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Match' => 'invalid_etag' })").raises(Excon::Errors::PreconditionFailed) do
208
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Match' => 'invalid_etag' })
209
- end
210
-
211
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Modified-Since' => Time.now })").raises(Excon::Errors::NotModified) do
212
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Modified-Since' => Time.now })
213
- end
214
-
215
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-None-Match' => Digest::MD5.hexdigest(lorem_file.read) })").raises(Excon::Errors::NotModified) do
216
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-None-Match' => Digest::MD5.hexdigest(lorem_file.read) })
217
- end
218
-
219
- tests("#get_object('#{@directory.identity}', 'fog_object', { 'If-Unmodified-Since' => Time.now - 60 })").raises(Excon::Errors::PreconditionFailed) do
220
- Fog::Storage[:aws].get_object(@directory.identity, 'fog_object', { 'If-Unmodified-Since' => Time.now - 60 })
221
- end
222
-
223
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Match' => 'invalid_etag' })").raises(Excon::Errors::PreconditionFailed) do
224
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Match' => 'invalid_etag' })
225
- end
226
-
227
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Modified-Since' => Time.now })").raises(Excon::Errors::NotModified) do
228
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Modified-Since' => Time.now })
229
- end
230
-
231
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-None-Match' => Digest::MD5.hexdigest(lorem_file.read) })").raises(Excon::Errors::NotModified) do
232
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-None-Match' => Digest::MD5.hexdigest(lorem_file.read) })
233
- end
234
-
235
- tests("#head_object('#{@directory.identity}', 'fog_object', { 'If-Unmodified-Since' => Time.now - 60 })").raises(Excon::Errors::PreconditionFailed) do
236
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_object', { 'If-Unmodified-Since' => Time.now - 60 })
237
- end
238
-
239
- Fog::Storage[:aws].delete_object(@directory.identity, 'fog_object')
240
-
241
- tests("#head_object(fognonbucket, 'fog_non_object')").raises(Excon::Errors::NotFound) do
242
- Fog::Storage[:aws].head_object(fognonbucket, 'fog_non_object')
243
- end
244
-
245
- tests("#head_object('#{@directory.identity}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
246
- Fog::Storage[:aws].head_object(@directory.identity, 'fog_non_object')
247
- end
248
-
249
- tests("#delete_object('#{fognonbucket}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
250
- Fog::Storage[:aws].delete_object(fognonbucket, 'fog_non_object')
251
- end
252
-
253
- tests("#delete_multiple_objects('#{fognonbucket}', ['fog_non_object'])").raises(Excon::Errors::NotFound) do
254
- pending if Fog.mocking?
255
- Fog::Storage[:aws].delete_multiple_objects(fognonbucket, ['fog_non_object'])
256
- end
257
-
258
- tests("#put_object_acl('#{@directory.identity}', 'fog_object', 'invalid')").raises(Excon::Errors::BadRequest) do
259
- Fog::Storage[:aws].put_object_acl('#{@directory.identity}', 'fog_object', 'invalid')
260
- end
261
-
262
- tests("#post_object_restore('#{@directory.identity}', 'fog_non_object')").raises(Excon::Errors::NotFound) do
263
- Fog::Storage[:aws].post_object_restore(@directory.identity, 'fog_non_object')
264
- end
265
- end
266
-
267
- @directory.destroy
268
-
269
- end