azure 0.6.0 → 0.6.1

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.
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