azure 0.6.0 → 0.6.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (283) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +11 -11
  3. data/.travis.yml +11 -33
  4. data/ChangeLog.txt +20 -5
  5. data/Gemfile +15 -15
  6. data/README.md +541 -537
  7. data/Rakefile +129 -127
  8. data/azure.gemspec +43 -42
  9. data/lib/azure.rb +52 -51
  10. data/lib/azure/base_management/affinity_group.rb +32 -32
  11. data/lib/azure/base_management/base_management_service.rb +234 -234
  12. data/lib/azure/base_management/location.rb +27 -27
  13. data/lib/azure/base_management/management_http_request.rb +171 -148
  14. data/lib/azure/base_management/serialization.rb +129 -129
  15. data/lib/azure/base_management/sql_management_http_request.rb +45 -0
  16. data/lib/azure/blob/blob.rb +31 -31
  17. data/lib/azure/blob/blob_service.rb +1423 -1423
  18. data/lib/azure/blob/block.rb +30 -30
  19. data/lib/azure/blob/container.rb +31 -31
  20. data/lib/azure/blob/serialization.rb +284 -284
  21. data/lib/azure/cloud_service_management/cloud_service.rb +38 -31
  22. data/lib/azure/cloud_service_management/cloud_service_management_service.rb +134 -125
  23. data/lib/azure/cloud_service_management/serialization.rb +101 -63
  24. data/lib/azure/core.rb +39 -36
  25. data/lib/azure/core/auth/authorizer.rb +36 -36
  26. data/lib/azure/core/auth/shared_key.rb +110 -110
  27. data/lib/azure/core/auth/shared_key_lite.rb +48 -48
  28. data/lib/azure/core/auth/signer.rb +48 -48
  29. data/lib/azure/core/configuration.rb +211 -184
  30. data/lib/azure/core/error.rb +22 -22
  31. data/lib/azure/core/filtered_service.rb +43 -43
  32. data/lib/azure/core/http/debug_filter.rb +35 -35
  33. data/lib/azure/core/http/http_error.rb +88 -88
  34. data/lib/azure/core/http/http_filter.rb +52 -52
  35. data/lib/azure/core/http/http_request.rb +157 -157
  36. data/lib/azure/core/http/http_response.rb +140 -140
  37. data/lib/azure/core/http/retry_policy.rb +73 -73
  38. data/lib/azure/core/http/signer_filter.rb +33 -33
  39. data/lib/azure/core/service.rb +62 -62
  40. data/lib/azure/core/signed_service.rb +42 -42
  41. data/lib/azure/core/utility.rb +190 -190
  42. data/lib/azure/queue/message.rb +29 -29
  43. data/lib/azure/queue/queue.rb +28 -28
  44. data/lib/azure/queue/queue_service.rb +567 -567
  45. data/lib/azure/queue/serialization.rb +106 -106
  46. data/lib/azure/service/access_policy.rb +25 -25
  47. data/lib/azure/service/enumeration_results.rb +20 -20
  48. data/lib/azure/service/logging.rb +31 -31
  49. data/lib/azure/service/metrics.rb +30 -30
  50. data/lib/azure/service/retention_policy.rb +24 -24
  51. data/lib/azure/service/serialization.rb +239 -239
  52. data/lib/azure/service/signed_identifier.rb +29 -29
  53. data/lib/azure/service/storage_service.rb +78 -78
  54. data/lib/azure/service/storage_service_properties.rb +31 -31
  55. data/lib/azure/service_bus/action.rb +21 -21
  56. data/lib/azure/service_bus/auth/wrap_service.rb +88 -88
  57. data/lib/azure/service_bus/auth/wrap_signer.rb +68 -68
  58. data/lib/azure/service_bus/brokered_message.rb +123 -123
  59. data/lib/azure/service_bus/brokered_message_serializer.rb +159 -159
  60. data/lib/azure/service_bus/correlation_filter.rb +45 -45
  61. data/lib/azure/service_bus/empty_rule_action.rb +29 -29
  62. data/lib/azure/service_bus/false_filter.rb +38 -38
  63. data/lib/azure/service_bus/filter.rb +21 -21
  64. data/lib/azure/service_bus/interval.rb +103 -103
  65. data/lib/azure/service_bus/queue.rb +229 -229
  66. data/lib/azure/service_bus/resource.rb +108 -108
  67. data/lib/azure/service_bus/rule.rb +97 -97
  68. data/lib/azure/service_bus/rule_aspect.rb +34 -34
  69. data/lib/azure/service_bus/serialization.rb +160 -160
  70. data/lib/azure/service_bus/service_bus_service.rb +828 -828
  71. data/lib/azure/service_bus/sql_filter.rb +50 -50
  72. data/lib/azure/service_bus/sql_rule_action.rb +50 -50
  73. data/lib/azure/service_bus/subscription.rb +183 -183
  74. data/lib/azure/service_bus/topic.rb +186 -186
  75. data/lib/azure/service_bus/true_filter.rb +38 -38
  76. data/lib/azure/sql_database_management/serialization.rb +111 -90
  77. data/lib/azure/sql_database_management/sql_database.rb +31 -31
  78. data/lib/azure/sql_database_management/sql_database_management_service.rb +200 -202
  79. data/lib/azure/storage_management/serialization.rb +190 -50
  80. data/lib/azure/storage_management/storage_account.rb +40 -29
  81. data/lib/azure/storage_management/storage_management_service.rb +166 -99
  82. data/lib/azure/table/auth/shared_key.rb +92 -92
  83. data/lib/azure/table/auth/shared_key_lite.rb +44 -44
  84. data/lib/azure/table/batch.rb +329 -329
  85. data/lib/azure/table/batch_response.rb +118 -118
  86. data/lib/azure/table/edmtype.rb +126 -126
  87. data/lib/azure/table/entity.rb +30 -30
  88. data/lib/azure/table/guid.rb +23 -23
  89. data/lib/azure/table/query.rb +111 -111
  90. data/lib/azure/table/serialization.rb +107 -107
  91. data/lib/azure/table/table_service.rb +559 -559
  92. data/lib/azure/version.rb +30 -30
  93. data/lib/azure/virtual_machine_image_management/serialization.rb +49 -49
  94. data/lib/azure/virtual_machine_image_management/virtual_machine_disk.rb +27 -27
  95. data/lib/azure/virtual_machine_image_management/virtual_machine_image.rb +27 -27
  96. data/lib/azure/virtual_machine_image_management/virtual_machine_image_management_service.rb +66 -66
  97. data/lib/azure/virtual_machine_management/serialization.rb +257 -247
  98. data/lib/azure/virtual_machine_management/virtual_machine.rb +41 -57
  99. data/lib/azure/virtual_machine_management/virtual_machine_management_service.rb +317 -304
  100. data/lib/azure/virtual_network_management/serialization.rb +186 -186
  101. data/lib/azure/virtual_network_management/virtual_network.rb +36 -36
  102. data/lib/azure/virtual_network_management/virtual_network_management_service.rb +109 -109
  103. data/test/fixtures/affinity_group.xml +33 -33
  104. data/test/fixtures/all_containers.xml +20 -20
  105. data/test/fixtures/all_tables.xml +22 -22
  106. data/test/fixtures/certificate.pem +21 -21
  107. data/test/fixtures/container_acl.xml +11 -11
  108. data/test/fixtures/create_sql_database_server.xml +1 -1
  109. data/test/fixtures/create_storage_desc_error.xml +5 -0
  110. data/test/fixtures/create_storage_extendedprop_error.xml +8 -0
  111. data/test/fixtures/create_storage_extendedpropname_error.xml +6 -0
  112. data/test/fixtures/create_storage_full_error.xml +6 -0
  113. data/test/fixtures/create_storage_label_error.xml +5 -0
  114. data/test/fixtures/create_storage_location_error.xml +5 -0
  115. data/test/fixtures/create_storage_name_error.xml +6 -0
  116. data/test/fixtures/create_table_response_entry.xml +15 -15
  117. data/test/fixtures/delete_storage_container_error.xml +5 -0
  118. data/test/fixtures/delete_storage_error.xml +5 -0
  119. data/test/fixtures/deployment_error.xml +5 -5
  120. data/test/fixtures/get_storage_account_error.xml +5 -0
  121. data/test/fixtures/get_storage_account_properties.xml +32 -0
  122. data/test/fixtures/get_storage_account_properties_new.xml +32 -0
  123. data/test/fixtures/http_error.xml +5 -5
  124. data/test/fixtures/insert_entity_response_entry.xml +25 -25
  125. data/test/fixtures/list_affinity_groups.xml +22 -22
  126. data/test/fixtures/list_blobs.xml +120 -120
  127. data/test/fixtures/list_block_all_with_none_committed.xml +21 -21
  128. data/test/fixtures/list_blocks_all.xml +22 -22
  129. data/test/fixtures/list_blocks_committed.xml +12 -12
  130. data/test/fixtures/list_cloud_services.xml +38 -28
  131. data/test/fixtures/list_containers.xml +37 -37
  132. data/test/fixtures/list_firewall_management_endpoint.xml +27 -0
  133. data/test/fixtures/list_images.xml +110 -110
  134. data/test/fixtures/list_locations.xml +62 -62
  135. data/test/fixtures/list_page_ranges.xml +10 -10
  136. data/test/fixtures/list_sql_database.xml +36 -36
  137. data/test/fixtures/list_sql_server_firewall.xml +23 -23
  138. data/test/fixtures/list_storage_accounts.xml +45 -45
  139. data/test/fixtures/list_virtual_networks.xml +92 -92
  140. data/test/fixtures/logging.xml +11 -11
  141. data/test/fixtures/management_certificate.pem +55 -55
  142. data/test/fixtures/messages.xml +12 -12
  143. data/test/fixtures/metrics.xml +10 -10
  144. data/test/fixtures/privatekey.key +28 -28
  145. data/test/fixtures/query_entities_empty_response.xml +7 -7
  146. data/test/fixtures/query_entities_response.xml +45 -45
  147. data/test/fixtures/queue_service_properties.xml +22 -22
  148. data/test/fixtures/queue_service_properties_original.xml +19 -19
  149. data/test/fixtures/queues.xml +16 -16
  150. data/test/fixtures/retention_policy.xml +5 -5
  151. data/test/fixtures/sb_default_create_queue_response.xml +23 -23
  152. data/test/fixtures/sb_default_create_topic_response.xml +18 -18
  153. data/test/fixtures/sb_get_access_token_response.txt +1 -1
  154. data/test/fixtures/sb_queues_runtime_peek_message_response_headers.txt +9 -9
  155. data/test/fixtures/storage_service_properties.xml +23 -23
  156. data/test/fixtures/update_storage_account.xml +16 -0
  157. data/test/fixtures/update_storage_error.xml +5 -0
  158. data/test/fixtures/updated_storage_accounts.xml +53 -0
  159. data/test/fixtures/virtual_machine.xml +108 -107
  160. data/test/fixtures/windows_virtual_machine.xml +106 -106
  161. data/test/integration/affinity_group/Affinity_test.rb +55 -55
  162. data/test/integration/affinity_group/Create_Affinity_test.rb +63 -63
  163. data/test/integration/affinity_group/Delete_Affinity_test.rb +56 -56
  164. data/test/integration/affinity_group/List_Affinity_test.rb +41 -41
  165. data/test/integration/affinity_group/Update_Affinity_test.rb +82 -82
  166. data/test/integration/blob/blob_gb18030_test.rb +199 -199
  167. data/test/integration/blob/blob_metadata_test.rb +75 -75
  168. data/test/integration/blob/blob_pages_test.rb +119 -119
  169. data/test/integration/blob/blob_properties_test.rb +77 -77
  170. data/test/integration/blob/block_blob_test.rb +254 -254
  171. data/test/integration/blob/container/container_acl_test.rb +69 -69
  172. data/test/integration/blob/container/container_metadata_test.rb +50 -50
  173. data/test/integration/blob/container/create_container_test.rb +60 -60
  174. data/test/integration/blob/container/delete_container_test.rb +39 -39
  175. data/test/integration/blob/container/get_container_properties_test.rb +48 -48
  176. data/test/integration/blob/container/list_containers_test.rb +79 -79
  177. data/test/integration/blob/container/root_container_test.rb +53 -53
  178. data/test/integration/blob/copy_blob_test.rb +113 -113
  179. data/test/integration/blob/create_blob_snapshot_test.rb +80 -80
  180. data/test/integration/blob/create_page_blob_test.rb +83 -83
  181. data/test/integration/blob/delete_blob_test.rb +159 -159
  182. data/test/integration/blob/get_blob_test.rb +65 -65
  183. data/test/integration/blob/informative_errors_test.rb +38 -38
  184. data/test/integration/blob/lease/acquire_lease_test.rb +36 -36
  185. data/test/integration/blob/lease/break_lease_test.rb +40 -40
  186. data/test/integration/blob/lease/release_lease_test.rb +40 -40
  187. data/test/integration/blob/lease/renew_lease_test.rb +42 -42
  188. data/test/integration/blob/list_blobs_test.rb +113 -113
  189. data/test/integration/database/create_sql_server_firewall_test.rb +86 -86
  190. data/test/integration/database/create_sql_server_test.rb +53 -57
  191. data/test/integration/database/delete_sql_server_firewall_test.rb +70 -72
  192. data/test/integration/database/delete_sql_server_test.rb +58 -63
  193. data/test/integration/database/list_sql_server_firewall_test.rb +45 -46
  194. data/test/integration/database/list_sql_servers_test.rb +44 -45
  195. data/test/integration/database/reset_password_sql_server_test.rb +55 -56
  196. data/test/integration/location/Location_List_test.rb +39 -39
  197. data/test/integration/queue/clear_messages_test.rb +42 -42
  198. data/test/integration/queue/create_message_test.rb +75 -75
  199. data/test/integration/queue/create_queue_test.rb +50 -50
  200. data/test/integration/queue/delete_message_test.rb +67 -67
  201. data/test/integration/queue/delete_queue_test.rb +45 -45
  202. data/test/integration/queue/informative_errors_test.rb +41 -41
  203. data/test/integration/queue/list_messages_encoded_test.rb +79 -79
  204. data/test/integration/queue/list_messages_test.rb +79 -79
  205. data/test/integration/queue/list_queues_test.rb +44 -44
  206. data/test/integration/queue/peek_messages_test.rb +59 -59
  207. data/test/integration/queue/queue_gb18030_test.rb +131 -131
  208. data/test/integration/queue/queue_metadata_test.rb +40 -40
  209. data/test/integration/queue/update_message_test.rb +74 -74
  210. data/test/integration/service_bus/informative_errors_test.rb +36 -36
  211. data/test/integration/service_bus/queues_scenario_test.rb +200 -200
  212. data/test/integration/service_bus/queues_test.rb +265 -265
  213. data/test/integration/service_bus/rules_test.rb +144 -144
  214. data/test/integration/service_bus/sb_queue_gb18030_test.rb +182 -182
  215. data/test/integration/service_bus/scenario_test.rb +101 -101
  216. data/test/integration/service_bus/subscriptions_test.rb +211 -211
  217. data/test/integration/service_bus/topics_scenario_test.rb +406 -406
  218. data/test/integration/service_bus/topics_test.rb +129 -129
  219. data/test/integration/storage_management/storage_management_test.rb +160 -0
  220. data/test/integration/table/create_table_test.rb +35 -35
  221. data/test/integration/table/delete_entity_batch_test.rb +106 -106
  222. data/test/integration/table/delete_entity_test.rb +93 -93
  223. data/test/integration/table/delete_table_test.rb +39 -39
  224. data/test/integration/table/get_table_test.rb +36 -36
  225. data/test/integration/table/informative_errors_test.rb +38 -38
  226. data/test/integration/table/insert_entity_batch_test.rb +99 -99
  227. data/test/integration/table/insert_entity_test.rb +87 -87
  228. data/test/integration/table/insert_or_merge_entity_batch_test.rb +158 -158
  229. data/test/integration/table/insert_or_merge_entity_test.rb +142 -142
  230. data/test/integration/table/insert_or_replace_entity_batch_test.rb +151 -151
  231. data/test/integration/table/insert_or_replace_entity_test.rb +136 -136
  232. data/test/integration/table/merge_entity_batch_test.rb +127 -127
  233. data/test/integration/table/merge_entity_test.rb +112 -112
  234. data/test/integration/table/query_entities_test.rb +194 -194
  235. data/test/integration/table/query_tables_test.rb +42 -42
  236. data/test/integration/table/query_test.rb +250 -250
  237. data/test/integration/table/table_acl_test.rb +51 -51
  238. data/test/integration/table/table_gb18030_test.rb +355 -355
  239. data/test/integration/table/update_entity_batch_test.rb +148 -148
  240. data/test/integration/table/update_entity_test.rb +130 -130
  241. data/test/integration/test_helper.rb +42 -44
  242. data/test/integration/vm/VM_Create_test.rb +213 -235
  243. data/test/integration/vm/VM_Delete_test.rb +55 -55
  244. data/test/integration/vm/VM_List_test.rb +71 -71
  245. data/test/integration/vm/VM_ShutDown_test.rb +59 -59
  246. data/test/integration/vm_image/virtual_machine_disk_test.rb +37 -37
  247. data/test/integration/vm_image/virtual_machine_image_test.rb +36 -36
  248. data/test/integration/vnet/Virtual_Network_Create_test.rb +122 -122
  249. data/test/integration/vnet/Virtual_Network_list_test.rb +53 -53
  250. data/test/support/env.rb +19 -19
  251. data/test/support/fixtures.rb +36 -36
  252. data/test/support/name_generator.rb +160 -160
  253. data/test/support/stubs.rb +42 -42
  254. data/test/support/virtual_machine_name_generator.rb +117 -127
  255. data/test/support/virtual_network_helper.rb +73 -73
  256. data/test/test_helper.rb +52 -52
  257. data/test/unit/affinity_group/affinity_group_test.rb +192 -192
  258. data/test/unit/affinity_group/serialization_test.rb +88 -88
  259. data/test/unit/base_management/location_test.rb +57 -57
  260. data/test/unit/blob/blob_service_test.rb +1946 -1946
  261. data/test/unit/cloud_service_management/cloud_service_management_service_test.rb +94 -94
  262. data/test/unit/cloud_service_management/serialization_test.rb +169 -76
  263. data/test/unit/core/auth/shared_key_lite_test.rb +51 -51
  264. data/test/unit/core/auth/shared_key_test.rb +58 -58
  265. data/test/unit/core/auth/signer_test.rb +30 -30
  266. data/test/unit/core/http/http_error_test.rb +57 -57
  267. data/test/unit/core/http/http_request_test.rb +66 -66
  268. data/test/unit/core/http/http_response_test.rb +45 -45
  269. data/test/unit/core/http/retry_policy_test.rb +23 -23
  270. data/test/unit/database/serialization_test.rb +97 -95
  271. data/test/unit/database/sql_database_server_service_test.rb +288 -152
  272. data/test/unit/service/serialization_test.rb +501 -501
  273. data/test/unit/service/storage_service_test.rb +290 -290
  274. data/test/unit/storage_management/serialization_test.rb +232 -65
  275. data/test/unit/storage_management/storage_management_service_test.rb +233 -94
  276. data/test/unit/table/edmtype_test.rb +107 -107
  277. data/test/unit/virtual_machine_image_management/serialization_test.rb +34 -34
  278. data/test/unit/virtual_machine_image_management/virtual_machine_image_management_service_test.rb +60 -60
  279. data/test/unit/virtual_machine_management/serialization_test.rb +119 -116
  280. data/test/unit/virtual_machine_management/virtual_machine_management_service_test.rb +383 -386
  281. data/test/unit/vnet/serialization_test.rb +187 -187
  282. data/test/unit/vnet/virtual_network_management_service_test.rb +131 -131
  283. metadata +55 -23
