stuartpreston-azure-sdk-for-ruby 0.7.1 → 0.7.2
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 +4 -4
- data/.gitignore +11 -11
- data/.travis.yml +10 -10
- data/ChangeLog.txt +70 -68
- data/Gemfile +15 -15
- data/README.md +618 -618
- data/Rakefile +133 -133
- data/azure.gemspec +44 -44
- data/lib/azure.rb +52 -52
- data/lib/azure/base_management/affinity_group.rb +32 -32
- data/lib/azure/base_management/base_management_service.rb +304 -304
- data/lib/azure/base_management/location.rb +27 -27
- data/lib/azure/base_management/management_http_request.rb +171 -171
- data/lib/azure/base_management/serialization.rb +129 -129
- data/lib/azure/base_management/sql_management_http_request.rb +45 -45
- data/lib/azure/blob/blob.rb +31 -31
- data/lib/azure/blob/blob_service.rb +1423 -1423
- data/lib/azure/blob/block.rb +30 -30
- data/lib/azure/blob/container.rb +31 -31
- data/lib/azure/blob/serialization.rb +284 -284
- data/lib/azure/cloud_service_management/cloud_service.rb +38 -38
- data/lib/azure/cloud_service_management/cloud_service_management_service.rb +140 -140
- data/lib/azure/cloud_service_management/serialization.rb +117 -117
- data/lib/azure/core.rb +39 -39
- data/lib/azure/core/auth/authorizer.rb +36 -36
- data/lib/azure/core/auth/shared_key.rb +110 -110
- data/lib/azure/core/auth/shared_key_lite.rb +48 -48
- data/lib/azure/core/auth/signer.rb +48 -48
- data/lib/azure/core/configuration.rb +211 -211
- data/lib/azure/core/error.rb +22 -22
- data/lib/azure/core/filtered_service.rb +43 -43
- data/lib/azure/core/http/debug_filter.rb +35 -35
- data/lib/azure/core/http/http_error.rb +88 -88
- data/lib/azure/core/http/http_filter.rb +52 -52
- data/lib/azure/core/http/http_request.rb +157 -157
- data/lib/azure/core/http/http_response.rb +140 -140
- data/lib/azure/core/http/retry_policy.rb +73 -73
- data/lib/azure/core/http/signer_filter.rb +33 -33
- data/lib/azure/core/service.rb +62 -62
- data/lib/azure/core/signed_service.rb +42 -42
- data/lib/azure/core/utility.rb +190 -190
- data/lib/azure/queue/message.rb +29 -29
- data/lib/azure/queue/queue.rb +28 -28
- data/lib/azure/queue/queue_service.rb +567 -567
- data/lib/azure/queue/serialization.rb +106 -106
- data/lib/azure/service/access_policy.rb +25 -25
- data/lib/azure/service/cors.rb +11 -11
- data/lib/azure/service/cors_rule.rb +15 -15
- data/lib/azure/service/enumeration_results.rb +20 -20
- data/lib/azure/service/logging.rb +31 -31
- data/lib/azure/service/metrics.rb +30 -30
- data/lib/azure/service/retention_policy.rb +24 -24
- data/lib/azure/service/serialization.rb +297 -297
- data/lib/azure/service/signed_identifier.rb +29 -29
- data/lib/azure/service/storage_service.rb +82 -82
- data/lib/azure/service/storage_service_properties.rb +37 -37
- data/lib/azure/service_bus/action.rb +21 -21
- data/lib/azure/service_bus/auth/wrap_service.rb +88 -88
- data/lib/azure/service_bus/auth/wrap_signer.rb +68 -68
- data/lib/azure/service_bus/brokered_message.rb +123 -123
- data/lib/azure/service_bus/brokered_message_serializer.rb +159 -159
- data/lib/azure/service_bus/correlation_filter.rb +45 -45
- data/lib/azure/service_bus/empty_rule_action.rb +29 -29
- data/lib/azure/service_bus/false_filter.rb +38 -38
- data/lib/azure/service_bus/filter.rb +21 -21
- data/lib/azure/service_bus/interval.rb +103 -103
- data/lib/azure/service_bus/queue.rb +229 -229
- data/lib/azure/service_bus/relay.rb +87 -87
- data/lib/azure/service_bus/resource.rb +108 -108
- data/lib/azure/service_bus/rule.rb +97 -97
- data/lib/azure/service_bus/rule_aspect.rb +34 -34
- data/lib/azure/service_bus/serialization.rb +161 -161
- data/lib/azure/service_bus/service_bus_service.rb +896 -896
- data/lib/azure/service_bus/sql_filter.rb +50 -50
- data/lib/azure/service_bus/sql_rule_action.rb +50 -50
- data/lib/azure/service_bus/subscription.rb +183 -183
- data/lib/azure/service_bus/topic.rb +186 -186
- data/lib/azure/service_bus/true_filter.rb +38 -38
- data/lib/azure/sql_database_management/serialization.rb +111 -111
- data/lib/azure/sql_database_management/sql_database.rb +31 -31
- data/lib/azure/sql_database_management/sql_database_management_service.rb +200 -200
- data/lib/azure/storage_management/serialization.rb +184 -184
- data/lib/azure/storage_management/storage_account.rb +40 -40
- data/lib/azure/storage_management/storage_management_service.rb +166 -166
- data/lib/azure/table/auth/shared_key.rb +92 -92
- data/lib/azure/table/auth/shared_key_lite.rb +44 -44
- data/lib/azure/table/batch.rb +329 -329
- data/lib/azure/table/batch_response.rb +118 -118
- data/lib/azure/table/edmtype.rb +126 -126
- data/lib/azure/table/entity.rb +30 -30
- data/lib/azure/table/guid.rb +23 -23
- data/lib/azure/table/query.rb +111 -111
- data/lib/azure/table/serialization.rb +107 -107
- data/lib/azure/table/table_service.rb +559 -559
- data/lib/azure/version.rb +31 -31
- data/lib/azure/virtual_machine_image_management/serialization.rb +66 -66
- data/lib/azure/virtual_machine_image_management/virtual_machine_disk.rb +25 -25
- data/lib/azure/virtual_machine_image_management/virtual_machine_image.rb +25 -25
- data/lib/azure/virtual_machine_image_management/virtual_machine_image_management_service.rb +94 -94
- data/lib/azure/virtual_machine_management/serialization.rb +462 -462
- data/lib/azure/virtual_machine_management/virtual_machine.rb +45 -45
- data/lib/azure/virtual_machine_management/virtual_machine_management_service.rb +588 -588
- data/lib/azure/virtual_network_management/serialization.rb +190 -190
- data/lib/azure/virtual_network_management/virtual_network.rb +37 -37
- data/lib/azure/virtual_network_management/virtual_network_management_service.rb +109 -109
- data/test/fixtures/affinity_group.xml +33 -33
- data/test/fixtures/all_containers.xml +20 -20
- data/test/fixtures/all_tables.xml +22 -22
- data/test/fixtures/certificate.pem +21 -21
- data/test/fixtures/container_acl.xml +11 -11
- data/test/fixtures/create_sql_database_server.xml +1 -1
- data/test/fixtures/create_storage_desc_error.xml +5 -5
- data/test/fixtures/create_storage_extendedprop_error.xml +8 -8
- data/test/fixtures/create_storage_extendedpropname_error.xml +6 -6
- data/test/fixtures/create_storage_full_error.xml +6 -6
- data/test/fixtures/create_storage_label_error.xml +5 -5
- data/test/fixtures/create_storage_location_error.xml +5 -5
- data/test/fixtures/create_storage_name_error.xml +6 -6
- data/test/fixtures/create_table_response_entry.xml +15 -15
- data/test/fixtures/delete_storage_container_error.xml +5 -5
- data/test/fixtures/delete_storage_error.xml +5 -5
- data/test/fixtures/deployment_error.xml +5 -5
- data/test/fixtures/get_storage_account_error.xml +5 -5
- data/test/fixtures/get_storage_account_properties.xml +31 -31
- data/test/fixtures/get_storage_account_properties_new.xml +31 -31
- data/test/fixtures/http_error.xml +5 -5
- data/test/fixtures/insert_entity_response_entry.xml +25 -25
- data/test/fixtures/list_affinity_groups.xml +22 -22
- data/test/fixtures/list_blobs.xml +120 -120
- data/test/fixtures/list_block_all_with_none_committed.xml +21 -21
- data/test/fixtures/list_blocks_all.xml +22 -22
- data/test/fixtures/list_blocks_committed.xml +12 -12
- data/test/fixtures/list_cloud_services.xml +38 -38
- data/test/fixtures/list_containers.xml +37 -37
- data/test/fixtures/list_firewall_management_endpoint.xml +27 -27
- data/test/fixtures/list_images.xml +110 -110
- data/test/fixtures/list_locations.xml +62 -62
- data/test/fixtures/list_page_ranges.xml +10 -10
- data/test/fixtures/list_sql_database.xml +36 -36
- data/test/fixtures/list_sql_server_firewall.xml +23 -23
- data/test/fixtures/list_storage_account_single.xml +24 -24
- data/test/fixtures/list_storage_accounts.xml +45 -45
- data/test/fixtures/list_virtual_networks.xml +92 -92
- data/test/fixtures/logging.xml +11 -11
- data/test/fixtures/management_certificate.pem +55 -55
- data/test/fixtures/messages.xml +12 -12
- data/test/fixtures/metrics.xml +10 -10
- data/test/fixtures/privatekey.key +28 -28
- data/test/fixtures/query_entities_empty_response.xml +7 -7
- data/test/fixtures/query_entities_response.xml +45 -45
- data/test/fixtures/queue_service_properties.xml +22 -22
- data/test/fixtures/queue_service_properties_original.xml +19 -19
- data/test/fixtures/queues.xml +16 -16
- data/test/fixtures/retention_policy.xml +5 -5
- data/test/fixtures/sb_default_create_queue_response.xml +23 -23
- data/test/fixtures/sb_default_create_relay_response.xml +15 -15
- data/test/fixtures/sb_default_create_topic_response.xml +18 -18
- data/test/fixtures/sb_get_access_token_response.txt +1 -1
- data/test/fixtures/sb_queues_runtime_peek_message_response_headers.txt +9 -9
- data/test/fixtures/storage_service_properties.xml +54 -54
- data/test/fixtures/update_storage_account.xml +16 -16
- data/test/fixtures/update_storage_error.xml +4 -4
- data/test/fixtures/updated_storage_accounts.xml +52 -52
- data/test/fixtures/virtual_machine.xml +113 -113
- data/test/fixtures/windows_virtual_machine.xml +106 -106
- data/test/integration/affinity_group/Affinity_test.rb +55 -55
- data/test/integration/affinity_group/Create_Affinity_test.rb +63 -63
- data/test/integration/affinity_group/Delete_Affinity_test.rb +56 -56
- data/test/integration/affinity_group/List_Affinity_test.rb +41 -41
- data/test/integration/affinity_group/Update_Affinity_test.rb +82 -82
- data/test/integration/blob/blob_gb18030_test.rb +199 -199
- data/test/integration/blob/blob_metadata_test.rb +75 -75
- data/test/integration/blob/blob_pages_test.rb +119 -119
- data/test/integration/blob/blob_properties_test.rb +77 -77
- data/test/integration/blob/block_blob_test.rb +254 -254
- data/test/integration/blob/container/container_acl_test.rb +69 -69
- data/test/integration/blob/container/container_metadata_test.rb +50 -50
- data/test/integration/blob/container/create_container_test.rb +60 -60
- data/test/integration/blob/container/delete_container_test.rb +39 -39
- data/test/integration/blob/container/get_container_properties_test.rb +48 -48
- data/test/integration/blob/container/list_containers_test.rb +79 -79
- data/test/integration/blob/container/root_container_test.rb +53 -53
- data/test/integration/blob/copy_blob_test.rb +113 -113
- data/test/integration/blob/create_blob_snapshot_test.rb +80 -80
- data/test/integration/blob/create_page_blob_test.rb +83 -83
- data/test/integration/blob/delete_blob_test.rb +159 -159
- data/test/integration/blob/get_blob_test.rb +65 -65
- data/test/integration/blob/informative_errors_test.rb +38 -38
- data/test/integration/blob/lease/acquire_lease_test.rb +36 -36
- data/test/integration/blob/lease/break_lease_test.rb +40 -40
- data/test/integration/blob/lease/release_lease_test.rb +40 -40
- data/test/integration/blob/lease/renew_lease_test.rb +42 -42
- data/test/integration/blob/list_blobs_test.rb +113 -113
- data/test/integration/cloud_service/Cloud_Create_test.rb +44 -44
- data/test/integration/cloud_service/Cloud_Delete_test.rb +44 -44
- data/test/integration/database/create_sql_server_firewall_test.rb +86 -86
- data/test/integration/database/create_sql_server_test.rb +53 -53
- data/test/integration/database/delete_sql_server_firewall_test.rb +70 -70
- data/test/integration/database/delete_sql_server_test.rb +58 -58
- data/test/integration/database/list_sql_server_firewall_test.rb +45 -45
- data/test/integration/database/list_sql_servers_test.rb +44 -44
- data/test/integration/database/reset_password_sql_server_test.rb +55 -55
- data/test/integration/location/Location_List_test.rb +39 -39
- data/test/integration/queue/clear_messages_test.rb +42 -42
- data/test/integration/queue/create_message_test.rb +75 -75
- data/test/integration/queue/create_queue_test.rb +50 -50
- data/test/integration/queue/delete_message_test.rb +67 -67
- data/test/integration/queue/delete_queue_test.rb +45 -45
- data/test/integration/queue/informative_errors_test.rb +41 -41
- data/test/integration/queue/list_messages_encoded_test.rb +79 -79
- data/test/integration/queue/list_messages_test.rb +79 -79
- data/test/integration/queue/list_queues_test.rb +44 -44
- data/test/integration/queue/peek_messages_test.rb +59 -59
- data/test/integration/queue/queue_gb18030_test.rb +131 -131
- data/test/integration/queue/queue_metadata_test.rb +40 -40
- data/test/integration/queue/update_message_test.rb +74 -74
- data/test/integration/service_bus/informative_errors_test.rb +36 -36
- data/test/integration/service_bus/queues_scenario_test.rb +200 -200
- data/test/integration/service_bus/queues_test.rb +265 -265
- data/test/integration/service_bus/relay_test.rb +131 -131
- data/test/integration/service_bus/rules_test.rb +144 -144
- data/test/integration/service_bus/sb_queue_gb18030_test.rb +182 -182
- data/test/integration/service_bus/scenario_test.rb +101 -101
- data/test/integration/service_bus/subscriptions_test.rb +211 -211
- data/test/integration/service_bus/topics_scenario_test.rb +406 -406
- data/test/integration/service_bus/topics_test.rb +129 -129
- data/test/integration/storage_management/storage_management_test.rb +160 -160
- data/test/integration/table/create_table_test.rb +35 -35
- data/test/integration/table/delete_entity_batch_test.rb +106 -106
- data/test/integration/table/delete_entity_test.rb +93 -93
- data/test/integration/table/delete_table_test.rb +39 -39
- data/test/integration/table/get_table_test.rb +36 -36
- data/test/integration/table/informative_errors_test.rb +38 -38
- data/test/integration/table/insert_entity_batch_test.rb +99 -99
- data/test/integration/table/insert_entity_test.rb +87 -87
- data/test/integration/table/insert_or_merge_entity_batch_test.rb +158 -158
- data/test/integration/table/insert_or_merge_entity_test.rb +142 -142
- data/test/integration/table/insert_or_replace_entity_batch_test.rb +151 -151
- data/test/integration/table/insert_or_replace_entity_test.rb +136 -136
- data/test/integration/table/merge_entity_batch_test.rb +127 -127
- data/test/integration/table/merge_entity_test.rb +112 -112
- data/test/integration/table/query_entities_test.rb +194 -194
- data/test/integration/table/query_tables_test.rb +42 -42
- data/test/integration/table/query_test.rb +250 -250
- data/test/integration/table/table_acl_test.rb +51 -51
- data/test/integration/table/table_gb18030_test.rb +355 -355
- data/test/integration/table/update_entity_batch_test.rb +148 -148
- data/test/integration/table/update_entity_test.rb +130 -130
- data/test/integration/test_helper.rb +42 -42
- data/test/integration/vm/VM_Create_test.rb +260 -260
- data/test/integration/vm/VM_Delete_test.rb +55 -55
- data/test/integration/vm/VM_Operations_test.rb +173 -173
- data/test/integration/vm_image/virtual_machine_disk_test.rb +37 -37
- data/test/integration/vm_image/virtual_machine_image_test.rb +36 -36
- data/test/integration/vnet/Virtual_Network_Create_test.rb +122 -122
- data/test/integration/vnet/Virtual_Network_list_test.rb +53 -53
- data/test/support/env.rb +19 -19
- data/test/support/fixtures.rb +36 -36
- data/test/support/name_generator.rb +168 -168
- data/test/support/stubs.rb +42 -42
- data/test/support/virtual_machine_name_generator.rb +102 -102
- data/test/support/virtual_network_helper.rb +73 -73
- data/test/test_helper.rb +53 -53
- data/test/unit/affinity_group/affinity_group_test.rb +192 -192
- data/test/unit/affinity_group/serialization_test.rb +88 -88
- data/test/unit/base_management/location_test.rb +57 -57
- data/test/unit/blob/blob_service_test.rb +1946 -1946
- data/test/unit/cloud_service_management/cloud_service_management_service_test.rb +94 -94
- data/test/unit/cloud_service_management/serialization_test.rb +169 -169
- data/test/unit/core/auth/shared_key_lite_test.rb +51 -51
- data/test/unit/core/auth/shared_key_test.rb +58 -58
- data/test/unit/core/auth/signer_test.rb +30 -30
- data/test/unit/core/http/http_error_test.rb +57 -57
- data/test/unit/core/http/http_request_test.rb +66 -66
- data/test/unit/core/http/http_response_test.rb +45 -45
- data/test/unit/core/http/retry_policy_test.rb +23 -23
- data/test/unit/database/serialization_test.rb +97 -97
- data/test/unit/database/sql_database_server_service_test.rb +288 -288
- data/test/unit/service/serialization_test.rb +532 -532
- data/test/unit/service/storage_service_test.rb +292 -292
- data/test/unit/storage_management/serialization_test.rb +232 -232
- data/test/unit/storage_management/storage_management_service_test.rb +261 -261
- data/test/unit/table/edmtype_test.rb +107 -107
- data/test/unit/virtual_machine_image_management/serialization_test.rb +35 -35
- data/test/unit/virtual_machine_image_management/virtual_machine_image_management_service_test.rb +65 -65
- data/test/unit/virtual_machine_management/serialization_test.rb +258 -258
- data/test/unit/virtual_machine_management/virtual_machine_management_service_test.rb +440 -440
- data/test/unit/vnet/serialization_test.rb +187 -187
- data/test/unit/vnet/virtual_network_management_service_test.rb +131 -131
- metadata +34 -27
@@ -1,261 +1,261 @@
|
|
1
|
-
#-------------------------------------------------------------------------
|
2
|
-
# Copyright 2013 Microsoft Open Technologies, Inc.
|
3
|
-
#
|
4
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
-
# you may not use this file except in compliance with the License.
|
6
|
-
# You may obtain a copy of the License at
|
7
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
-
#
|
9
|
-
# Unless required by applicable law or agreed to in writing, software
|
10
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
-
# See the License for the specific language governing permissions and
|
13
|
-
# limitations under the License.
|
14
|
-
#--------------------------------------------------------------------------
|
15
|
-
require "test_helper"
|
16
|
-
|
17
|
-
describe Azure::StorageManagementService do
|
18
|
-
|
19
|
-
subject { Azure::StorageManagementService.new }
|
20
|
-
let(:request_path) {'/services/storageservices'}
|
21
|
-
let(:storage_accounts_xml) { Fixtures["list_storage_accounts"] }
|
22
|
-
let(:one_storage_account_xml) { Fixtures['list_storage_account_single']}
|
23
|
-
let(:method) { :get }
|
24
|
-
let(:mock_request){ mock() }
|
25
|
-
|
26
|
-
let(:response) {
|
27
|
-
response = mock()
|
28
|
-
response.stubs(:body).returns(storage_accounts_xml)
|
29
|
-
response
|
30
|
-
}
|
31
|
-
|
32
|
-
let(:single_response) {
|
33
|
-
single_response = mock()
|
34
|
-
single_response.stubs(:body).returns(one_storage_account_xml)
|
35
|
-
single_response
|
36
|
-
}
|
37
|
-
|
38
|
-
let(:response_body) {Nokogiri::XML response.body}
|
39
|
-
let(:single_response_body) { Nokogiri::XML single_response.body }
|
40
|
-
|
41
|
-
before{
|
42
|
-
Loggerx.expects(:puts).returns(nil).at_least(0)
|
43
|
-
}
|
44
|
-
|
45
|
-
describe "#list_storage_accounts" do
|
46
|
-
before {
|
47
|
-
ManagementHttpRequest.stubs(:new).with(method, request_path, nil).returns(mock_request)
|
48
|
-
mock_request.expects(:call).returns(response_body)
|
49
|
-
}
|
50
|
-
|
51
|
-
it "assembles a URI for the request" do
|
52
|
-
subject.list_storage_accounts
|
53
|
-
end
|
54
|
-
|
55
|
-
it "sets the properties of the storage accounts" do
|
56
|
-
storage_account = subject.list_storage_accounts.first
|
57
|
-
storage_account.name.must_equal 'storage1'
|
58
|
-
end
|
59
|
-
|
60
|
-
it "returns a list of storage accounts for the subscription" do
|
61
|
-
results = subject.list_storage_accounts
|
62
|
-
results.must_be_kind_of Array
|
63
|
-
results.length.must_equal 2
|
64
|
-
results.first.must_be_kind_of Azure::StorageManagement::StorageAccount
|
65
|
-
end
|
66
|
-
end
|
67
|
-
|
68
|
-
describe "#list_storage_accounts_single" do
|
69
|
-
before {
|
70
|
-
ManagementHttpRequest.stubs(:new).with(
|
71
|
-
method, request_path, nil
|
72
|
-
).returns(mock_request)
|
73
|
-
mock_request.expects(:call).returns(single_response_body)
|
74
|
-
}
|
75
|
-
|
76
|
-
it "returns an array even if single account exists" do
|
77
|
-
results = subject.list_storage_accounts
|
78
|
-
results.must_be_kind_of Array
|
79
|
-
results.length.must_equal 1
|
80
|
-
results.first.must_be_kind_of Azure::StorageManagement::StorageAccount
|
81
|
-
results.first.name.must_equal 'storage1'
|
82
|
-
end
|
83
|
-
end
|
84
|
-
|
85
|
-
describe "#get_storage_account" do
|
86
|
-
before {
|
87
|
-
ManagementHttpRequest.stubs(:new).with(method, request_path, nil).returns(mock_request)
|
88
|
-
mock_request.expects(:call).returns(response_body)
|
89
|
-
}
|
90
|
-
|
91
|
-
it "assembles a URI for the request" do
|
92
|
-
subject.get_storage_account 'storage1'
|
93
|
-
end
|
94
|
-
|
95
|
-
it "returns true if found storage account with given name" do
|
96
|
-
result = subject.get_storage_account 'storage1'
|
97
|
-
result.must_equal true
|
98
|
-
end
|
99
|
-
|
100
|
-
it "returns false if storage account with given name doesn't exists" do
|
101
|
-
result = subject.get_storage_account 'storage3'
|
102
|
-
result.must_equal false
|
103
|
-
end
|
104
|
-
end
|
105
|
-
|
106
|
-
describe "#create_storage_account" do
|
107
|
-
let(:options) {
|
108
|
-
{
|
109
|
-
location: 'East Asia',
|
110
|
-
description: 'Test Storage Description'
|
111
|
-
}
|
112
|
-
}
|
113
|
-
|
114
|
-
it 'Checks if name is provided' do
|
115
|
-
exception = assert_raises(RuntimeError) do
|
116
|
-
subject.create_storage_account(options)
|
117
|
-
end
|
118
|
-
assert_match('Name not specified', exception.message)
|
119
|
-
end
|
120
|
-
|
121
|
-
it 'Checks if name is not nil' do
|
122
|
-
exception = assert_raises(RuntimeError) do
|
123
|
-
subject.create_storage_account('', options)
|
124
|
-
end
|
125
|
-
assert_match('Name not specified', exception.message)
|
126
|
-
end
|
127
|
-
|
128
|
-
it 'Checks if name is not empty' do
|
129
|
-
exception = assert_raises(RuntimeError) do
|
130
|
-
subject.create_storage_account('', options)
|
131
|
-
end
|
132
|
-
assert_match('Name not specified', exception.message)
|
133
|
-
end
|
134
|
-
|
135
|
-
it "Create storage account return message if storage account exists of given name." do
|
136
|
-
ManagementHttpRequest.any_instance.expects(:call).returns response_body
|
137
|
-
msg = subject.create_storage_account 'storage1'
|
138
|
-
assert_match(/^Storage Account storage1 already exist.*/, msg)
|
139
|
-
end
|
140
|
-
|
141
|
-
it "Create storage account if storage account doesn't exists of given name." do
|
142
|
-
Azure::StorageManagementService.any_instance.stubs(:get_storage_account).with('storage3').returns(false)
|
143
|
-
ManagementHttpRequest.any_instance.expects(:call).returns nil
|
144
|
-
subject.create_storage_account 'storage3'
|
145
|
-
end
|
146
|
-
|
147
|
-
end
|
148
|
-
|
149
|
-
describe "#update_storage_account" do
|
150
|
-
let(:updated_accounts_xml) { Fixtures["updated_storage_accounts"] }
|
151
|
-
let(:no_options_specified) { 'No options specified' }
|
152
|
-
let(:update_storage_account_req) { Fixtures["update_storage_account"] }
|
153
|
-
|
154
|
-
let(:updated_storage_account_mock_request){ mock() }
|
155
|
-
let(:updated_storage_account_response) {
|
156
|
-
updated_storage_account_response = mock()
|
157
|
-
updated_storage_account_response.stubs(:body).returns(updated_accounts_xml)
|
158
|
-
updated_storage_account_response
|
159
|
-
}
|
160
|
-
let(:updated_storage_account_response_body) {Nokogiri::XML updated_storage_account_response.body}
|
161
|
-
|
162
|
-
let(:update_request) {
|
163
|
-
update_request = mock()
|
164
|
-
update_request.stubs(:body).returns('')
|
165
|
-
update_request
|
166
|
-
}
|
167
|
-
|
168
|
-
before {
|
169
|
-
ManagementHttpRequest.stubs(:new).with(method, request_path, nil).returns(mock_request)
|
170
|
-
mock_request.expects(:call).returns(response_body)
|
171
|
-
|
172
|
-
Azure::StorageManagement::Serialization.stubs(:update_storage_account).returns(update_storage_account_req)
|
173
|
-
}
|
174
|
-
|
175
|
-
let(:options) { {
|
176
|
-
description: 'Test Description',
|
177
|
-
label: 'Test Label',
|
178
|
-
geo_replication_enabled: false,
|
179
|
-
extended_properties: {
|
180
|
-
prop_1_name: 'prop_1_value',
|
181
|
-
prop_2_name: 'prop_2_value'
|
182
|
-
}
|
183
|
-
}
|
184
|
-
}
|
185
|
-
|
186
|
-
it "checks if nil options is provided" do
|
187
|
-
exception = assert_raises RuntimeError do
|
188
|
-
subject.update_storage_account 'storage2', nil
|
189
|
-
end
|
190
|
-
assert_match no_options_specified, exception.message
|
191
|
-
end
|
192
|
-
|
193
|
-
it "checks if empty options is provided" do
|
194
|
-
exception = assert_raises RuntimeError do
|
195
|
-
subject.update_storage_account 'storage2', Hash.new
|
196
|
-
end
|
197
|
-
assert_match no_options_specified, exception.message
|
198
|
-
end
|
199
|
-
|
200
|
-
it "checks if account exists before updating" do
|
201
|
-
ret_val = subject.update_storage_account 'storage3', Hash.new
|
202
|
-
ret_val.must_equal "Storage Account 'storage3' does not exist. Skipped..."
|
203
|
-
end
|
204
|
-
|
205
|
-
it "updates the specified account" do
|
206
|
-
ManagementHttpRequest.stubs(:new).with(:put, "#{request_path}/storage2", update_storage_account_req).returns(update_request)
|
207
|
-
update_request.expects(:call).returns('')
|
208
|
-
|
209
|
-
subject.update_storage_account 'storage2', options
|
210
|
-
|
211
|
-
ManagementHttpRequest.stubs(:new).with(method, request_path, nil).returns(updated_storage_account_mock_request)
|
212
|
-
updated_storage_account_mock_request.expects(:call).returns(updated_storage_account_response_body)
|
213
|
-
|
214
|
-
accounts = subject.list_storage_accounts
|
215
|
-
|
216
|
-
accounts.each { |account|
|
217
|
-
next unless account.name == 'storage2'
|
218
|
-
|
219
|
-
account.name.must_equal 'storage2'
|
220
|
-
account.label.must_equal options[:label]
|
221
|
-
account.geo_replication_enabled.must_equal "#{options[:geo_replication_enabled]}"
|
222
|
-
|
223
|
-
account.extended_properties.each { |prop|
|
224
|
-
prop[:value].must_equal "#{options[:extended_properties][:"#{prop[:name]}"]}"
|
225
|
-
}
|
226
|
-
}
|
227
|
-
end
|
228
|
-
end
|
229
|
-
|
230
|
-
describe '#get_storage_account_properties' do
|
231
|
-
let(:account_name) { 'storage2' }
|
232
|
-
let(:label) { 'ValidLabel' }
|
233
|
-
let(:request_path) { "/services/storageservices/#{account_name}" }
|
234
|
-
let(:account_xml) { Fixtures['get_storage_account_properties'] }
|
235
|
-
|
236
|
-
let(:get_account_mock_request) { mock() }
|
237
|
-
let(:get_account_response) {
|
238
|
-
get_account_response = mock()
|
239
|
-
get_account_response.stubs(:body).returns(account_xml)
|
240
|
-
get_account_response
|
241
|
-
}
|
242
|
-
let(:get_account_response_body) {
|
243
|
-
Nokogiri::XML(get_account_response.body)
|
244
|
-
}
|
245
|
-
|
246
|
-
before {
|
247
|
-
ManagementHttpRequest.stubs(:new).with(
|
248
|
-
:get, request_path, nil
|
249
|
-
).returns(get_account_mock_request)
|
250
|
-
get_account_mock_request.expects(:call).returns(
|
251
|
-
get_account_response_body
|
252
|
-
)
|
253
|
-
}
|
254
|
-
|
255
|
-
it 'returns the label as a Base64 decoded string' do
|
256
|
-
account = subject.get_storage_account_properties(account_name)
|
257
|
-
account.label.must_be_kind_of(String)
|
258
|
-
account.label.must_equal(label)
|
259
|
-
end
|
260
|
-
end
|
261
|
-
end
|
1
|
+
#-------------------------------------------------------------------------
|
2
|
+
# Copyright 2013 Microsoft Open Technologies, Inc.
|
3
|
+
#
|
4
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
5
|
+
# you may not use this file except in compliance with the License.
|
6
|
+
# You may obtain a copy of the License at
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
+
#
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
+
# See the License for the specific language governing permissions and
|
13
|
+
# limitations under the License.
|
14
|
+
#--------------------------------------------------------------------------
|
15
|
+
require "test_helper"
|
16
|
+
|
17
|
+
describe Azure::StorageManagementService do
|
18
|
+
|
19
|
+
subject { Azure::StorageManagementService.new }
|
20
|
+
let(:request_path) {'/services/storageservices'}
|
21
|
+
let(:storage_accounts_xml) { Fixtures["list_storage_accounts"] }
|
22
|
+
let(:one_storage_account_xml) { Fixtures['list_storage_account_single']}
|
23
|
+
let(:method) { :get }
|
24
|
+
let(:mock_request){ mock() }
|
25
|
+
|
26
|
+
let(:response) {
|
27
|
+
response = mock()
|
28
|
+
response.stubs(:body).returns(storage_accounts_xml)
|
29
|
+
response
|
30
|
+
}
|
31
|
+
|
32
|
+
let(:single_response) {
|
33
|
+
single_response = mock()
|
34
|
+
single_response.stubs(:body).returns(one_storage_account_xml)
|
35
|
+
single_response
|
36
|
+
}
|
37
|
+
|
38
|
+
let(:response_body) {Nokogiri::XML response.body}
|
39
|
+
let(:single_response_body) { Nokogiri::XML single_response.body }
|
40
|
+
|
41
|
+
before{
|
42
|
+
Loggerx.expects(:puts).returns(nil).at_least(0)
|
43
|
+
}
|
44
|
+
|
45
|
+
describe "#list_storage_accounts" do
|
46
|
+
before {
|
47
|
+
ManagementHttpRequest.stubs(:new).with(method, request_path, nil).returns(mock_request)
|
48
|
+
mock_request.expects(:call).returns(response_body)
|
49
|
+
}
|
50
|
+
|
51
|
+
it "assembles a URI for the request" do
|
52
|
+
subject.list_storage_accounts
|
53
|
+
end
|
54
|
+
|
55
|
+
it "sets the properties of the storage accounts" do
|
56
|
+
storage_account = subject.list_storage_accounts.first
|
57
|
+
storage_account.name.must_equal 'storage1'
|
58
|
+
end
|
59
|
+
|
60
|
+
it "returns a list of storage accounts for the subscription" do
|
61
|
+
results = subject.list_storage_accounts
|
62
|
+
results.must_be_kind_of Array
|
63
|
+
results.length.must_equal 2
|
64
|
+
results.first.must_be_kind_of Azure::StorageManagement::StorageAccount
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
describe "#list_storage_accounts_single" do
|
69
|
+
before {
|
70
|
+
ManagementHttpRequest.stubs(:new).with(
|
71
|
+
method, request_path, nil
|
72
|
+
).returns(mock_request)
|
73
|
+
mock_request.expects(:call).returns(single_response_body)
|
74
|
+
}
|
75
|
+
|
76
|
+
it "returns an array even if single account exists" do
|
77
|
+
results = subject.list_storage_accounts
|
78
|
+
results.must_be_kind_of Array
|
79
|
+
results.length.must_equal 1
|
80
|
+
results.first.must_be_kind_of Azure::StorageManagement::StorageAccount
|
81
|
+
results.first.name.must_equal 'storage1'
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
describe "#get_storage_account" do
|
86
|
+
before {
|
87
|
+
ManagementHttpRequest.stubs(:new).with(method, request_path, nil).returns(mock_request)
|
88
|
+
mock_request.expects(:call).returns(response_body)
|
89
|
+
}
|
90
|
+
|
91
|
+
it "assembles a URI for the request" do
|
92
|
+
subject.get_storage_account 'storage1'
|
93
|
+
end
|
94
|
+
|
95
|
+
it "returns true if found storage account with given name" do
|
96
|
+
result = subject.get_storage_account 'storage1'
|
97
|
+
result.must_equal true
|
98
|
+
end
|
99
|
+
|
100
|
+
it "returns false if storage account with given name doesn't exists" do
|
101
|
+
result = subject.get_storage_account 'storage3'
|
102
|
+
result.must_equal false
|
103
|
+
end
|
104
|
+
end
|
105
|
+
|
106
|
+
describe "#create_storage_account" do
|
107
|
+
let(:options) {
|
108
|
+
{
|
109
|
+
location: 'East Asia',
|
110
|
+
description: 'Test Storage Description'
|
111
|
+
}
|
112
|
+
}
|
113
|
+
|
114
|
+
it 'Checks if name is provided' do
|
115
|
+
exception = assert_raises(RuntimeError) do
|
116
|
+
subject.create_storage_account(options)
|
117
|
+
end
|
118
|
+
assert_match('Name not specified', exception.message)
|
119
|
+
end
|
120
|
+
|
121
|
+
it 'Checks if name is not nil' do
|
122
|
+
exception = assert_raises(RuntimeError) do
|
123
|
+
subject.create_storage_account('', options)
|
124
|
+
end
|
125
|
+
assert_match('Name not specified', exception.message)
|
126
|
+
end
|
127
|
+
|
128
|
+
it 'Checks if name is not empty' do
|
129
|
+
exception = assert_raises(RuntimeError) do
|
130
|
+
subject.create_storage_account('', options)
|
131
|
+
end
|
132
|
+
assert_match('Name not specified', exception.message)
|
133
|
+
end
|
134
|
+
|
135
|
+
it "Create storage account return message if storage account exists of given name." do
|
136
|
+
ManagementHttpRequest.any_instance.expects(:call).returns response_body
|
137
|
+
msg = subject.create_storage_account 'storage1'
|
138
|
+
assert_match(/^Storage Account storage1 already exist.*/, msg)
|
139
|
+
end
|
140
|
+
|
141
|
+
it "Create storage account if storage account doesn't exists of given name." do
|
142
|
+
Azure::StorageManagementService.any_instance.stubs(:get_storage_account).with('storage3').returns(false)
|
143
|
+
ManagementHttpRequest.any_instance.expects(:call).returns nil
|
144
|
+
subject.create_storage_account 'storage3'
|
145
|
+
end
|
146
|
+
|
147
|
+
end
|
148
|
+
|
149
|
+
describe "#update_storage_account" do
|
150
|
+
let(:updated_accounts_xml) { Fixtures["updated_storage_accounts"] }
|
151
|
+
let(:no_options_specified) { 'No options specified' }
|
152
|
+
let(:update_storage_account_req) { Fixtures["update_storage_account"] }
|
153
|
+
|
154
|
+
let(:updated_storage_account_mock_request){ mock() }
|
155
|
+
let(:updated_storage_account_response) {
|
156
|
+
updated_storage_account_response = mock()
|
157
|
+
updated_storage_account_response.stubs(:body).returns(updated_accounts_xml)
|
158
|
+
updated_storage_account_response
|
159
|
+
}
|
160
|
+
let(:updated_storage_account_response_body) {Nokogiri::XML updated_storage_account_response.body}
|
161
|
+
|
162
|
+
let(:update_request) {
|
163
|
+
update_request = mock()
|
164
|
+
update_request.stubs(:body).returns('')
|
165
|
+
update_request
|
166
|
+
}
|
167
|
+
|
168
|
+
before {
|
169
|
+
ManagementHttpRequest.stubs(:new).with(method, request_path, nil).returns(mock_request)
|
170
|
+
mock_request.expects(:call).returns(response_body)
|
171
|
+
|
172
|
+
Azure::StorageManagement::Serialization.stubs(:update_storage_account).returns(update_storage_account_req)
|
173
|
+
}
|
174
|
+
|
175
|
+
let(:options) { {
|
176
|
+
description: 'Test Description',
|
177
|
+
label: 'Test Label',
|
178
|
+
geo_replication_enabled: false,
|
179
|
+
extended_properties: {
|
180
|
+
prop_1_name: 'prop_1_value',
|
181
|
+
prop_2_name: 'prop_2_value'
|
182
|
+
}
|
183
|
+
}
|
184
|
+
}
|
185
|
+
|
186
|
+
it "checks if nil options is provided" do
|
187
|
+
exception = assert_raises RuntimeError do
|
188
|
+
subject.update_storage_account 'storage2', nil
|
189
|
+
end
|
190
|
+
assert_match no_options_specified, exception.message
|
191
|
+
end
|
192
|
+
|
193
|
+
it "checks if empty options is provided" do
|
194
|
+
exception = assert_raises RuntimeError do
|
195
|
+
subject.update_storage_account 'storage2', Hash.new
|
196
|
+
end
|
197
|
+
assert_match no_options_specified, exception.message
|
198
|
+
end
|
199
|
+
|
200
|
+
it "checks if account exists before updating" do
|
201
|
+
ret_val = subject.update_storage_account 'storage3', Hash.new
|
202
|
+
ret_val.must_equal "Storage Account 'storage3' does not exist. Skipped..."
|
203
|
+
end
|
204
|
+
|
205
|
+
it "updates the specified account" do
|
206
|
+
ManagementHttpRequest.stubs(:new).with(:put, "#{request_path}/storage2", update_storage_account_req).returns(update_request)
|
207
|
+
update_request.expects(:call).returns('')
|
208
|
+
|
209
|
+
subject.update_storage_account 'storage2', options
|
210
|
+
|
211
|
+
ManagementHttpRequest.stubs(:new).with(method, request_path, nil).returns(updated_storage_account_mock_request)
|
212
|
+
updated_storage_account_mock_request.expects(:call).returns(updated_storage_account_response_body)
|
213
|
+
|
214
|
+
accounts = subject.list_storage_accounts
|
215
|
+
|
216
|
+
accounts.each { |account|
|
217
|
+
next unless account.name == 'storage2'
|
218
|
+
|
219
|
+
account.name.must_equal 'storage2'
|
220
|
+
account.label.must_equal options[:label]
|
221
|
+
account.geo_replication_enabled.must_equal "#{options[:geo_replication_enabled]}"
|
222
|
+
|
223
|
+
account.extended_properties.each { |prop|
|
224
|
+
prop[:value].must_equal "#{options[:extended_properties][:"#{prop[:name]}"]}"
|
225
|
+
}
|
226
|
+
}
|
227
|
+
end
|
228
|
+
end
|
229
|
+
|
230
|
+
describe '#get_storage_account_properties' do
|
231
|
+
let(:account_name) { 'storage2' }
|
232
|
+
let(:label) { 'ValidLabel' }
|
233
|
+
let(:request_path) { "/services/storageservices/#{account_name}" }
|
234
|
+
let(:account_xml) { Fixtures['get_storage_account_properties'] }
|
235
|
+
|
236
|
+
let(:get_account_mock_request) { mock() }
|
237
|
+
let(:get_account_response) {
|
238
|
+
get_account_response = mock()
|
239
|
+
get_account_response.stubs(:body).returns(account_xml)
|
240
|
+
get_account_response
|
241
|
+
}
|
242
|
+
let(:get_account_response_body) {
|
243
|
+
Nokogiri::XML(get_account_response.body)
|
244
|
+
}
|
245
|
+
|
246
|
+
before {
|
247
|
+
ManagementHttpRequest.stubs(:new).with(
|
248
|
+
:get, request_path, nil
|
249
|
+
).returns(get_account_mock_request)
|
250
|
+
get_account_mock_request.expects(:call).returns(
|
251
|
+
get_account_response_body
|
252
|
+
)
|
253
|
+
}
|
254
|
+
|
255
|
+
it 'returns the label as a Base64 decoded string' do
|
256
|
+
account = subject.get_storage_account_properties(account_name)
|
257
|
+
account.label.must_be_kind_of(String)
|
258
|
+
account.label.must_equal(label)
|
259
|
+
end
|
260
|
+
end
|
261
|
+
end
|