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