@@ -1,195 +1,195 @@
1
- #-------------------------------------------------------------------------
2
- # # Copyright (c) Microsoft and contributors. All rights reserved.
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 "integration/test_helper"
16
- require "azure/table/table_service"
17
- require "azure/core/http/http_error"
18
-
19
- describe Azure::Table::TableService do
20
- describe "#query_entities" do
21
- subject { Azure::Table::TableService.new }
22
- let(:table_name){ TableNameHelper.name }
23
- let(:entities_per_partition){3}
24
- let(:partitions){ ["part1", "part2", "part3"]}
25
- let(:entities){
26
- entities = {}
27
- index = 0
28
- partitions.each { |p|
29
- entities[p] = []
30
- (0..entities_per_partition).each { |i|
31
- entities[p].push "entity-#{index}"
32
- index+=1
33
- }
34
- }
35
- entities
36
- }
37
- let(:entity_properties){
38
- {
39
- "CustomStringProperty" => "CustomPropertyValue",
40
- "CustomIntegerProperty" => 37,
41
- "CustomBooleanProperty" => true,
42
- "CustomDateProperty" => Time.now
43
- }
44
- }
45
- before {
46
- subject.create_table table_name
47
- partitions.each { |p|
48
- entities[p].each { |e|
49
- entity = entity_properties.dup
50
- entity[:PartitionKey] = p
51
- entity[:RowKey] = e
52
- subject.insert_entity table_name, entity
53
- }
54
- }
55
- }
56
-
57
- after { TableNameHelper.clean }
58
-
59
- it "Queries a table for list of entities" do
60
- result = subject.query_entities table_name
61
- result.must_be_kind_of Array
62
- result.length.must_equal ((partitions.length + 1) * entities_per_partition)
63
-
64
- result.each { |e|
65
- entities[e.properties["PartitionKey"]].must_include e.properties["RowKey"]
66
- entity_properties.each { |k,v|
67
- unless v.class == Time
68
- e.properties[k].must_equal v
69
- else
70
- e.properties[k].to_i.must_equal v.to_i
71
- end
72
- }
73
- }
74
- end
75
-
76
- it "can constrain by partition and row key, returning zero or one entity" do
77
- partition = partitions[0]
78
- row_key = entities[partition][0]
79
-
80
- result = subject.query_entities table_name, { :partition_key => partition, :row_key => row_key }
81
- result.must_be_kind_of Array
82
- result.length.must_equal 1
83
-
84
- result.each { |e|
85
- e.properties["RowKey"].must_equal row_key
86
- entity_properties.each { |k,v|
87
- unless v.class == Time
88
- e.properties[k].must_equal v
89
- else
90
- e.properties[k].to_i.must_equal v.to_i
91
- end
92
- }
93
- }
94
- end
95
-
96
- it "can project a subset of properties, populating sparse properties with nil" do
97
- projection = ["CustomIntegerProperty", "ThisPropertyDoesNotExist"]
98
- result = subject.query_entities table_name, { :select => projection }
99
- result.must_be_kind_of Array
100
- result.length.must_equal ((partitions.length + 1) * entities_per_partition)
101
-
102
- result.each { |e|
103
- e.properties.length.must_equal projection.length
104
- e.properties["CustomIntegerProperty"].must_equal entity_properties["CustomIntegerProperty"]
105
- e.properties.must_include "ThisPropertyDoesNotExist"
106
- e.properties["ThisPropertyDoesNotExist"].must_equal ""
107
- }
108
- end
109
-
110
- it "can filter by one or more properties, returning a matching set of entities" do
111
- subject.insert_entity table_name, entity_properties.merge({
112
- "PartitionKey" => "filter-test-partition",
113
- "RowKey" => "filter-test-key",
114
- "CustomIntegerProperty" => entity_properties["CustomIntegerProperty"] + 1,
115
- "CustomBooleanProperty"=> false
116
- })
117
-
118
- filter = "CustomIntegerProperty gt #{entity_properties["CustomIntegerProperty"]} and CustomBooleanProperty eq false"
119
- result = subject.query_entities table_name, { :filter => filter }
120
- result.must_be_kind_of Array
121
- result.length.must_equal 1
122
- result.first.properties["PartitionKey"].must_equal "filter-test-partition"
123
-
124
- filter = "CustomIntegerProperty gt #{entity_properties["CustomIntegerProperty"]} and CustomBooleanProperty eq true"
125
- result = subject.query_entities table_name, { :filter => filter }
126
- result.must_be_kind_of Array
127
- result.length.must_equal 0
128
- end
129
-
130
- it "can limit the result set using the top parameter" do
131
- result = subject.query_entities table_name, { :top => 3 }
132
- result.must_be_kind_of Array
133
- result.length.must_equal 3
134
- result.continuation_token.wont_be_nil
135
- end
136
-
137
- it "can page results using the top parameter and continuation_token" do
138
- result = subject.query_entities table_name, { :top => 3 }
139
- result.must_be_kind_of Array
140
- result.length.must_equal 3
141
- result.continuation_token.wont_be_nil
142
-
143
- result2 = subject.query_entities table_name, { :top => 3, :continuation_token => result.continuation_token }
144
- result2.must_be_kind_of Array
145
- result2.length.must_equal 3
146
- result2.continuation_token.wont_be_nil
147
-
148
- result3 = subject.query_entities table_name, { :top => 3, :continuation_token => result2.continuation_token }
149
- result3.must_be_kind_of Array
150
- result3.length.must_equal 3
151
- result3.continuation_token.wont_be_nil
152
-
153
- result4 = subject.query_entities table_name, { :top => 3, :continuation_token => result3.continuation_token }
154
- result4.must_be_kind_of Array
155
- result4.length.must_equal 3
156
- result4.continuation_token.must_be_nil
157
- end
158
-
159
- it "can combine projection, filtering, and paging in the same query" do
160
- subject.insert_entity table_name, entity_properties.merge({
161
- "PartitionKey" => "filter-test-partition",
162
- "RowKey" => "filter-test-key",
163
- "CustomIntegerProperty" => entity_properties["CustomIntegerProperty"] + 1,
164
- "CustomBooleanProperty"=> false
165
- })
166
-
167
- filter = "CustomIntegerProperty eq #{entity_properties["CustomIntegerProperty"]}"
168
- projection = ["PartitionKey", "CustomIntegerProperty"]
169
- result = subject.query_entities table_name, { :select => projection, :filter => filter, :top => 3 }
170
- result.must_be_kind_of Array
171
- result.length.must_equal 3
172
- result.continuation_token.wont_be_nil
173
-
174
- result.first.properties["CustomIntegerProperty"].must_equal entity_properties["CustomIntegerProperty"]
175
- result.first.properties["PartitionKey"].wont_be_nil
176
- result.first.properties.length.must_equal 2
177
-
178
- result2 = subject.query_entities table_name, { :select => projection, :filter => filter, :top => 3, :continuation_token => result.continuation_token }
179
- result2.must_be_kind_of Array
180
- result2.length.must_equal 3
181
- result2.continuation_token.wont_be_nil
182
-
183
- result3 = subject.query_entities table_name, { :select => projection, :filter => filter, :top => 3, :continuation_token => result2.continuation_token }
184
- result3.must_be_kind_of Array
185
- result3.length.must_equal 3
186
- result3.continuation_token.wont_be_nil
187
-
188
- result4 = subject.query_entities table_name, { :select => projection, :filter => filter, :top => 3, :continuation_token => result3.continuation_token }
189
- result4.must_be_kind_of Array
190
- result4.length.must_equal 3
191
- result4.continuation_token.must_be_nil
192
- end
193
-
194
- end
1
+ #-------------------------------------------------------------------------
2
+ # # Copyright (c) Microsoft and contributors. All rights reserved.
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 "integration/test_helper"
16
+ require "azure/table/table_service"
17
+ require "azure/core/http/http_error"
18
+
19
+ describe Azure::Table::TableService do
20
+ describe "#query_entities" do
21
+ subject { Azure::Table::TableService.new }
22
+ let(:table_name){ TableNameHelper.name }
23
+ let(:entities_per_partition){3}
24
+ let(:partitions){ ["part1", "part2", "part3"]}
25
+ let(:entities){
26
+ entities = {}
27
+ index = 0
28
+ partitions.each { |p|
29
+ entities[p] = []
30
+ (0..entities_per_partition).each { |i|
31
+ entities[p].push "entity-#{index}"
32
+ index+=1
33
+ }
34
+ }
35
+ entities
36
+ }
37
+ let(:entity_properties){
38
+ {
39
+ "CustomStringProperty" => "CustomPropertyValue",
40
+ "CustomIntegerProperty" => 37,
41
+ "CustomBooleanProperty" => true,
42
+ "CustomDateProperty" => Time.now
43
+ }
44
+ }
45
+ before {
46
+ subject.create_table table_name
47
+ partitions.each { |p|
48
+ entities[p].each { |e|
49
+ entity = entity_properties.dup
50
+ entity[:PartitionKey] = p
51
+ entity[:RowKey] = e
52
+ subject.insert_entity table_name, entity
53
+ }
54
+ }
55
+ }
56
+
57
+ after { TableNameHelper.clean }
58
+
59
+ it "Queries a table for list of entities" do
60
+ result = subject.query_entities table_name
61
+ result.must_be_kind_of Array
62
+ result.length.must_equal ((partitions.length + 1) * entities_per_partition)
63
+
64
+ result.each { |e|
65
+ entities[e.properties["PartitionKey"]].must_include e.properties["RowKey"]
66
+ entity_properties.each { |k,v|
67
+ unless v.class == Time
68
+ e.properties[k].must_equal v
69
+ else
70
+ e.properties[k].to_i.must_equal v.to_i
71
+ end
72
+ }
73
+ }
74
+ end
75
+
76
+ it "can constrain by partition and row key, returning zero or one entity" do
77
+ partition = partitions[0]
78
+ row_key = entities[partition][0]
79
+
80
+ result = subject.query_entities table_name, { :partition_key => partition, :row_key => row_key }
81
+ result.must_be_kind_of Array
82
+ result.length.must_equal 1
83
+
84
+ result.each { |e|
85
+ e.properties["RowKey"].must_equal row_key
86
+ entity_properties.each { |k,v|
87
+ unless v.class == Time
88
+ e.properties[k].must_equal v
89
+ else
90
+ e.properties[k].to_i.must_equal v.to_i
91
+ end
92
+ }
93
+ }
94
+ end
95
+
96
+ it "can project a subset of properties, populating sparse properties with nil" do
97
+ projection = ["CustomIntegerProperty", "ThisPropertyDoesNotExist"]
98
+ result = subject.query_entities table_name, { :select => projection }
99
+ result.must_be_kind_of Array
100
+ result.length.must_equal ((partitions.length + 1) * entities_per_partition)
101
+
102
+ result.each { |e|
103
+ e.properties.length.must_equal projection.length
104
+ e.properties["CustomIntegerProperty"].must_equal entity_properties["CustomIntegerProperty"]
105
+ e.properties.must_include "ThisPropertyDoesNotExist"
106
+ e.properties["ThisPropertyDoesNotExist"].must_equal ""
107
+ }
108
+ end
109
+
110
+ it "can filter by one or more properties, returning a matching set of entities" do
111
+ subject.insert_entity table_name, entity_properties.merge({
112
+ "PartitionKey" => "filter-test-partition",
113
+ "RowKey" => "filter-test-key",
114
+ "CustomIntegerProperty" => entity_properties["CustomIntegerProperty"] + 1,
115
+ "CustomBooleanProperty"=> false
116
+ })
117
+
118
+ filter = "CustomIntegerProperty gt #{entity_properties["CustomIntegerProperty"]} and CustomBooleanProperty eq false"
119
+ result = subject.query_entities table_name, { :filter => filter }
120
+ result.must_be_kind_of Array
121
+ result.length.must_equal 1
122
+ result.first.properties["PartitionKey"].must_equal "filter-test-partition"
123
+
124
+ filter = "CustomIntegerProperty gt #{entity_properties["CustomIntegerProperty"]} and CustomBooleanProperty eq true"
125
+ result = subject.query_entities table_name, { :filter => filter }
126
+ result.must_be_kind_of Array
127
+ result.length.must_equal 0
128
+ end
129
+
130
+ it "can limit the result set using the top parameter" do
131
+ result = subject.query_entities table_name, { :top => 3 }
132
+ result.must_be_kind_of Array
133
+ result.length.must_equal 3
134
+ result.continuation_token.wont_be_nil
135
+ end
136
+
137
+ it "can page results using the top parameter and continuation_token" do
138
+ result = subject.query_entities table_name, { :top => 3 }
139
+ result.must_be_kind_of Array
140
+ result.length.must_equal 3
141
+ result.continuation_token.wont_be_nil
142
+
143
+ result2 = subject.query_entities table_name, { :top => 3, :continuation_token => result.continuation_token }
144
+ result2.must_be_kind_of Array
145
+ result2.length.must_equal 3
146
+ result2.continuation_token.wont_be_nil
147
+
148
+ result3 = subject.query_entities table_name, { :top => 3, :continuation_token => result2.continuation_token }
149
+ result3.must_be_kind_of Array
150
+ result3.length.must_equal 3
151
+ result3.continuation_token.wont_be_nil
152
+
153
+ result4 = subject.query_entities table_name, { :top => 3, :continuation_token => result3.continuation_token }
154
+ result4.must_be_kind_of Array
155
+ result4.length.must_equal 3
156
+ result4.continuation_token.must_be_nil
157
+ end
158
+
159
+ it "can combine projection, filtering, and paging in the same query" do
160
+ subject.insert_entity table_name, entity_properties.merge({
161
+ "PartitionKey" => "filter-test-partition",
162
+ "RowKey" => "filter-test-key",
163
+ "CustomIntegerProperty" => entity_properties["CustomIntegerProperty"] + 1,
164
+ "CustomBooleanProperty"=> false
165
+ })
166
+
167
+ filter = "CustomIntegerProperty eq #{entity_properties["CustomIntegerProperty"]}"
168
+ projection = ["PartitionKey", "CustomIntegerProperty"]
169
+ result = subject.query_entities table_name, { :select => projection, :filter => filter, :top => 3 }
170
+ result.must_be_kind_of Array
171
+ result.length.must_equal 3
172
+ result.continuation_token.wont_be_nil
173
+
174
+ result.first.properties["CustomIntegerProperty"].must_equal entity_properties["CustomIntegerProperty"]
175
+ result.first.properties["PartitionKey"].wont_be_nil
176
+ result.first.properties.length.must_equal 2
177
+
178
+ result2 = subject.query_entities table_name, { :select => projection, :filter => filter, :top => 3, :continuation_token => result.continuation_token }
179
+ result2.must_be_kind_of Array
180
+ result2.length.must_equal 3
181
+ result2.continuation_token.wont_be_nil
182
+
183
+ result3 = subject.query_entities table_name, { :select => projection, :filter => filter, :top => 3, :continuation_token => result2.continuation_token }
184
+ result3.must_be_kind_of Array
185
+ result3.length.must_equal 3
186
+ result3.continuation_token.wont_be_nil
187
+
188
+ result4 = subject.query_entities table_name, { :select => projection, :filter => filter, :top => 3, :continuation_token => result3.continuation_token }
189
+ result4.must_be_kind_of Array
190
+ result4.length.must_equal 3
191
+ result4.continuation_token.must_be_nil
192
+ end
193
+
194
+ end
195
195
  end
