azure 0.1.1 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.gitignore +6 -0
- data/ChangeLog.txt +5 -0
- data/Gemfile +16 -3
- data/README.md +344 -2
- data/Rakefile +66 -37
- data/azure.gemspec +30 -11
- data/lib/azure.rb +35 -4
- data/lib/azure/blob/blob.rb +32 -0
- data/lib/azure/blob/blob_service.rb +1423 -0
- data/lib/azure/blob/block.rb +31 -0
- data/lib/azure/blob/container.rb +32 -0
- data/lib/azure/blob/serialization.rb +285 -0
- data/lib/azure/core.rb +32 -0
- data/lib/azure/core/auth/authorizer.rb +36 -0
- data/lib/azure/core/auth/shared_key.rb +21 -6
- data/lib/azure/core/auth/shared_key_lite.rb +17 -3
- data/lib/azure/core/auth/signer.rb +48 -0
- data/lib/azure/core/configuration.rb +152 -0
- data/lib/azure/core/error.rb +22 -0
- data/lib/azure/core/filtered_service.rb +44 -0
- data/lib/azure/core/http/debug_filter.rb +36 -0
- data/lib/azure/core/http/http_error.rb +84 -0
- data/lib/azure/core/http/http_filter.rb +53 -0
- data/lib/azure/core/http/http_request.rb +157 -0
- data/lib/azure/core/http/http_response.rb +133 -0
- data/lib/azure/core/http/retry_policy.rb +68 -0
- data/lib/azure/core/http/signer_filter.rb +34 -0
- data/lib/azure/core/service.rb +38 -32
- data/lib/azure/core/signed_service.rb +43 -0
- data/lib/azure/queue/message.rb +30 -0
- data/lib/azure/queue/queue.rb +29 -0
- data/lib/azure/queue/queue_service.rb +568 -0
- data/lib/azure/queue/serialization.rb +103 -0
- data/lib/azure/service/access_policy.rb +26 -0
- data/lib/azure/service/enumeration_results.rb +21 -0
- data/lib/azure/service/logging.rb +32 -0
- data/lib/azure/service/metrics.rb +31 -0
- data/lib/azure/service/retention_policy.rb +25 -0
- data/lib/azure/service/serialization.rb +240 -0
- data/lib/azure/service/signed_identifier.rb +30 -0
- data/lib/azure/service/storage_service.rb +79 -0
- data/lib/azure/service/storage_service_properties.rb +32 -0
- data/lib/azure/service_bus/action.rb +21 -0
- data/lib/azure/service_bus/auth/wrap_service.rb +59 -46
- data/lib/azure/service_bus/auth/wrap_signer.rb +69 -0
- data/lib/azure/service_bus/brokered_message.rb +36 -51
- data/lib/azure/service_bus/brokered_message_serializer.rb +48 -34
- data/lib/azure/service_bus/correlation_filter.rb +45 -0
- data/lib/azure/service_bus/empty_rule_action.rb +30 -0
- data/lib/azure/service_bus/false_filter.rb +38 -0
- data/lib/azure/service_bus/filter.rb +21 -0
- data/lib/azure/{core/utils → service_bus}/interval.rb +29 -22
- data/lib/azure/service_bus/queue.rb +230 -0
- data/lib/azure/service_bus/resource.rb +109 -0
- data/lib/azure/service_bus/rule.rb +98 -0
- data/lib/azure/service_bus/rule_aspect.rb +34 -0
- data/lib/azure/service_bus/serialization.rb +160 -0
- data/lib/azure/service_bus/service_bus_service.rb +819 -12
- data/lib/azure/service_bus/sql_filter.rb +50 -0
- data/lib/azure/service_bus/sql_rule_action.rb +50 -0
- data/lib/azure/service_bus/subscription.rb +184 -0
- data/lib/azure/service_bus/topic.rb +187 -0
- data/lib/azure/service_bus/true_filter.rb +38 -0
- data/lib/azure/{tables → table}/auth/shared_key.rb +33 -12
- data/lib/azure/table/auth/shared_key_lite.rb +44 -0
- data/lib/azure/table/batch.rb +330 -0
- data/lib/azure/table/batch_response.rb +117 -0
- data/lib/azure/table/edmtype.rb +127 -0
- data/lib/azure/table/entity.rb +31 -0
- data/lib/azure/table/guid.rb +24 -0
- data/lib/azure/table/query.rb +112 -0
- data/lib/azure/table/serialization.rb +105 -0
- data/lib/azure/table/table_service.rb +557 -0
- data/lib/azure/version.rb +31 -0
- data/test/fixtures/container_acl.xml +11 -0
- data/test/fixtures/{error.xml → http_error.xml} +0 -0
- data/test/fixtures/list_blobs.xml +121 -0
- data/test/fixtures/list_block_all_with_none_committed.xml +22 -0
- data/test/fixtures/list_blocks_all.xml +23 -0
- data/test/fixtures/list_blocks_committed.xml +13 -0
- data/test/fixtures/list_containers.xml +38 -0
- data/test/fixtures/list_page_ranges.xml +11 -0
- data/test/fixtures/logging.xml +11 -0
- data/test/fixtures/metrics.xml +10 -0
- data/test/fixtures/queues.xml +1 -1
- data/test/fixtures/retention_policy.xml +5 -0
- data/test/fixtures/storage_service_properties.xml +23 -0
- data/test/integration/blob/blob_metadata_test.rb +75 -0
- data/test/integration/blob/blob_pages_test.rb +119 -0
- data/test/integration/blob/blob_properties_test.rb +77 -0
- data/test/integration/blob/block_blob_test.rb +254 -0
- data/test/integration/blob/container/container_acl_test.rb +69 -0
- data/test/integration/blob/container/container_metadata_test.rb +50 -0
- data/test/integration/blob/container/create_container_test.rb +60 -0
- data/test/integration/blob/container/delete_container_test.rb +39 -0
- data/test/integration/blob/container/get_container_properties_test.rb +48 -0
- data/test/integration/blob/container/list_containers_test.rb +79 -0
- data/test/integration/blob/container/root_container_test.rb +50 -0
- data/test/integration/blob/copy_blob_test.rb +113 -0
- data/test/integration/blob/create_blob_snapshot_test.rb +80 -0
- data/test/integration/blob/create_page_blob_test.rb +83 -0
- data/test/integration/blob/delete_blob_test.rb +159 -0
- data/test/integration/blob/get_blob_test.rb +65 -0
- data/test/integration/blob/informative_errors_test.rb +39 -0
- data/test/integration/blob/lease/acquire_lease_test.rb +36 -0
- data/test/integration/blob/lease/break_lease_test.rb +40 -0
- data/test/integration/blob/lease/release_lease_test.rb +40 -0
- data/test/integration/blob/lease/renew_lease_test.rb +42 -0
- data/test/integration/blob/list_blobs_test.rb +113 -0
- data/test/integration/queue/clear_messages_test.rb +42 -0
- data/test/integration/queue/create_message_test.rb +75 -0
- data/test/integration/queue/create_queue_test.rb +50 -0
- data/test/integration/queue/delete_message_test.rb +67 -0
- data/test/integration/queue/delete_queue_test.rb +45 -0
- data/test/integration/queue/informative_errors_test.rb +42 -0
- data/test/integration/queue/list_messages_encoded_test.rb +79 -0
- data/test/integration/queue/list_messages_test.rb +79 -0
- data/test/integration/queue/list_queues_test.rb +44 -0
- data/test/integration/queue/peek_messages_test.rb +59 -0
- data/test/integration/queue/queue_metadata_test.rb +40 -0
- data/test/integration/queue/update_message_test.rb +74 -0
- data/test/integration/service_bus/informative_errors_test.rb +37 -0
- data/test/integration/service_bus/queues_scenario_test.rb +200 -0
- data/test/integration/service_bus/queues_test.rb +266 -0
- data/test/integration/service_bus/rules_test.rb +145 -0
- data/test/integration/service_bus/scenario_test.rb +102 -0
- data/test/integration/service_bus/subscriptions_test.rb +211 -0
- data/test/integration/service_bus/topics_scenario_test.rb +406 -0
- data/test/integration/service_bus/topics_test.rb +129 -0
- data/test/integration/table/create_table_test.rb +36 -0
- data/test/integration/table/delete_entity_batch_test.rb +107 -0
- data/test/integration/table/delete_entity_test.rb +94 -0
- data/test/integration/table/delete_table_test.rb +40 -0
- data/test/integration/table/get_table_test.rb +37 -0
- data/test/integration/table/informative_errors_test.rb +39 -0
- data/test/integration/table/insert_entity_batch_test.rb +100 -0
- data/test/integration/table/insert_entity_test.rb +88 -0
- data/test/integration/table/insert_or_merge_entity_batch_test.rb +159 -0
- data/test/integration/table/insert_or_merge_entity_test.rb +143 -0
- data/test/integration/table/insert_or_replace_entity_batch_test.rb +152 -0
- data/test/integration/table/insert_or_replace_entity_test.rb +137 -0
- data/test/integration/table/merge_entity_batch_test.rb +128 -0
- data/test/integration/table/merge_entity_test.rb +113 -0
- data/test/integration/table/query_entities_test.rb +195 -0
- data/test/integration/table/query_tables_test.rb +43 -0
- data/test/integration/table/query_test.rb +251 -0
- data/test/integration/table/table_acl_test.rb +52 -0
- data/test/integration/table/update_entity_batch_test.rb +149 -0
- data/test/integration/table/update_entity_test.rb +131 -0
- data/test/integration/test_helper.rb +23 -9
- data/test/support/env.rb +15 -1
- data/test/support/fixtures.rb +14 -0
- data/test/support/name_generator.rb +74 -0
- data/test/support/stubs.rb +14 -0
- data/test/test_helper.rb +43 -3
- data/test/unit/blob/blob_service_test.rb +1947 -0
- data/test/unit/core/auth/shared_key_lite_test.rb +51 -0
- data/test/unit/core/auth/shared_key_test.rb +58 -0
- data/test/unit/core/auth/signer_test.rb +30 -0
- data/test/unit/core/http/http_error_test.rb +57 -0
- data/test/unit/core/http/http_request_test.rb +66 -0
- data/test/unit/core/http/http_response_test.rb +45 -0
- data/test/unit/service/serialization_test.rb +502 -0
- data/test/unit/service/storage_service_test.rb +291 -0
- data/test/unit/table/edmtype_test.rb +108 -0
- metadata +231 -230
- data/Gemfile.lock +0 -36
- data/lib/azure/atom.rb +0 -170
- data/lib/azure/auth.rb +0 -29
- data/lib/azure/blobs.rb +0 -620
- data/lib/azure/blobs/blob.rb +0 -360
- data/lib/azure/blobs/container.rb +0 -209
- data/lib/azure/blobs/service.rb +0 -396
- data/lib/azure/blobs/shared_access_signature.rb +0 -84
- data/lib/azure/blobs/uri.rb +0 -60
- data/lib/azure/configuration.rb +0 -121
- data/lib/azure/core/collection.rb +0 -118
- data/lib/azure/core/signer.rb +0 -32
- data/lib/azure/core/utils/queryable.rb +0 -74
- data/lib/azure/core/utils/storage_service_properties.rb +0 -83
- data/lib/azure/core/utils/string.rb +0 -59
- data/lib/azure/error.rb +0 -72
- data/lib/azure/queues.rb +0 -272
- data/lib/azure/queues/message.rb +0 -174
- data/lib/azure/queues/queue.rb +0 -187
- data/lib/azure/queues/service.rb +0 -263
- data/lib/azure/queues/service_properties.rb +0 -152
- data/lib/azure/queues/uri.rb +0 -78
- data/lib/azure/request.rb +0 -102
- data/lib/azure/response.rb +0 -93
- data/lib/azure/service_bus.rb +0 -4
- data/lib/azure/service_bus/auth/authorizer.rb +0 -22
- data/lib/azure/service_bus/auth/uri.rb +0 -52
- data/lib/azure/service_bus/auth/wrap.rb +0 -37
- data/lib/azure/service_bus/auth/wrap_token.rb +0 -45
- data/lib/azure/service_bus/auth/wrap_token_manager.rb +0 -46
- data/lib/azure/service_bus/queues.rb +0 -194
- data/lib/azure/service_bus/queues/queue.rb +0 -100
- data/lib/azure/service_bus/queues/queue_serializer.rb +0 -51
- data/lib/azure/service_bus/queues/service.rb +0 -154
- data/lib/azure/service_bus/queues/uri.rb +0 -80
- data/lib/azure/service_bus/rules.rb +0 -110
- data/lib/azure/service_bus/rules/rule.rb +0 -97
- data/lib/azure/service_bus/rules/service.rb +0 -122
- data/lib/azure/service_bus/rules/uri.rb +0 -39
- data/lib/azure/service_bus/subscriptions.rb +0 -170
- data/lib/azure/service_bus/subscriptions/service.rb +0 -133
- data/lib/azure/service_bus/subscriptions/subscription.rb +0 -164
- data/lib/azure/service_bus/subscriptions/subscription_serializer.rb +0 -74
- data/lib/azure/service_bus/subscriptions/uri.rb +0 -71
- data/lib/azure/service_bus/topics.rb +0 -120
- data/lib/azure/service_bus/topics/service.rb +0 -98
- data/lib/azure/service_bus/topics/topic.rb +0 -122
- data/lib/azure/service_bus/topics/topic_serializer.rb +0 -44
- data/lib/azure/service_bus/topics/uri.rb +0 -58
- data/lib/azure/service_runtime/client/goal_state_pipe_monitor.rb +0 -21
- data/lib/azure/service_runtime/client/goal_state_protocol.rb +0 -18
- data/lib/azure/service_runtime/client/runtime_client.rb +0 -135
- data/lib/azure/service_runtime/deployment.rb +0 -24
- data/lib/azure/service_runtime/local_resource.rb +0 -15
- data/lib/azure/service_runtime/role.rb +0 -17
- data/lib/azure/service_runtime/role_environment.rb +0 -206
- data/lib/azure/service_runtime/role_environment_change.rb +0 -32
- data/lib/azure/service_runtime/role_instance.rb +0 -35
- data/lib/azure/service_runtime/role_instance_endpoint.rb +0 -14
- data/lib/azure/tables.rb +0 -215
- data/lib/azure/tables/auth/shared_key_lite.rb +0 -30
- data/lib/azure/tables/entities_collection.rb +0 -66
- data/lib/azure/tables/entity.rb +0 -127
- data/lib/azure/tables/service.rb +0 -211
- data/lib/azure/tables/table.rb +0 -129
- data/lib/azure/tables/tables_collection.rb +0 -62
- data/lib/azure/tables/types.rb +0 -65
- data/lib/azure/tables/uri.rb +0 -62
- data/test/integration/blobs/auth_test.rb +0 -19
- data/test/integration/blobs/blob_test.rb +0 -61
- data/test/integration/blobs/clear_page_range_test.rb +0 -19
- data/test/integration/blobs/copy_test.rb +0 -33
- data/test/integration/blobs/create_blobs_test.rb +0 -51
- data/test/integration/blobs/create_container_test.rb +0 -13
- data/test/integration/blobs/create_snapshot_test.rb +0 -17
- data/test/integration/blobs/delete_blob_snapshots_test.rb +0 -19
- data/test/integration/blobs/delete_blobs_test.rb +0 -25
- data/test/integration/blobs/delete_container_test.rb +0 -24
- data/test/integration/blobs/delete_snapshot_test.rb +0 -17
- data/test/integration/blobs/get_blob_snapshot_test.rb +0 -18
- data/test/integration/blobs/get_blobs_test.rb +0 -31
- data/test/integration/blobs/get_page_range_test.rb +0 -19
- data/test/integration/blobs/list_blobs_test.rb +0 -39
- data/test/integration/blobs/list_containers_test.rb +0 -28
- data/test/integration/blobs/manage_blob_leases_test.rb +0 -45
- data/test/integration/blobs/manage_blob_metadata_test.rb +0 -51
- data/test/integration/blobs/manage_blob_properties_test.rb +0 -25
- data/test/integration/blobs/manage_blob_service_properties_test.rb +0 -38
- data/test/integration/blobs/manage_container_metadata_test.rb +0 -46
- data/test/integration/blobs/manage_container_permissions_test.rb +0 -17
- data/test/integration/blobs/update_page_range_test.rb +0 -20
- data/test/integration/queues/clear_messages_test.rb +0 -22
- data/test/integration/queues/create_queue_test.rb +0 -13
- data/test/integration/queues/delete_message_test.rb +0 -42
- data/test/integration/queues/delete_queue_test.rb +0 -24
- data/test/integration/queues/get_messages_test.rb +0 -39
- data/test/integration/queues/list_queues_test.rb +0 -43
- data/test/integration/queues/manage_queue_metadata_test.rb +0 -45
- data/test/integration/queues/manage_queue_service_properties_test.rb +0 -27
- data/test/integration/queues/peek_messages_test.rb +0 -55
- data/test/integration/queues/put_message_test.rb +0 -31
- data/test/integration/queues/update_message_test.rb +0 -46
- data/test/integration/service_bus/auth_test.rb +0 -18
- data/test/integration/service_bus/queues/create_queue_test.rb +0 -25
- data/test/integration/service_bus/queues/delete_message_from_queue_test.rb +0 -29
- data/test/integration/service_bus/queues/delete_queue_test.rb +0 -25
- data/test/integration/service_bus/queues/get_queue_test.rb +0 -23
- data/test/integration/service_bus/queues/list_queues_test.rb +0 -39
- data/test/integration/service_bus/queues/peek_message_from_queue_test.rb +0 -34
- data/test/integration/service_bus/queues/read_and_delete_message_from_queue_test.rb +0 -31
- data/test/integration/service_bus/queues/send_message_to_queue_test.rb +0 -22
- data/test/integration/service_bus/queues/unlock_message_from_queue_test.rb +0 -36
- data/test/integration/service_bus/rules/create_rule_test.rb +0 -19
- data/test/integration/service_bus/rules/delete_rule_test.rb +0 -17
- data/test/integration/service_bus/rules/get_rule_test.rb +0 -21
- data/test/integration/service_bus/rules/list_rules_test.rb +0 -24
- data/test/integration/service_bus/rules/rule_test.rb +0 -16
- data/test/integration/service_bus/subscriptions/create_subscription_test.rb +0 -25
- data/test/integration/service_bus/subscriptions/delete_message_from_subscription_test.rb +0 -31
- data/test/integration/service_bus/subscriptions/delete_subscription_test.rb +0 -30
- data/test/integration/service_bus/subscriptions/fetch_subscription_test.rb +0 -28
- data/test/integration/service_bus/subscriptions/list_subscriptions_test.rb +0 -23
- data/test/integration/service_bus/subscriptions/peek_lock_message_from_subscription_test.rb +0 -42
- data/test/integration/service_bus/subscriptions/read_delete_message_from_subscription_test.rb +0 -36
- data/test/integration/service_bus/subscriptions/subscription_test.rb +0 -31
- data/test/integration/service_bus/subscriptions/unlock_message_from_subscription_test.rb +0 -43
- data/test/integration/service_bus/topics/create_topic_test.rb +0 -25
- data/test/integration/service_bus/topics/delete_topic_test.rb +0 -25
- data/test/integration/service_bus/topics/get_topic_test.rb +0 -23
- data/test/integration/service_bus/topics/list_topics_test.rb +0 -39
- data/test/integration/service_bus/topics/send_message_to_topic_test.rb +0 -23
- data/test/integration/tables/auth_test.rb +0 -29
- data/test/integration/tables/creating_tables_test.rb +0 -16
- data/test/integration/tables/delete_entity_test.rb +0 -39
- data/test/integration/tables/deleting_table_test.rb +0 -22
- data/test/integration/tables/insert_entity_test.rb +0 -23
- data/test/integration/tables/merge_entity_test.rb +0 -28
- data/test/integration/tables/query_entities_test.rb +0 -131
- data/test/integration/tables/query_tables_test.rb +0 -63
- data/test/integration/tables/update_entity_test.rb +0 -54
- data/test/support/blobs.rb +0 -12
- data/test/support/table_names.rb +0 -44
- data/test/unit/atom_test.rb +0 -58
- data/test/unit/auth_test.rb +0 -24
- data/test/unit/blobs/blob_test.rb +0 -5
- data/test/unit/blobs/container_test.rb +0 -67
- data/test/unit/blobs/service_test.rb +0 -17
- data/test/unit/blobs/shared_access_signature_test.rb +0 -66
- data/test/unit/blobs_test.rb +0 -156
- data/test/unit/core/service_test.rb +0 -57
- data/test/unit/core/utils/interval_test.rb +0 -70
- data/test/unit/core/utils/queryable_test.rb +0 -69
- data/test/unit/core/utils/storage_service_properties_test.rb +0 -66
- data/test/unit/error_test.rb +0 -39
- data/test/unit/queues/message_test.rb +0 -40
- data/test/unit/queues/queue_test.rb +0 -64
- data/test/unit/queues/service_properties.rb +0 -35
- data/test/unit/request_test.rb +0 -38
- data/test/unit/response_test.rb +0 -43
- data/test/unit/service_bus/auth/authorizer_test.rb +0 -27
- data/test/unit/service_bus/auth/wrap_token_test.rb +0 -28
- data/test/unit/service_bus/queues/queue_test.rb +0 -38
- data/test/unit/service_bus/topics/topic_test.rb +0 -33
- data/test/unit/service_runtime/data/goalstate.xml +0 -9
- data/test/unit/service_runtime/data/roleenvironmentdata.xml +0 -29
- data/test/unit/service_runtime/data/runtime.xml +0 -6
- data/test/unit/service_runtime/role_environment_test.rb +0 -144
- data/test/unit/tables/auth/shared_key_lite_test.rb +0 -39
- data/test/unit/tables/auth/shared_key_test.rb +0 -45
- data/test/unit/tables/entities_collection_test.rb +0 -39
- data/test/unit/tables/entity_test.rb +0 -72
- data/test/unit/tables/table_test.rb +0 -57
- data/test/unit/tables_test.rb +0 -302
- data/test/unit/types_test.rb +0 -67
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Listing blobs" do
|
|
4
|
-
let :container do
|
|
5
|
-
Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
after do
|
|
9
|
-
ContainerNameHelper.clean
|
|
10
|
-
end
|
|
11
|
-
|
|
12
|
-
it "returns an empty list if there are no blobs in the container" do
|
|
13
|
-
blobs = container.blobs
|
|
14
|
-
blobs.must_be_empty
|
|
15
|
-
end
|
|
16
|
-
|
|
17
|
-
it "returns a list of blobs if one or more exist" do
|
|
18
|
-
blob_1 = create_block_blob(container: container, name: "blob_1.jpg")
|
|
19
|
-
blob_2 = create_block_blob(container: container, name: "blob_2.jpg")
|
|
20
|
-
|
|
21
|
-
blobs = container.blobs
|
|
22
|
-
blobs.must_include(blob_1)
|
|
23
|
-
blobs.must_include(blob_2)
|
|
24
|
-
end
|
|
25
|
-
|
|
26
|
-
it "includes the properties of the blobs" do
|
|
27
|
-
create_block_blob(:container => container)
|
|
28
|
-
|
|
29
|
-
blob = container.blobs.first
|
|
30
|
-
blob.properties.wont_be_empty
|
|
31
|
-
end
|
|
32
|
-
|
|
33
|
-
it "includes any metadata set in the blob" do
|
|
34
|
-
create_block_blob(:container => container, :metadata => {"Key" => "Value"})
|
|
35
|
-
|
|
36
|
-
blob = container.blobs.first
|
|
37
|
-
blob.metadata["Key"].must_equal "Value"
|
|
38
|
-
end
|
|
39
|
-
end
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Listing containers" do
|
|
4
|
-
after do
|
|
5
|
-
ContainerNameHelper.clean
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
it "returns an empty list if there are no containers" do
|
|
9
|
-
all_containers = Azure::Blobs.containers
|
|
10
|
-
all_containers.must_be_empty
|
|
11
|
-
end
|
|
12
|
-
|
|
13
|
-
it "returns a list of containers if one or more exist" do
|
|
14
|
-
container_1 = Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
15
|
-
container_2 = Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
16
|
-
|
|
17
|
-
all_containers = Azure::Blobs.containers
|
|
18
|
-
all_containers.must_include(container_1)
|
|
19
|
-
all_containers.must_include(container_2)
|
|
20
|
-
end
|
|
21
|
-
|
|
22
|
-
it "loads the properties of each container" do
|
|
23
|
-
Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
24
|
-
container = Azure::Blobs.containers.first
|
|
25
|
-
|
|
26
|
-
container.properties.wont_be_empty
|
|
27
|
-
end
|
|
28
|
-
end
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Manage Blob Leases" do
|
|
4
|
-
|
|
5
|
-
before do
|
|
6
|
-
@container = Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
7
|
-
@blob = Azure::Blobs.create_block_blob(@container, "myBlob", nil)
|
|
8
|
-
end
|
|
9
|
-
|
|
10
|
-
after do
|
|
11
|
-
ContainerNameHelper.clean
|
|
12
|
-
end
|
|
13
|
-
|
|
14
|
-
it "should be able to acquire a lease" do
|
|
15
|
-
Azure::Blobs.lease(@blob, :acquire)
|
|
16
|
-
@blob.error.must_be_nil
|
|
17
|
-
@blob.lease_id.wont_be_nil
|
|
18
|
-
end
|
|
19
|
-
|
|
20
|
-
it "should fail trying to acquire a lease in a blob with an active lease" do
|
|
21
|
-
Azure::Blobs.lease(@blob, :acquire)
|
|
22
|
-
Azure::Blobs.lease(@blob, :acquire)
|
|
23
|
-
@blob.error.wont_be_nil
|
|
24
|
-
end
|
|
25
|
-
|
|
26
|
-
it "should be able to renew a lease" do
|
|
27
|
-
Azure::Blobs.lease(@blob, :acquire)
|
|
28
|
-
Azure::Blobs.lease(@blob, :renew)
|
|
29
|
-
@blob.error.must_be_nil
|
|
30
|
-
end
|
|
31
|
-
|
|
32
|
-
it "should be able to release a lease" do
|
|
33
|
-
Azure::Blobs.lease(@blob, :acquire)
|
|
34
|
-
Azure::Blobs.lease(@blob, :release)
|
|
35
|
-
Azure::Blobs.lease(@blob, :acquire)
|
|
36
|
-
@blob.error.must_be_nil
|
|
37
|
-
end
|
|
38
|
-
|
|
39
|
-
it "should be able to break a lease" do
|
|
40
|
-
Azure::Blobs.lease(@blob, :acquire)
|
|
41
|
-
Azure::Blobs.lease(@blob, :break)
|
|
42
|
-
Azure::Blobs.lease(@blob, :acquire)
|
|
43
|
-
@blob.error.wont_be_nil
|
|
44
|
-
end
|
|
45
|
-
end
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Managing the blob's metadata" do
|
|
4
|
-
let :container do
|
|
5
|
-
Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
after do
|
|
9
|
-
ContainerNameHelper.clean
|
|
10
|
-
end
|
|
11
|
-
|
|
12
|
-
it "can set the metadata on blob creation (but changes key casing)" do
|
|
13
|
-
blob = Azure::Blobs.create_block_blob(
|
|
14
|
-
container,
|
|
15
|
-
"myblob.jpg",
|
|
16
|
-
Fixtures["32px-fulls-black.jpg"].to_path,
|
|
17
|
-
"Key" => "Value"
|
|
18
|
-
)
|
|
19
|
-
|
|
20
|
-
blob.metadata.clear
|
|
21
|
-
blob.load_metadata!
|
|
22
|
-
blob.metadata["key"].must_equal "Value"
|
|
23
|
-
end
|
|
24
|
-
|
|
25
|
-
it "gets the metadata when listing blobs" do
|
|
26
|
-
create_block_blob(:container => container, :metadata => {"Key" => "Value"})
|
|
27
|
-
|
|
28
|
-
blob = Azure::Blobs.blobs(container).first
|
|
29
|
-
blob.metadata["Key"].must_equal "Value"
|
|
30
|
-
end
|
|
31
|
-
|
|
32
|
-
it "force-loads the metadata when calling #load_metadata!" do
|
|
33
|
-
blob = create_block_blob(:container => container, :metadata => {"name" => "Xara"})
|
|
34
|
-
blob.metadata["name"] = "NotXara" # change the metadata locally
|
|
35
|
-
blob.load_metadata! # it gets replaced by the metadata on the server
|
|
36
|
-
|
|
37
|
-
blob.metadata["name"].must_equal "Xara"
|
|
38
|
-
end
|
|
39
|
-
|
|
40
|
-
it "can update the metadata on the server after you modify the hash" do
|
|
41
|
-
blob = create_block_blob(:container => container)
|
|
42
|
-
blob.metadata.update("name" => "Manu")
|
|
43
|
-
|
|
44
|
-
result = blob.save_metadata!
|
|
45
|
-
result.must_equal true
|
|
46
|
-
|
|
47
|
-
blob.metadata["name"] = "NotManu"
|
|
48
|
-
metadata = blob.load_metadata!
|
|
49
|
-
blob.metadata["name"].must_equal "Manu"
|
|
50
|
-
end
|
|
51
|
-
end
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Managing the blob's properties" do
|
|
4
|
-
before do
|
|
5
|
-
@container = Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
after do
|
|
9
|
-
ContainerNameHelper.clean
|
|
10
|
-
end
|
|
11
|
-
|
|
12
|
-
it "should set blob properties" do
|
|
13
|
-
# FIXME: Why do this if we're not checking for any property getting set?
|
|
14
|
-
blob = create_block_blob(:container => @container)
|
|
15
|
-
result = blob.save_properties!
|
|
16
|
-
result.must_equal true
|
|
17
|
-
end
|
|
18
|
-
|
|
19
|
-
it "force-loads the properties" do
|
|
20
|
-
blob = create_block_blob(:container => @container)
|
|
21
|
-
blob.properties.clear
|
|
22
|
-
blob.load_properties!
|
|
23
|
-
blob.properties["etag"].wont_be_nil
|
|
24
|
-
end
|
|
25
|
-
end
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
require "azure/core/utils/storage_service_properties"
|
|
3
|
-
|
|
4
|
-
describe "Manage Blob Service Properties" do
|
|
5
|
-
it "should be able to set blob service properties" do
|
|
6
|
-
|
|
7
|
-
properties = {
|
|
8
|
-
"Logging" => {
|
|
9
|
-
"Version" => "1.0",
|
|
10
|
-
"Delete" => "true",
|
|
11
|
-
"Read" => "true",
|
|
12
|
-
"Write" => "true",
|
|
13
|
-
"RetentionPolicy" => {
|
|
14
|
-
"Enabled" => true,
|
|
15
|
-
"Days" => 7
|
|
16
|
-
}
|
|
17
|
-
},
|
|
18
|
-
"Metrics"=> {
|
|
19
|
-
"Version" => "1.0",
|
|
20
|
-
"Enabled" => "true",
|
|
21
|
-
"IncludeAPIs" => "false",
|
|
22
|
-
"RetentionPolicy" => {
|
|
23
|
-
"Enabled" => true,
|
|
24
|
-
"Days" => 7
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
Azure::Blobs.set_service_properties(properties).must_equal true
|
|
30
|
-
end
|
|
31
|
-
|
|
32
|
-
it "should be able to get blob service properties" do
|
|
33
|
-
response = Azure::Blobs.get_service_properties
|
|
34
|
-
response.must_be :kind_of?, Hash
|
|
35
|
-
response["Metrics"].must_be :kind_of?, Hash
|
|
36
|
-
response["Metrics"]["Version"].must_equal "1.0"
|
|
37
|
-
end
|
|
38
|
-
end
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Managing the container's metadata" do
|
|
4
|
-
after do
|
|
5
|
-
ContainerNameHelper.clean
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
it "sets metadata on container creation (Azure changes the casing of metadata keys)" do
|
|
9
|
-
Azure::Blobs.create_container(
|
|
10
|
-
ContainerNameHelper.name,
|
|
11
|
-
"UppercaseKey" => "U", "downcaseKey" => "D"
|
|
12
|
-
)
|
|
13
|
-
|
|
14
|
-
# FIXME: Change this once we have a way of finding a container by name.
|
|
15
|
-
container = Azure::Blobs.containers.first
|
|
16
|
-
|
|
17
|
-
container.metadata["Uppercasekey"].must_equal "U"
|
|
18
|
-
container.metadata["Downcasekey"].must_equal "D"
|
|
19
|
-
end
|
|
20
|
-
|
|
21
|
-
it "gets metadata when listing containers" do
|
|
22
|
-
Azure::Blobs.create_container(ContainerNameHelper.name, "Key" => "Value")
|
|
23
|
-
|
|
24
|
-
# FIXME: Change this once we have a way of finding a container by name.
|
|
25
|
-
container = Azure::Blobs.containers.first
|
|
26
|
-
container.metadata["Key"].must_equal "Value"
|
|
27
|
-
end
|
|
28
|
-
|
|
29
|
-
it "force-loads the metadata when calling #metadata!" do
|
|
30
|
-
container = Azure::Blobs.create_container(ContainerNameHelper.name, "Key" => "Value")
|
|
31
|
-
|
|
32
|
-
container.metadata.must_be_empty
|
|
33
|
-
container.load_metadata!.wont_be_empty
|
|
34
|
-
container.metadata.wont_be_empty
|
|
35
|
-
end
|
|
36
|
-
|
|
37
|
-
it "saves the metadata in the server if you modify the metadata hash" do
|
|
38
|
-
container = Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
39
|
-
container.metadata["Key"] = "Value"
|
|
40
|
-
container.save_metadata!
|
|
41
|
-
|
|
42
|
-
# FIXME: Change this once we have a way of finding a container by name.
|
|
43
|
-
loaded_container = Azure::Blobs.containers.first
|
|
44
|
-
loaded_container.metadata["Key"].must_equal "Value"
|
|
45
|
-
end
|
|
46
|
-
end
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Managing a container's permissions" do
|
|
4
|
-
after do
|
|
5
|
-
ContainerNameHelper.clean
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
it "can grant temporary anonymous access to a blob via shared access signstures" do
|
|
9
|
-
container = Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
10
|
-
blob = create_block_blob(:container => container)
|
|
11
|
-
|
|
12
|
-
url = blob.shared_access_signature("r", 10 * 60) # read permissions, 10 minutes
|
|
13
|
-
|
|
14
|
-
response = Net::HTTP.get_response(url)
|
|
15
|
-
response.code.must_equal "200"
|
|
16
|
-
end
|
|
17
|
-
end
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Update Page Range" do
|
|
4
|
-
before do
|
|
5
|
-
@container = Azure::Blobs.create_container(ContainerNameHelper.name)
|
|
6
|
-
@blob = Azure::Blobs.create_page_blob(@container, "myBlob", 2048)
|
|
7
|
-
end
|
|
8
|
-
|
|
9
|
-
after do
|
|
10
|
-
ContainerNameHelper.clean
|
|
11
|
-
end
|
|
12
|
-
|
|
13
|
-
it "should be able to update a range of bytes" do
|
|
14
|
-
stream = "Hello World!" + (" " * (1024 - 12))
|
|
15
|
-
|
|
16
|
-
stream.bytesize.must_equal 1024
|
|
17
|
-
|
|
18
|
-
Azure::Blobs.update_page_range(@blob, 0, 1023, stream).must_equal true
|
|
19
|
-
end
|
|
20
|
-
end
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Clear Messages" do
|
|
4
|
-
after do
|
|
5
|
-
QueueNameHelper.clean
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
before do
|
|
9
|
-
@queue = Azure::Queues.create(QueueNameHelper.name)
|
|
10
|
-
end
|
|
11
|
-
|
|
12
|
-
it "should be able to delete all messages from the queue" do
|
|
13
|
-
@queue << "message 1"
|
|
14
|
-
@queue << "message 2"
|
|
15
|
-
|
|
16
|
-
result = @queue.clear
|
|
17
|
-
result.must_equal true
|
|
18
|
-
|
|
19
|
-
messages = @queue.get(5)
|
|
20
|
-
messages.must_be_empty
|
|
21
|
-
end
|
|
22
|
-
end
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Create queues" do
|
|
4
|
-
after do
|
|
5
|
-
QueueNameHelper.clean
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
it "should be able to create a new queue" do
|
|
9
|
-
queue = Azure::Queues.create(QueueNameHelper.name)
|
|
10
|
-
queue.must_be_kind_of Azure::Queues::Queue
|
|
11
|
-
assert queue.valid?, "must be valid"
|
|
12
|
-
end
|
|
13
|
-
end
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Delete Messages" do
|
|
4
|
-
after do
|
|
5
|
-
QueueNameHelper.clean
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
before do
|
|
9
|
-
@queue = Azure::Queues.create(QueueNameHelper.name)
|
|
10
|
-
@queue << "some sample text"
|
|
11
|
-
end
|
|
12
|
-
|
|
13
|
-
it "should be able to delete a message from the queue" do
|
|
14
|
-
message = @queue.pop
|
|
15
|
-
response = message.delete
|
|
16
|
-
response.must_equal true
|
|
17
|
-
assert message.frozen?
|
|
18
|
-
end
|
|
19
|
-
|
|
20
|
-
describe "Invalid delete operations" do
|
|
21
|
-
it "shouldn't be able to delete an expired message" do
|
|
22
|
-
skip "Docs say so but in fact this test it's not passing as of now"
|
|
23
|
-
|
|
24
|
-
Azure::Queues::Message.new("some sample text") do |message|
|
|
25
|
-
message.ttl = 1
|
|
26
|
-
end
|
|
27
|
-
|
|
28
|
-
message = @queue.pop
|
|
29
|
-
sleep 1
|
|
30
|
-
|
|
31
|
-
response = message.delete
|
|
32
|
-
response.must_equal false
|
|
33
|
-
end
|
|
34
|
-
|
|
35
|
-
it "shouldn't be able to delete an already deleted message" do
|
|
36
|
-
message = @queue.pop
|
|
37
|
-
message.delete
|
|
38
|
-
|
|
39
|
-
proc { message.delete }.must_raise RuntimeError
|
|
40
|
-
end
|
|
41
|
-
end
|
|
42
|
-
end
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Deleting a queue" do
|
|
4
|
-
after do
|
|
5
|
-
QueueNameHelper.clean
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
it "should return false if the queue cannot be deleted" do
|
|
9
|
-
queue = Azure::Queues::Queue.new(QueueNameHelper.name)
|
|
10
|
-
response = queue.delete
|
|
11
|
-
|
|
12
|
-
response.must_equal false
|
|
13
|
-
refute queue.valid?
|
|
14
|
-
refute queue.frozen?
|
|
15
|
-
end
|
|
16
|
-
|
|
17
|
-
it "should return true if the queue can be deleted" do
|
|
18
|
-
queue = Azure::Queues.create(QueueNameHelper.name)
|
|
19
|
-
response = queue.delete
|
|
20
|
-
|
|
21
|
-
response.must_equal true
|
|
22
|
-
assert queue.frozen?
|
|
23
|
-
end
|
|
24
|
-
end
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
require "integration/test_helper"
|
|
2
|
-
|
|
3
|
-
describe "Get Messages" do
|
|
4
|
-
after do
|
|
5
|
-
QueueNameHelper.clean
|
|
6
|
-
end
|
|
7
|
-
|
|
8
|
-
before do
|
|
9
|
-
@queue = Azure::Queues.create(QueueNameHelper.name)
|
|
10
|
-
end
|
|
11
|
-
|
|
12
|
-
it "gets the last message when calling #pop" do
|
|
13
|
-
@queue << "message 1"
|
|
14
|
-
@queue << "message 2"
|
|
15
|
-
|
|
16
|
-
message = @queue.pop
|
|
17
|
-
message.text.must_equal "message 1"
|
|
18
|
-
end
|
|
19
|
-
|
|
20
|
-
it "can get more than once message at a time" do
|
|
21
|
-
@queue << "message 1"
|
|
22
|
-
@queue << "message 2"
|
|
23
|
-
|
|
24
|
-
messages = @queue.get(5)
|
|
25
|
-
messages.must_respond_to :each
|
|
26
|
-
messages.size.must_equal 2
|
|
27
|
-
end
|
|
28
|
-
|
|
29
|
-
it "can reset the visibilitytimeout option for retrieved messages" do
|
|
30
|
-
@queue << "message 1"
|
|
31
|
-
|
|
32
|
-
message = @queue.pop(visibilitytimeout: 10)
|
|
33
|
-
|
|
34
|
-
next_visible_at = message.time_next_visible.to_i
|
|
35
|
-
inserted_at = message.insertion_time.to_i
|
|
36
|
-
|
|
37
|
-
next_visible_at.must_be_close_to(inserted_at + 10, 2.0)
|
|
38
|
-
end
|
|
39
|
-
end
|