@@ -1,43 +1,43 @@
1
- #-------------------------------------------------------------------------
2
- # # Copyright (c) Microsoft and contributors. All rights reserved.
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 "integration/test_helper"
16
- require "azure/table/table_service"
17
- require "azure/core/http/http_error"
18
-
19
- describe Azure::Table::TableService do
20
- describe "#query_tables" do
21
- subject { Azure::Table::TableService.new }
22
- let(:tables){ [TableNameHelper.name, TableNameHelper.name] }
23
- before { tables.each { |t| subject.create_table t } }
24
- after { TableNameHelper.clean }
25
-
26
- it "gets a list of tables for the account" do
27
- result = subject.query_tables
28
- result.must_be_kind_of Array
29
-
30
- tables.each { |t|
31
- table = result.find {|c|
32
- c[:properties]["TableName"] == t
33
- }
34
- table.wont_be_nil
35
- updated = subject.get_table(t)
36
- updated.wont_be_nil
37
-
38
- # this is a weird, but sometimes it's off by a few seconds
39
- assert ((table[:updated] - updated).abs < 30), "time stamps don't match"
40
- }
41
- end
42
- end
1
+ #-------------------------------------------------------------------------
2
+ # # Copyright (c) Microsoft and contributors. All rights reserved.
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 "integration/test_helper"
16
+ require "azure/table/table_service"
17
+ require "azure/core/http/http_error"
18
+
19
+ describe Azure::Table::TableService do
20
+ describe "#query_tables" do
21
+ subject { Azure::Table::TableService.new }
22
+ let(:tables){ [TableNameHelper.name, TableNameHelper.name] }
23
+ before { tables.each { |t| subject.create_table t } }
24
+ after { TableNameHelper.clean }
25
+
26
+ it "gets a list of tables for the account" do
27
+ result = subject.query_tables
28
+ result.must_be_kind_of Array
29
+
30
+ tables.each { |t|
31
+ table = result.find {|c|
32
+ c[:properties]["TableName"] == t
33
+ }
34
+ table.wont_be_nil
35
+ updated = subject.get_table(t)
36
+ updated.wont_be_nil
37
+
38
+ # this is a weird, but sometimes it's off by a few seconds
39
+ assert ((table[:updated] - updated).abs < 30), "time stamps don't match"
40
+ }
41
+ end
42
+ end
43
43
  end