fog-azure-rm 0.0.4 → 0.0.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (433) hide show
  1. checksums.yaml +4 -4
  2. data/.DS_Store +0 -0
  3. data/.travis.yml +11 -1
  4. data/CHANGELOG.md +35 -14
  5. data/fog-azure-rm.gemspec +8 -9
  6. data/lib/fog/azurerm.rb +3 -0
  7. data/lib/fog/azurerm/application_gateway.rb +64 -0
  8. data/lib/fog/azurerm/compute.rb +1 -0
  9. data/lib/fog/azurerm/config.rb +17 -0
  10. data/lib/fog/azurerm/core.rb +1 -0
  11. data/lib/fog/azurerm/dns.rb +4 -2
  12. data/lib/fog/azurerm/docs/application_gateway.md +139 -0
  13. data/lib/fog/azurerm/docs/dns.md +28 -6
  14. data/lib/fog/azurerm/docs/network.md +151 -143
  15. data/lib/fog/azurerm/docs/resources.md +3 -3
  16. data/lib/fog/azurerm/docs/storage.md +15 -3
  17. data/lib/fog/azurerm/docs/traffic_manager.md +118 -0
  18. data/lib/fog/azurerm/fog_azure_rm_exception.rb +13 -0
  19. data/lib/fog/azurerm/models/application_gateway/backend_address_pool.rb +22 -0
  20. data/lib/fog/azurerm/models/application_gateway/backend_http_setting.rb +26 -0
  21. data/lib/fog/azurerm/models/application_gateway/frontend_ip_configuration.rb +22 -0
  22. data/lib/fog/azurerm/models/application_gateway/frontend_port.rb +18 -0
  23. data/lib/fog/azurerm/models/{network/application_gateway.rb → application_gateway/gateway.rb} +74 -78
  24. data/lib/fog/azurerm/models/{network/application_gateways.rb → application_gateway/gateways.rb} +6 -6
  25. data/lib/fog/azurerm/models/application_gateway/http_listener.rb +28 -0
  26. data/lib/fog/azurerm/models/application_gateway/ip_configuration.rb +18 -0
  27. data/lib/fog/azurerm/models/application_gateway/probe.rb +28 -0
  28. data/lib/fog/azurerm/models/application_gateway/request_routing_rule.rb +25 -0
  29. data/lib/fog/azurerm/models/application_gateway/ssl_certificate.rb +22 -0
  30. data/lib/fog/azurerm/models/application_gateway/url_path_map.rb +28 -0
  31. data/lib/fog/azurerm/models/compute/availability_set.rb +8 -8
  32. data/lib/fog/azurerm/models/compute/availability_sets.rb +3 -1
  33. data/lib/fog/azurerm/models/compute/server.rb +50 -34
  34. data/lib/fog/azurerm/models/dns/record_set.rb +30 -2
  35. data/lib/fog/azurerm/models/dns/record_sets.rb +4 -2
  36. data/lib/fog/azurerm/models/dns/zone.rb +1 -1
  37. data/lib/fog/azurerm/models/dns/zones.rb +4 -2
  38. data/lib/fog/azurerm/models/network/express_route_circuit.rb +89 -0
  39. data/lib/fog/azurerm/models/network/express_route_circuit_peering.rb +93 -0
  40. data/lib/fog/azurerm/models/network/express_route_circuit_peerings.rb +31 -0
  41. data/lib/fog/azurerm/models/network/express_route_circuits.rb +29 -0
  42. data/lib/fog/azurerm/models/network/express_route_service_provider.rb +29 -0
  43. data/lib/fog/azurerm/models/network/express_route_service_providers.rb +21 -0
  44. data/lib/fog/azurerm/models/network/frontend_ip_configuration.rb +5 -15
  45. data/lib/fog/azurerm/models/network/inbound_nat_pool.rb +6 -7
  46. data/lib/fog/azurerm/models/network/inbound_nat_rule.rb +6 -9
  47. data/lib/fog/azurerm/models/network/load_balancer.rb +17 -19
  48. data/lib/fog/azurerm/models/network/load_balancing_rule.rb +11 -16
  49. data/lib/fog/azurerm/models/network/network_interface.rb +24 -24
  50. data/lib/fog/azurerm/models/network/network_security_group.rb +9 -9
  51. data/lib/fog/azurerm/models/network/network_security_rule.rb +13 -13
  52. data/lib/fog/azurerm/models/network/probe.rb +7 -8
  53. data/lib/fog/azurerm/models/network/public_ip.rb +15 -16
  54. data/lib/fog/azurerm/models/network/public_ips.rb +4 -2
  55. data/lib/fog/azurerm/models/network/subnet.rb +8 -8
  56. data/lib/fog/azurerm/models/network/virtual_network.rb +9 -9
  57. data/lib/fog/azurerm/models/network/virtual_network_gateway.rb +138 -0
  58. data/lib/fog/azurerm/models/network/virtual_network_gateways.rb +29 -0
  59. data/lib/fog/azurerm/models/network/vpn_client_configuration.rb +34 -0
  60. data/lib/fog/azurerm/models/network/vpn_client_revoked_certificates.rb +22 -0
  61. data/lib/fog/azurerm/models/network/vpn_client_root_certificates.rb +22 -0
  62. data/lib/fog/azurerm/models/resources/azure_resource.rb +5 -5
  63. data/lib/fog/azurerm/models/resources/dependency.rb +5 -5
  64. data/lib/fog/azurerm/models/resources/deployment.rb +14 -14
  65. data/lib/fog/azurerm/models/resources/provider.rb +4 -4
  66. data/lib/fog/azurerm/models/resources/provider_resource_type.rb +4 -4
  67. data/lib/fog/azurerm/models/resources/resource_group.rb +9 -1
  68. data/lib/fog/azurerm/models/resources/resource_groups.rb +5 -1
  69. data/lib/fog/azurerm/models/storage/data_disk.rb +6 -6
  70. data/lib/fog/azurerm/models/storage/storage_account.rb +41 -10
  71. data/lib/fog/azurerm/models/storage/storage_accounts.rb +1 -6
  72. data/lib/fog/azurerm/models/traffic_manager/traffic_manager_end_point.rb +75 -0
  73. data/lib/fog/azurerm/models/traffic_manager/traffic_manager_end_points.rb +31 -0
  74. data/lib/fog/azurerm/models/traffic_manager/traffic_manager_profile.rb +59 -0
  75. data/lib/fog/azurerm/models/traffic_manager/traffic_manager_profiles.rb +26 -0
  76. data/lib/fog/azurerm/network.rb +25 -25
  77. data/lib/fog/azurerm/requests/{network → application_gateway}/create_application_gateway.rb +59 -95
  78. data/lib/fog/azurerm/requests/application_gateway/delete_application_gateway.rb +26 -0
  79. data/lib/fog/azurerm/requests/application_gateway/list_application_gateways.rb +29 -0
  80. data/lib/fog/azurerm/requests/compute/attach_data_disk_to_vm.rb +38 -38
  81. data/lib/fog/azurerm/requests/compute/check_vm_status.rb +8 -10
  82. data/lib/fog/azurerm/requests/compute/create_availability_set.rb +15 -20
  83. data/lib/fog/azurerm/requests/compute/create_virtual_machine.rb +50 -45
  84. data/lib/fog/azurerm/requests/compute/deallocate_virtual_machine.rb +9 -10
  85. data/lib/fog/azurerm/requests/compute/delete_availability_set.rb +7 -8
  86. data/lib/fog/azurerm/requests/compute/delete_virtual_machine.rb +9 -10
  87. data/lib/fog/azurerm/requests/compute/detach_data_disk_from_vm.rb +20 -19
  88. data/lib/fog/azurerm/requests/compute/generalize_virtual_machine.rb +9 -10
  89. data/lib/fog/azurerm/requests/compute/get_availability_set.rb +32 -0
  90. data/lib/fog/azurerm/requests/compute/get_virtual_machine.rb +17 -14
  91. data/lib/fog/azurerm/requests/compute/list_availability_sets.rb +7 -6
  92. data/lib/fog/azurerm/requests/compute/list_available_sizes_for_virtual_machine.rb +37 -31
  93. data/lib/fog/azurerm/requests/compute/list_virtual_machines.rb +47 -42
  94. data/lib/fog/azurerm/requests/compute/power_off_virtual_machine.rb +9 -10
  95. data/lib/fog/azurerm/requests/compute/redeploy_virtual_machine.rb +9 -10
  96. data/lib/fog/azurerm/requests/compute/restart_virtual_machine.rb +9 -10
  97. data/lib/fog/azurerm/requests/compute/start_virtual_machine.rb +9 -10
  98. data/lib/fog/azurerm/requests/dns/{create_record_set.rb → create_or_update_record_set.rb} +2 -2
  99. data/lib/fog/azurerm/requests/dns/{create_zone.rb → create_or_update_zone.rb} +3 -3
  100. data/lib/fog/azurerm/requests/dns/get_record_set.rb +56 -0
  101. data/lib/fog/azurerm/requests/dns/get_zone.rb +50 -0
  102. data/lib/fog/azurerm/requests/dns/list_record_sets.rb +2 -2
  103. data/lib/fog/azurerm/requests/network/add_address_prefixes_in_virtual_network.rb +3 -3
  104. data/lib/fog/azurerm/requests/network/add_dns_servers_in_virtual_network.rb +8 -6
  105. data/lib/fog/azurerm/requests/network/add_security_rules.rb +15 -13
  106. data/lib/fog/azurerm/requests/network/add_subnets_in_virtual_network.rb +6 -4
  107. data/lib/fog/azurerm/requests/network/attach_network_security_group_to_subnet.rb +13 -15
  108. data/lib/fog/azurerm/requests/network/attach_resource_to_nic.rb +17 -16
  109. data/lib/fog/azurerm/requests/network/attach_route_table_to_subnet.rb +13 -15
  110. data/lib/fog/azurerm/requests/network/check_for_public_ip.rb +2 -4
  111. data/lib/fog/azurerm/requests/network/check_for_virtual_network.rb +5 -5
  112. data/lib/fog/azurerm/requests/network/create_load_balancer.rb +43 -62
  113. data/lib/fog/azurerm/requests/network/create_or_update_express_route_circuit.rb +98 -0
  114. data/lib/fog/azurerm/requests/network/create_or_update_express_route_circuit_peering.rb +69 -0
  115. data/lib/fog/azurerm/requests/network/create_or_update_network_interface.rb +14 -19
  116. data/lib/fog/azurerm/requests/network/create_or_update_network_security_group.rb +29 -26
  117. data/lib/fog/azurerm/requests/network/create_or_update_virtual_network.rb +19 -25
  118. data/lib/fog/azurerm/requests/network/create_or_update_virtual_network_gateway.rb +151 -0
  119. data/lib/fog/azurerm/requests/network/create_public_ip.rb +8 -10
  120. data/lib/fog/azurerm/requests/network/create_subnet.rb +13 -15
  121. data/lib/fog/azurerm/requests/network/delete_express_route_circuit.rb +28 -0
  122. data/lib/fog/azurerm/requests/network/delete_express_route_circuit_peering.rb +28 -0
  123. data/lib/fog/azurerm/requests/network/delete_load_balancer.rb +8 -7
  124. data/lib/fog/azurerm/requests/network/delete_network_interface.rb +7 -8
  125. data/lib/fog/azurerm/requests/network/delete_network_security_group.rb +8 -7
  126. data/lib/fog/azurerm/requests/network/delete_public_ip.rb +4 -6
  127. data/lib/fog/azurerm/requests/network/delete_subnet.rb +6 -7
  128. data/lib/fog/azurerm/requests/network/delete_virtual_network.rb +6 -7
  129. data/lib/fog/azurerm/requests/network/delete_virtual_network_gateway.rb +28 -0
  130. data/lib/fog/azurerm/requests/network/detach_network_security_group_from_subnet.rb +15 -17
  131. data/lib/fog/azurerm/requests/network/detach_resource_from_nic.rb +15 -14
  132. data/lib/fog/azurerm/requests/network/detach_route_table_from_subnet.rb +15 -17
  133. data/lib/fog/azurerm/requests/network/get_express_route_circuit.rb +51 -0
  134. data/lib/fog/azurerm/requests/network/get_express_route_circuit_peering.rb +48 -0
  135. data/lib/fog/azurerm/requests/network/get_network_interface.rb +7 -7
  136. data/lib/fog/azurerm/requests/network/get_network_security_group.rb +11 -7
  137. data/lib/fog/azurerm/requests/network/get_public_ip.rb +41 -0
  138. data/lib/fog/azurerm/requests/network/get_subnet.rb +10 -9
  139. data/lib/fog/azurerm/requests/network/get_virtual_network.rb +12 -14
  140. data/lib/fog/azurerm/requests/network/get_virtual_network_gateway.rb +45 -0
  141. data/lib/fog/azurerm/requests/network/list_express_route_circuit_peerings.rb +44 -0
  142. data/lib/fog/azurerm/requests/network/list_express_route_circuits.rb +53 -0
  143. data/lib/fog/azurerm/requests/network/list_express_route_service_providers.rb +37 -0
  144. data/lib/fog/azurerm/requests/network/list_load_balancers.rb +6 -6
  145. data/lib/fog/azurerm/requests/network/list_network_interfaces.rb +42 -37
  146. data/lib/fog/azurerm/requests/network/list_network_security_groups.rb +149 -143
  147. data/lib/fog/azurerm/requests/network/list_public_ips.rb +26 -22
  148. data/lib/fog/azurerm/requests/network/list_subnets.rb +35 -31
  149. data/lib/fog/azurerm/requests/network/list_virtual_network_gateways.rb +43 -0
  150. data/lib/fog/azurerm/requests/network/list_virtual_networks.rb +52 -51
  151. data/lib/fog/azurerm/requests/network/remove_address_prefixes_from_virtual_network.rb +6 -4
  152. data/lib/fog/azurerm/requests/network/remove_dns_servers_from_virtual_network.rb +6 -4
  153. data/lib/fog/azurerm/requests/network/remove_security_rule.rb +15 -13
  154. data/lib/fog/azurerm/requests/network/remove_subnets_from_virtual_network.rb +6 -4
  155. data/lib/fog/azurerm/requests/resources/create_deployment.rb +27 -21
  156. data/lib/fog/azurerm/requests/resources/create_resource_group.rb +9 -9
  157. data/lib/fog/azurerm/requests/resources/delete_deployment.rb +3 -4
  158. data/lib/fog/azurerm/requests/resources/delete_resource_group.rb +3 -5
  159. data/lib/fog/azurerm/requests/resources/delete_resource_tag.rb +14 -20
  160. data/lib/fog/azurerm/requests/resources/list_deployments.rb +8 -7
  161. data/lib/fog/azurerm/requests/resources/list_resource_groups.rb +27 -23
  162. data/lib/fog/azurerm/requests/resources/list_tagged_resources.rb +30 -27
  163. data/lib/fog/azurerm/requests/resources/tag_resource.rb +15 -20
  164. data/lib/fog/azurerm/requests/storage/check_storage_account_name_availability.rb +13 -15
  165. data/lib/fog/azurerm/requests/storage/create_container.rb +6 -5
  166. data/lib/fog/azurerm/requests/storage/create_storage_account.rb +36 -22
  167. data/lib/fog/azurerm/requests/storage/delete_container.rb +6 -5
  168. data/lib/fog/azurerm/requests/storage/delete_disk.rb +13 -12
  169. data/lib/fog/azurerm/requests/storage/delete_storage_account.rb +8 -9
  170. data/lib/fog/azurerm/requests/storage/get_blob_metadata.rb +10 -9
  171. data/lib/fog/azurerm/requests/storage/get_container_access_control_list.rb +6 -5
  172. data/lib/fog/azurerm/requests/storage/get_container_metadata.rb +8 -7
  173. data/lib/fog/azurerm/requests/storage/get_container_properties.rb +6 -5
  174. data/lib/fog/azurerm/requests/storage/get_storage_access_keys.rb +7 -7
  175. data/lib/fog/azurerm/requests/storage/list_containers.rb +6 -5
  176. data/lib/fog/azurerm/requests/storage/list_storage_account_for_rg.rb +7 -12
  177. data/lib/fog/azurerm/requests/storage/list_storage_accounts.rb +7 -13
  178. data/lib/fog/azurerm/requests/storage/set_blob_metadata.rb +8 -7
  179. data/lib/fog/azurerm/requests/storage/set_container_metadata.rb +8 -7
  180. data/lib/fog/azurerm/requests/traffic_manager/create_traffic_manager_endpoint.rb +54 -0
  181. data/lib/fog/azurerm/requests/traffic_manager/create_traffic_manager_profile.rb +107 -0
  182. data/lib/fog/azurerm/requests/traffic_manager/delete_traffic_manager_endpoint.rb +28 -0
  183. data/lib/fog/azurerm/requests/traffic_manager/delete_traffic_manager_profile.rb +26 -0
  184. data/lib/fog/azurerm/requests/traffic_manager/get_traffic_manager_endpoint.rb +39 -0
  185. data/lib/fog/azurerm/requests/traffic_manager/get_traffic_manager_profile.rb +80 -0
  186. data/lib/fog/azurerm/requests/traffic_manager/list_traffic_manager_profiles.rb +82 -0
  187. data/lib/fog/azurerm/storage.rb +1 -1
  188. data/lib/fog/azurerm/traffic_manager.rb +56 -0
  189. data/lib/fog/azurerm/utilities/general.rb +28 -0
  190. data/lib/fog/azurerm/version.rb +1 -1
  191. data/test/api_stub.rb +14 -7
  192. data/test/api_stub/models/{network/application_gateway.rb → application_gateway/gateway.rb} +8 -7
  193. data/test/api_stub/models/compute/availability_set.rb +35 -6
  194. data/test/api_stub/models/compute/server.rb +15 -16
  195. data/test/api_stub/models/dns/record_set.rb +20 -0
  196. data/test/api_stub/models/network/express_route_circuit.rb +47 -0
  197. data/test/api_stub/models/network/express_route_circuit_peering.rb +33 -0
  198. data/test/api_stub/models/network/express_route_service_provider.rb +29 -0
  199. data/test/api_stub/models/network/load_balancer.rb +137 -115
  200. data/test/api_stub/models/network/network_interface.rb +3 -2
  201. data/test/api_stub/models/network/network_security_group.rb +4 -3
  202. data/test/api_stub/models/network/public_ip.rb +5 -4
  203. data/test/api_stub/models/network/subnet.rb +3 -2
  204. data/test/api_stub/models/network/virtual_network.rb +3 -2
  205. data/test/api_stub/models/network/virtual_network_gateway.rb +26 -0
  206. data/test/api_stub/models/resources/deployment.rb +56 -50
  207. data/test/api_stub/models/resources/resource.rb +17 -14
  208. data/test/api_stub/models/resources/resource_group.rb +4 -18
  209. data/test/api_stub/models/storage/storageaccount.rb +8 -15
  210. data/test/api_stub/models/{network → traffic_manager}/traffic_manager_end_point.rb +4 -3
  211. data/test/api_stub/models/{network → traffic_manager}/traffic_manager_profile.rb +4 -3
  212. data/test/api_stub/requests/application_gateway/gateway.rb +431 -0
  213. data/test/api_stub/requests/compute/availability_set.rb +34 -23
  214. data/test/api_stub/requests/compute/virtual_machine.rb +73 -30
  215. data/test/api_stub/requests/dns/record_set.rb +6 -6
  216. data/test/api_stub/requests/dns/zone.rb +2 -2
  217. data/test/api_stub/requests/network/express_route_circuit.rb +100 -0
  218. data/test/api_stub/requests/network/express_route_circuit_peering.rb +62 -0
  219. data/test/api_stub/requests/network/express_route_service_provider.rb +30 -0
  220. data/test/api_stub/requests/network/load_balancer.rb +273 -251
  221. data/test/api_stub/requests/network/network_interface.rb +12 -16
  222. data/test/api_stub/requests/network/network_security_group.rb +12 -27
  223. data/test/api_stub/requests/network/public_ip.rb +7 -9
  224. data/test/api_stub/requests/network/subnet.rb +6 -8
  225. data/test/api_stub/requests/network/virtual_network.rb +6 -8
  226. data/test/api_stub/requests/network/virtual_network_gateway.rb +49 -0
  227. data/test/api_stub/requests/resources/deployment.rb +56 -11
  228. data/test/api_stub/requests/resources/resource.rb +6 -8
  229. data/test/api_stub/requests/resources/resource_group.rb +6 -8
  230. data/test/api_stub/requests/storage/storageaccount.rb +44 -31
  231. data/test/api_stub/requests/traffic_manager/traffic_manager_endpoint.rb +41 -0
  232. data/test/api_stub/requests/{network → traffic_manager}/traffic_manager_profile.rb +7 -5
  233. data/test/integration/application_gateway.rb +16 -8
  234. data/test/integration/availability_set.rb +1 -1
  235. data/test/integration/container.rb +2 -1
  236. data/test/integration/deployment.rb +54 -0
  237. data/test/integration/express_route_circuit.rb +80 -0
  238. data/test/integration/external_load_balancer.rb +7 -6
  239. data/test/integration/internal_load_balancer.rb +6 -5
  240. data/test/integration/network_interface.rb +2 -2
  241. data/test/integration/public_ip.rb +2 -2
  242. data/test/integration/record_set.rb +26 -8
  243. data/test/integration/resource_group.rb +39 -0
  244. data/test/integration/resource_tag.rb +62 -0
  245. data/test/integration/server.rb +6 -4
  246. data/test/integration/storage_account.rb +33 -5
  247. data/test/integration/subnet.rb +2 -2
  248. data/test/integration/traffic_manager.rb +12 -12
  249. data/test/integration/virtual_network.rb +6 -6
  250. data/test/integration/virtual_network_gateway.rb +101 -0
  251. data/test/integration/zone.rb +1 -1
  252. data/test/models/application_gateway/test_gateway.rb +57 -0
  253. data/test/models/{network/test_application_gateways.rb → application_gateway/test_gateways.rb} +10 -10
  254. data/test/models/compute/test_availability_set.rb +2 -1
  255. data/test/models/compute/test_availability_sets.rb +5 -4
  256. data/test/models/compute/test_server.rb +6 -5
  257. data/test/models/compute/test_servers.rb +3 -2
  258. data/test/models/dns/test_record_set.rb +27 -1
  259. data/test/models/dns/test_record_sets.rb +3 -2
  260. data/test/models/dns/test_zone.rb +1 -1
  261. data/test/models/dns/test_zones.rb +2 -1
  262. data/test/models/network/test_express_route_circuit.rb +58 -0
  263. data/test/models/network/test_express_route_circuit_peering.rb +59 -0
  264. data/test/models/network/test_express_route_circuit_peerings.rb +43 -0
  265. data/test/models/network/test_express_route_circuits.rb +42 -0
  266. data/test/models/network/test_express_route_service_providers.rb +30 -0
  267. data/test/models/network/test_load_balancer.rb +7 -12
  268. data/test/models/network/test_load_balancers.rb +4 -4
  269. data/test/models/network/test_network_interface.rb +10 -16
  270. data/test/models/network/test_network_interfaces.rb +3 -2
  271. data/test/models/network/test_network_security_group.rb +6 -8
  272. data/test/models/network/test_network_security_groups.rb +2 -1
  273. data/test/models/network/test_public_ip.rb +5 -6
  274. data/test/models/network/test_public_ips.rb +6 -6
  275. data/test/models/network/test_subnet.rb +9 -15
  276. data/test/models/network/test_subnets.rb +3 -2
  277. data/test/models/network/test_virtual_network.rb +10 -16
  278. data/test/models/network/test_virtual_network_gateway.rb +62 -0
  279. data/test/models/network/test_virtual_network_gateways.rb +42 -0
  280. data/test/models/network/test_virtual_networks.rb +3 -2
  281. data/test/models/resources/test_deployment.rb +2 -1
  282. data/test/models/resources/test_deployments.rb +2 -1
  283. data/test/models/resources/test_resource_group.rb +2 -1
  284. data/test/models/resources/test_resource_groups.rb +2 -1
  285. data/test/models/resources/test_resources.rb +2 -1
  286. data/test/models/storage/test_data_disk.rb +0 -6
  287. data/test/models/storage/test_storage_account.rb +29 -8
  288. data/test/models/storage/test_storage_accounts.rb +5 -5
  289. data/test/models/{network → traffic_manager}/test_traffic_manager_end_point.rb +4 -3
  290. data/test/models/traffic_manager/test_traffic_manager_end_points.rb +43 -0
  291. data/test/models/{network → traffic_manager}/test_traffic_manager_profile.rb +5 -4
  292. data/test/models/traffic_manager/test_traffic_manager_profiles.rb +42 -0
  293. data/test/requests/application_gateway/test_create_application_gateway.rb +51 -0
  294. data/test/requests/application_gateway/test_delete_application_gateway.rb +23 -0
  295. data/test/requests/application_gateway/test_list_application_gateways.rb +24 -0
  296. data/test/requests/compute/test_attach_data_disk_to_vm.rb +40 -123
  297. data/test/requests/compute/test_create_availability_set.rb +9 -11
  298. data/test/requests/compute/test_create_virtual_machine.rb +13 -29
  299. data/test/requests/compute/test_deallocate_virtual_machine.rb +7 -13
  300. data/test/requests/compute/test_delete_availability_set.rb +5 -11
  301. data/test/requests/compute/test_delete_virtual_machine.rb +7 -13
  302. data/test/requests/compute/test_detach_data_disk_from_vm.rb +13 -34
  303. data/test/requests/compute/test_generalize_virtual_machine.rb +7 -13
  304. data/test/requests/compute/test_get_availability_set.rb +24 -0
  305. data/test/requests/compute/test_get_virtual_machine.rb +8 -15
  306. data/test/requests/compute/test_get_vm_status.rb +8 -14
  307. data/test/requests/compute/test_list_availability_sets.rb +8 -14
  308. data/test/requests/compute/test_list_available_sizes_for_virtual_machine.rb +8 -15
  309. data/test/requests/compute/test_list_virtual_machines.rb +8 -14
  310. data/test/requests/compute/test_power_off_virtual_machine.rb +7 -13
  311. data/test/requests/compute/test_redeploy_virtual_machine.rb +7 -13
  312. data/test/requests/compute/test_restart_virtual_machine.rb +7 -13
  313. data/test/requests/compute/test_start_virtual_machine.rb +7 -13
  314. data/test/requests/dns/test_create_record_set.rb +8 -8
  315. data/test/requests/dns/test_create_zone.rb +6 -6
  316. data/test/requests/dns/test_delete_record_set.rb +2 -2
  317. data/test/requests/dns/test_delete_zone.rb +2 -2
  318. data/test/requests/dns/test_get_record_set.rb +46 -0
  319. data/test/requests/dns/test_get_zone.rb +46 -0
  320. data/test/requests/network/test_add_address_prefixes_in_virtual_network.rb +11 -27
  321. data/test/requests/network/test_add_dns_servers_in_virtual_network.rb +11 -27
  322. data/test/requests/network/test_add_security_rules.rb +11 -31
  323. data/test/requests/network/test_add_subnets_in_virtual_network.rb +11 -27
  324. data/test/requests/network/test_attach_network_security_group_to_subnet.rb +9 -16
  325. data/test/requests/network/test_attach_resource_to_nic.rb +15 -37
  326. data/test/requests/network/test_attach_route_table_to_subnet.rb +9 -16
  327. data/test/requests/network/test_check_for_public_ip.rb +10 -18
  328. data/test/requests/network/test_check_for_virtual_network.rb +10 -18
  329. data/test/requests/network/test_create_express_route_circuit.rb +39 -0
  330. data/test/requests/network/test_create_express_route_circuit_peering.rb +37 -0
  331. data/test/requests/network/test_create_load_balancer.rb +27 -34
  332. data/test/requests/network/test_create_network_interface.rb +16 -28
  333. data/test/requests/network/test_create_or_update_network_security_group.rb +38 -0
  334. data/test/requests/network/test_create_or_update_virtual_network.rb +20 -28
  335. data/test/requests/network/test_create_public_ip.rb +13 -22
  336. data/test/requests/network/test_create_subnet.rb +13 -22
  337. data/test/requests/network/test_create_virtual_network_gateway.rb +37 -0
  338. data/test/requests/network/test_delete_express_route_circuit.rb +24 -0
  339. data/test/requests/network/test_delete_express_route_circuit_peering.rb +24 -0
  340. data/test/requests/network/test_delete_load_balancer.rb +7 -13
  341. data/test/requests/network/test_delete_network_interface.rb +7 -13
  342. data/test/requests/network/test_delete_network_security_group.rb +6 -13
  343. data/test/requests/network/test_delete_public_ip.rb +7 -13
  344. data/test/requests/network/test_delete_subnet.rb +7 -13
  345. data/test/requests/network/test_delete_virtual_network.rb +7 -13
  346. data/test/requests/network/test_delete_virtual_network_gateway.rb +24 -0
  347. data/test/requests/network/test_detach_network_security_group_from_subnet.rb +9 -16
  348. data/test/requests/network/test_detach_resource_from_nic.rb +15 -34
  349. data/test/requests/network/test_detach_route_table_from_subnet.rb +9 -16
  350. data/test/requests/network/test_get_express_route_circuit.rb +24 -0
  351. data/test/requests/network/test_get_express_route_circuit_peering.rb +24 -0
  352. data/test/requests/network/test_get_network_interface.rb +8 -15
  353. data/test/requests/network/test_get_network_security_group.rb +9 -16
  354. data/test/requests/network/test_get_public_ip.rb +26 -0
  355. data/test/requests/network/test_get_subnet.rb +9 -16
  356. data/test/requests/network/test_get_virtual_network.rb +26 -0
  357. data/test/requests/network/test_get_virtual_network_gateway.rb +24 -0
  358. data/test/requests/network/test_list_express_route_circuit_peerings.rb +24 -0
  359. data/test/requests/network/test_list_express_route_circuits.rb +26 -0
  360. data/test/requests/network/test_list_express_route_service_providers.rb +24 -0
  361. data/test/requests/network/test_list_load_balancers.rb +8 -15
  362. data/test/requests/network/test_list_network_interfaces.rb +8 -15
  363. data/test/requests/network/test_list_network_security_groups.rb +9 -16
  364. data/test/requests/network/test_list_public_ips.rb +8 -15
  365. data/test/requests/network/test_list_subnets.rb +8 -15
  366. data/test/requests/network/test_list_virtual_network_gateways.rb +24 -0
  367. data/test/requests/network/test_list_virtual_networks.rb +8 -15
  368. data/test/requests/network/test_remove_address_prefixes_from_virtual_network.rb +11 -27
  369. data/test/requests/network/test_remove_dns_servers_from_virtual_network.rb +11 -27
  370. data/test/requests/network/test_remove_security_rule.rb +11 -31
  371. data/test/requests/network/test_remove_subnets_from_virtual_network.rb +11 -27
  372. data/test/requests/resources/test_create_deployment.rb +10 -27
  373. data/test/requests/resources/test_create_resource_group.rb +8 -15
  374. data/test/requests/resources/test_delete_deployment.rb +5 -11
  375. data/test/requests/resources/test_delete_resource_group.rb +8 -14
  376. data/test/requests/resources/test_delete_resource_tag.rb +12 -28
  377. data/test/requests/resources/test_list_deployments.rb +8 -15
  378. data/test/requests/resources/test_list_resource_groups.rb +8 -15
  379. data/test/requests/resources/test_list_tagged_resources.rb +8 -15
  380. data/test/requests/resources/test_tag_resource.rb +12 -28
  381. data/test/requests/storage/test_check_storage_account_name_availability.rb +14 -29
  382. data/test/requests/storage/test_create_storage_account.rb +13 -35
  383. data/test/requests/storage/test_delete_storage_account.rb +8 -14
  384. data/test/requests/storage/test_get_storage_access_keys.rb +7 -14
  385. data/test/requests/storage/test_list_storage_accounts.rb +12 -22
  386. data/test/requests/storage/test_list_storage_accounts_for_rg.rb +15 -29
  387. data/test/requests/traffic_manager/test_create_traffic_manager_endpoint.rb +25 -0
  388. data/test/requests/traffic_manager/test_create_traffic_manager_profile.rb +25 -0
  389. data/test/requests/traffic_manager/test_delete_traffic_manager_endpoint.rb +23 -0
  390. data/test/requests/traffic_manager/test_delete_traffic_manager_profile.rb +23 -0
  391. data/test/requests/traffic_manager/test_get_traffic_manager_endpoint.rb +24 -0
  392. data/test/requests/traffic_manager/test_get_traffic_manager_profile.rb +24 -0
  393. data/test/requests/traffic_manager/test_list_traffic_manager_profiles.rb +24 -0
  394. data/test/test_helper.rb +113 -4
  395. metadata +147 -86
  396. data/lib/fog/azurerm/models/network/application_gateway_backend_address_pool.rb +0 -24
  397. data/lib/fog/azurerm/models/network/application_gateway_backend_http_setting.rb +0 -30
  398. data/lib/fog/azurerm/models/network/application_gateway_frontend_ip_configuration.rb +0 -30
  399. data/lib/fog/azurerm/models/network/application_gateway_frontend_port.rb +0 -22
  400. data/lib/fog/azurerm/models/network/application_gateway_http_listener.rb +0 -37
  401. data/lib/fog/azurerm/models/network/application_gateway_ip_configuration.rb +0 -21
  402. data/lib/fog/azurerm/models/network/application_gateway_probe.rb +0 -32
  403. data/lib/fog/azurerm/models/network/application_gateway_request_routing_rule.rb +0 -35
  404. data/lib/fog/azurerm/models/network/application_gateway_ssl_certificate.rb +0 -26
  405. data/lib/fog/azurerm/models/network/application_gateway_url_path_map.rb +0 -32
  406. data/lib/fog/azurerm/models/network/traffic_manager_end_point.rb +0 -63
  407. data/lib/fog/azurerm/models/network/traffic_manager_end_points.rb +0 -29
  408. data/lib/fog/azurerm/models/network/traffic_manager_profile.rb +0 -59
  409. data/lib/fog/azurerm/models/network/traffic_manager_profiles.rb +0 -24
  410. data/lib/fog/azurerm/requests/network/create_traffic_manager_endpoint.rb +0 -78
  411. data/lib/fog/azurerm/requests/network/create_traffic_manager_profile.rb +0 -127
  412. data/lib/fog/azurerm/requests/network/delete_application_gateway.rb +0 -27
  413. data/lib/fog/azurerm/requests/network/delete_traffic_manager_endpoint.rb +0 -37
  414. data/lib/fog/azurerm/requests/network/delete_traffic_manager_profile.rb +0 -37
  415. data/lib/fog/azurerm/requests/network/get_traffic_manager_profile.rb +0 -96
  416. data/lib/fog/azurerm/requests/network/list_application_gateways.rb +0 -31
  417. data/lib/fog/azurerm/requests/network/list_traffic_manager_profiles.rb +0 -98
  418. data/test/api_stub/models/storage/data_disk.rb +0 -30
  419. data/test/api_stub/requests/network/application_gateway.rb +0 -433
  420. data/test/api_stub/requests/network/traffic_manager_endpoint.rb +0 -25
  421. data/test/models/network/test_application_gateway.rb +0 -62
  422. data/test/models/network/test_traffic_manager_end_points.rb +0 -42
  423. data/test/models/network/test_traffic_manager_profiles.rb +0 -41
  424. data/test/requests/network/test_create_application_gateway.rb +0 -61
  425. data/test/requests/network/test_create_network_security_group.rb +0 -45
  426. data/test/requests/network/test_create_traffic_manager_endpoint.rb +0 -32
  427. data/test/requests/network/test_create_traffic_manager_profile.rb +0 -32
  428. data/test/requests/network/test_delete_application_gateway.rb +0 -30
  429. data/test/requests/network/test_delete_traffic_manager_endpoint.rb +0 -28
  430. data/test/requests/network/test_delete_traffic_manager_profile.rb +0 -28
  431. data/test/requests/network/test_get_traffic_manager_profile.rb +0 -29
  432. data/test/requests/network/test_list_application_gateways.rb +0 -31
  433. data/test/requests/network/test_list_traffic_manager_profiles.rb +0 -29
@@ -1,25 +1,24 @@
1
1
  module Fog
2
2
  module Compute
3
3
  class AzureRM
4
- # This class provides the actual implemention for service calls.
4
+ # This class provides the actual implementation for service calls.
5
5
  class Real
6
6
  def deallocate_virtual_machine(resource_group, name)
7
- Fog::Logger.debug "Deallocating Virtual Machine #{name} in Resource Group #{resource_group}."
7
+ msg = "Deallocating Virtual Machine #{name} in Resource Group #{resource_group}"
8
+ Fog::Logger.debug msg
8
9
  begin
9
- promise = @compute_mgmt_client.virtual_machines.deallocate(resource_group, name)
10
- promise.value!
11
- Fog::Logger.debug "Virtual Machine #{name} Deallocated Successfully."
12
- true
10
+ @compute_mgmt_client.virtual_machines.deallocate(resource_group, name)
13
11
  rescue MsRestAzure::AzureOperationError => e
14
- msg = "Error Deallocating Virtual Machine '#{name}' in Resource Group '#{resource_group}'. #{e.body['error']['message']}"
15
- raise msg
12
+ raise_azure_exception(e, msg)
16
13
  end
14
+ Fog::Logger.debug "Virtual Machine #{name} Deallocated Successfully."
15
+ true
17
16
  end
18
17
  end
19
18
  # This class provides the mock implementation for unit tests.
20
19
  class Mock
21
- def deallocate_virtual_machine(resource_group, name)
22
- Fog::Logger.debug "Virtual Machine #{name} from Resource group #{resource_group} Deallocated successfully."
20
+ def deallocate_virtual_machine(*)
21
+ Fog::Logger.debug 'Virtual Machine fog-test-server from Resource group fog-test-rg Deallocated successfully.'
23
22
  true
24
23
  end
25
24
  end
@@ -1,19 +1,18 @@
1
1
  module Fog
2
2
  module Compute
3
3
  class AzureRM
4
- # This class provides the actual implemention for service calls.
4
+ # This class provides the actual implementation for service calls.
5
5
  class Real
6
6
  def delete_availability_set(resource_group, name)
7
+ msg = "Deleting Availability Set: #{name}."
8
+ Fog::Logger.debug msg
7
9
  begin
8
- Fog::Logger.debug "Deleting Availability Set: #{name}."
9
- promise = @compute_mgmt_client.availability_sets.delete(resource_group, name)
10
- promise.value!
11
- Fog::Logger.debug "Availability Set #{name} deleted successfully."
12
- true
10
+ @compute_mgmt_client.availability_sets.delete(resource_group, name)
13
11
  rescue MsRestAzure::AzureOperationError => e
14
- msg = "Exception deleting Availability Set #{name} in Resourse Group #{resource_group}. #{e.body['error']['message']}"
15
- raise msg
12
+ raise_azure_exception(e, msg)
16
13
  end
14
+ Fog::Logger.debug "Availability Set #{name} deleted successfully."
15
+ true
17
16
  end
18
17
  end
19
18
  # This class provides the mock implementation for unit tests.
@@ -1,25 +1,24 @@
1
1
  module Fog
2
2
  module Compute
3
3
  class AzureRM
4
- # This class provides the actual implemention for service calls.
4
+ # This class provides the actual implementation for service calls.
5
5
  class Real
6
6
  def delete_virtual_machine(resource_group, name)
7
- Fog::Logger.debug "Deleting Virtual Machine #{name} from Resource Group #{resource_group}."
7
+ msg = "Deleting Virtual Machine #{name} from Resource Group #{resource_group}"
8
+ Fog::Logger.debug msg
8
9
  begin
9
- promise = @compute_mgmt_client.virtual_machines.delete(resource_group, name)
10
- promise.value!
11
- Fog::Logger.debug "Virtual Machine #{name} Deleted Successfully."
12
- true
10
+ @compute_mgmt_client.virtual_machines.delete(resource_group, name)
13
11
  rescue MsRestAzure::AzureOperationError => e
14
- msg = "Error Deleting Virtual Machine '#{name}' from Resource Group '#{resource_group}'. #{e.body['error']['message']}"
15
- raise msg
12
+ raise_azure_exception(e, msg)
16
13
  end
14
+ Fog::Logger.debug "Virtual Machine #{name} Deleted Successfully."
15
+ true
17
16
  end
18
17
  end
19
18
  # This class provides the mock implementation for unit tests.
20
19
  class Mock
21
- def delete_virtual_machine(resource_group, name)
22
- Fog::Logger.debug "Virtual Machine #{name} from Resource group #{resource_group} deleted successfully."
20
+ def delete_virtual_machine(*)
21
+ Fog::Logger.debug 'Virtual Machine fog-test-server from Resource group fog-test-rg deleted successfully.'
23
22
  true
24
23
  end
25
24
  end
@@ -4,32 +4,31 @@ module Fog
4
4
  # This class provides the actual implementation for service calls.
5
5
  class Real
6
6
  def detach_data_disk_from_vm(resource_group, vm_name, disk_name)
7
- Fog::Logger.debug "Detaching Data Disk #{disk_name} from Virtual Machine #{vm_name} in Resource Group #{resource_group}."
7
+ msg = "Detaching Data Disk #{disk_name} from Virtual Machine #{vm_name} in Resource Group #{resource_group}."
8
+ Fog::Logger.debug msg
8
9
  vm = get_virtual_machine_instance(resource_group, vm_name, @compute_mgmt_client)
9
- vm.properties.storage_profile.data_disks.each_with_index do |disk, index|
10
+ vm.storage_profile.data_disks.each_with_index do |disk, index|
10
11
  if disk.name == disk_name
11
- vm.properties.storage_profile.data_disks.delete_at(index)
12
+ vm.storage_profile.data_disks.delete_at(index)
12
13
  end
13
14
  end
14
15
  vm.resources = nil
15
16
  begin
16
- promise = @compute_mgmt_client.virtual_machines.create_or_update(resource_group, vm_name, vm)
17
- result = promise.value!
18
- Fog::Logger.debug "Data Disk #{disk_name} detached from Virtual Machine #{vm_name} successfully."
19
- Azure::ARM::Compute::Models::VirtualMachine.serialize_object(result.body)
17
+ virtual_machine = @compute_mgmt_client.virtual_machines.create_or_update(resource_group, vm_name, vm)
20
18
  rescue MsRestAzure::AzureOperationError => e
21
- msg = "Error Detaching Data Disk #{disk_name} from Virtual Machine #{vm_name} in Resource Group #{resource_group}. #{e.body['error']['message']}"
22
- raise msg
19
+ raise_azure_exception(e, msg)
23
20
  end
21
+ Fog::Logger.debug "Data Disk #{disk_name} detached from Virtual Machine #{vm_name} successfully."
22
+ virtual_machine
24
23
  end
25
24
  end
26
25
  # This class provides the mock implementation for unit tests.
27
26
  class Mock
28
- def detach_data_disk_from_vm(resource_group, vm_name, disk_name)
29
- {
27
+ def detach_data_disk_from_vm(*)
28
+ vm = {
30
29
  'location' => 'West US',
31
- 'id' => "/subscriptions/########-####-####-####-############/resourceGroups/#{resource_group}/providers/Microsoft.Compute/virtualMachines/#{name}",
32
- 'name' => vm_name,
30
+ 'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Compute/virtualMachines/fog-test-server',
31
+ 'name' => 'fog-test-server',
33
32
  'type' => 'Microsoft.Compute/virtualMachines',
34
33
  'properties' =>
35
34
  {
@@ -48,10 +47,10 @@ module Fog
48
47
  },
49
48
  'osDisk' =>
50
49
  {
51
- 'name' => "#{vm_name}_os_disk",
50
+ 'name' => 'fog-test-server_os_disk',
52
51
  'vhd' =>
53
52
  {
54
- 'uri' => "http://#{storage_account_name}.blob.core.windows.net/vhds/#{vm_name}_os_disk.vhd"
53
+ 'uri' => 'http://mystorage1.blob.core.windows.net/vhds/fog-test-server_os_disk.vhd'
55
54
  },
56
55
  'createOption' => 'FromImage',
57
56
  'osType' => 'Linux',
@@ -59,10 +58,10 @@ module Fog
59
58
  },
60
59
  'dataDisks' => [{
61
60
  'lun' => 0,
62
- 'name' => disk_name,
63
- 'vhd_uri' => "https://confizrg7443.blob.core.windows.net/vhds/#{disk_name}.vhd",
61
+ 'name' => 'fog-test-server_data_disk',
62
+ 'vhd_uri' => 'https://confizrg7443.blob.core.windows.net/vhds/fog-test-server_data_disk.vhd',
64
63
  'create_option' => 'empty',
65
- 'disk_size_gb' => disk_size
64
+ 'disk_size_gb' => 1
66
65
  }]
67
66
  },
68
67
  'osProfile' =>
@@ -80,13 +79,15 @@ module Fog
80
79
  'networkInterfaces' =>
81
80
  [
82
81
  {
83
- 'id' => "/subscriptions/########-####-####-####-############/resourceGroups/#{resource_group}/providers/Microsoft.Network/networkInterfaces/fog-test-vnet"
82
+ 'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Network/networkInterfaces/fog-test-vnet'
84
83
  }
85
84
  ]
86
85
  },
87
86
  'provisioningState' => 'Succeeded'
88
87
  }
89
88
  }
89
+ vm_mapper = Azure::ARM::Compute::Models::VirtualMachine.mapper
90
+ @compute_mgmt_client.deserialize(vm_mapper, vm, 'result.body')
90
91
  end
91
92
  end
92
93
  end
@@ -1,25 +1,24 @@
1
1
  module Fog
2
2
  module Compute
3
3
  class AzureRM
4
- # This class provides the actual implemention for service calls.
4
+ # This class provides the actual implementation for service calls.
5
5
  class Real
6
6
  def generalize_virtual_machine(resource_group, name)
7
- Fog::Logger.debug "Generalizing Virtual Machine #{name} in Resource Group #{resource_group}."
7
+ msg = "Generalizing Virtual Machine #{name} in Resource Group #{resource_group}"
8
+ Fog::Logger.debug msg
8
9
  begin
9
- promise = @compute_mgmt_client.virtual_machines.generalize(resource_group, name)
10
- promise.value!
11
- Fog::Logger.debug "Virtual Machine #{name} Generalized Successfully."
12
- true
10
+ @compute_mgmt_client.virtual_machines.generalize(resource_group, name)
13
11
  rescue MsRestAzure::AzureOperationError => e
14
- msg = "Error Generalizing Virtual Machine '#{name}' in Resource Group '#{resource_group}'. #{e.body['error']['message']}"
15
- raise msg
12
+ raise_azure_exception(e, msg)
16
13
  end
14
+ Fog::Logger.debug "Virtual Machine #{name} Generalized Successfully."
15
+ true
17
16
  end
18
17
  end
19
18
  # This class provides the mock implementation for unit tests.
20
19
  class Mock
21
- def generalize_virtual_machine(resource_group, name)
22
- Fog::Logger.debug "Virtual Machine #{name} from Resource group #{resource_group} Generalized successfully."
20
+ def generalize_virtual_machine(*)
21
+ Fog::Logger.debug 'Virtual Machine fog-test-server from Resource group fog-test-rg Generalized successfully.'
23
22
  true
24
23
  end
25
24
  end
@@ -0,0 +1,32 @@
1
+ module Fog
2
+ module Compute
3
+ class AzureRM
4
+ # This class provides the actual implementation for service call.
5
+ class Real
6
+ def get_availability_set(resource_group, name)
7
+ msg = "Listing Availability Set: #{name} in Resource Group: #{resource_group}"
8
+ Fog::Logger.debug msg
9
+ begin
10
+ @compute_mgmt_client.availability_sets.get(resource_group, name)
11
+ rescue MsRestAzure::AzureOperationError => e
12
+ raise_azure_exception(e, msg)
13
+ end
14
+ end
15
+ end
16
+ # This class provides the mock implementation for unit tests.
17
+ class Mock
18
+ def get_availability_set(*)
19
+ {
20
+ 'id' => "/subscriptions/########-####-####-####-############/resourceGroups/'resource_group'/providers/Microsoft.Compute/virtualMachines/'name'",
21
+ 'name' => 'name',
22
+ 'type' => 'Microsoft.Compute/virtualMachines',
23
+ 'location' => 'westus',
24
+ '@platform_update_domain_count' => UPDATE_DOMAIN_COUNT,
25
+ '@platform_fault_domain_count' => FAULT_DOMAIN_COUNT,
26
+ '@virtual_machines' => []
27
+ }
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
@@ -1,26 +1,27 @@
1
1
  module Fog
2
2
  module Compute
3
3
  class AzureRM
4
- # This class provides the actual implemention for service calls.
4
+ # This class provides the actual implementation for service calls.
5
5
  class Real
6
6
  def get_virtual_machine(resource_group, name)
7
+ msg = "Getting Virtual Machine #{name} from Resource Group '#{resource_group}'"
8
+ Fog::Logger.debug msg
7
9
  begin
8
- promise = @compute_mgmt_client.virtual_machines.get(resource_group, name)
9
- response = promise.value!
10
- Azure::ARM::Compute::Models::VirtualMachine.serialize_object(response.body)
10
+ virtual_machine = @compute_mgmt_client.virtual_machines.get(resource_group, name)
11
11
  rescue MsRestAzure::AzureOperationError => e
12
- msg = "Exception getting Virtual Machine #{name} from Resource Group '#{resource_group}'. #{e.body['error']['message']}"
13
- raise msg
12
+ raise_azure_exception(e, msg)
14
13
  end
14
+ Fog::Logger.debug "Getting Virtual Machine #{name} from Resource Group '#{resource_group}' successful"
15
+ virtual_machine
15
16
  end
16
17
  end
17
18
  # This class provides the mock implementation for unit tests.
18
19
  class Mock
19
- def get_virtual_machine(resource_group, name)
20
- {
20
+ def get_virtual_machine(*)
21
+ vm = {
21
22
  'location' => 'westus',
22
- 'id' => "/subscriptions/########-####-####-####-############/resourceGroups/#{resource_group}/providers/Microsoft.Compute/virtualMachines/#{name}",
23
- 'name' => name,
23
+ 'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Compute/virtualMachines/fog-test-server',
24
+ 'name' => 'fog-test-server',
24
25
  'type' => 'Microsoft.Compute/virtualMachines',
25
26
  'properties' =>
26
27
  {
@@ -39,10 +40,10 @@ module Fog
39
40
  },
40
41
  'osDisk' =>
41
42
  {
42
- 'name' => "#{name}_os_disk",
43
+ 'name' => "fog-test-server_os_disk",
43
44
  'vhd' =>
44
45
  {
45
- 'uri' => 'http://fogtestsafirst.blob.core.windows.net/vhds/testVM_os_disk.vhd'
46
+ 'uri' => 'http://fogtestsafirst.blob.core.windows.net/vhds/fog-test-server_os_disk.vhd'
46
47
  },
47
48
  'createOption' => 'FromImage',
48
49
  'osType' => 'Linux',
@@ -52,7 +53,7 @@ module Fog
52
53
  },
53
54
  'osProfile' =>
54
55
  {
55
- 'computerName' => name,
56
+ 'computerName' => 'fog',
56
57
  'adminUsername' => 'testfog',
57
58
  'linuxConfiguration' =>
58
59
  {
@@ -65,13 +66,15 @@ module Fog
65
66
  'networkInterfaces' =>
66
67
  [
67
68
  {
68
- 'id' => "/subscriptions/########-####-####-####-############/resourceGroups/#{resource_group}/providers/Microsoft.Network/networkInterfaces/testNIC"
69
+ 'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Network/networkInterfaces/fog-test-vnet'
69
70
  }
70
71
  ]
71
72
  },
72
73
  'provisioningState' => 'Succeeded'
73
74
  }
74
75
  }
76
+ vm_mapper = Azure::ARM::Compute::Models::VirtualMachine.mapper
77
+ @compute_mgmt_client.deserialize(vm_mapper, vm, 'result.body')
75
78
  end
76
79
  end
77
80
  end
@@ -1,17 +1,18 @@
1
1
  module Fog
2
2
  module Compute
3
3
  class AzureRM
4
- # This class provides the actual implemention for service calls.
4
+ # This class provides the actual implementation for service calls.
5
5
  class Real
6
6
  def list_availability_sets(resource_group)
7
+ msg = "Listing Availability Sets in Resource Group: #{resource_group}"
8
+ Fog::Logger.debug msg
7
9
  begin
8
- promise = @compute_mgmt_client.availability_sets.list(resource_group)
9
- response = promise.value!
10
- Azure::ARM::Compute::Models::AvailabilitySetListResult.serialize_object(response.body)['value']
10
+ avail_sets = @compute_mgmt_client.availability_sets.list(resource_group)
11
11
  rescue MsRestAzure::AzureOperationError => e
12
- msg = "Exception listing availability sets in Resource Group #{resource_group}. #{e.body['error']['message']}"
13
- raise msg
12
+ raise_azure_exception(e, msg)
14
13
  end
14
+ Fog::Logger.debug "Listing Availability Sets in Resource Group: #{resource_group} successful."
15
+ avail_sets.value
15
16
  end
16
17
  end
17
18
  # This class provides the mock implementation for unit tests.
@@ -1,48 +1,54 @@
1
1
  module Fog
2
2
  module Compute
3
3
  class AzureRM
4
- # This class provides the actual implemention for service calls.
4
+ # This class provides the actual implementation for service calls.
5
5
  class Real
6
6
  def list_available_sizes_for_virtual_machine(resource_group, name)
7
+ msg = "Listing sizes for Virtual Machine #{name} in Resource Group #{resource_group}"
8
+ Fog::Logger.debug msg
7
9
  begin
8
- response = @compute_mgmt_client.virtual_machines.list_available_sizes(resource_group, name)
9
- result = response.value!
10
- Azure::ARM::Compute::Models::VirtualMachineSizeListResult.serialize_object(result.body)['value']
10
+ vm_sizes = @compute_mgmt_client.virtual_machines.list_available_sizes(resource_group, name)
11
11
  rescue MsRestAzure::AzureOperationError => e
12
- msg = "Error listing Sizes for Virtual Machine #{name} in Resource Group '#{resource_group}'. #{e.body['error']['message']}"
13
- raise msg
12
+ raise_azure_exception(e, msg)
14
13
  end
14
+ Fog::Logger.debug "Successfully listed sizes for Virtual Machine #{name} in Resource Group #{resource_group}"
15
+ vm_sizes.value
15
16
  end
16
17
  end
17
18
  # This class provides the mock implementation for unit tests.
18
19
  class Mock
19
- def list_available_sizes_for_virtual_machine(_resource_group, _name)
20
- [
20
+ def list_available_sizes_for_virtual_machine(*)
21
+ vm_sizes =
21
22
  {
22
- 'name' => 'Standard_A0',
23
- 'numberOfCores' => 1,
24
- 'osDiskSizeInMB' => 1_047_552,
25
- 'resourceDiskSizeInMB' => 20_480,
26
- 'memoryInMB' => 768,
27
- 'maxDataDiskCount' => 1
28
- },
29
- {
30
- 'name' => 'Standard_A1',
31
- 'numberOfCores' => 1,
32
- 'osDiskSizeInMB' => 1_047_552,
33
- 'resourceDiskSizeInMB' => 71_680,
34
- 'memoryInMB' => 1792,
35
- 'maxDataDiskCount' => 2
36
- },
37
- {
38
- 'name' => 'Standard_A2',
39
- 'numberOfCores' => 2,
40
- 'osDiskSizeInMB' => 1_047_552,
41
- 'resourceDiskSizeInMB' => 138_240,
42
- 'memoryInMB' => 3584,
43
- 'maxDataDiskCount' => 4
23
+ 'value' => [
24
+ {
25
+ 'name' => 'Standard_A0',
26
+ 'numberOfCores' => 1,
27
+ 'osDiskSizeInMB' => 1_047_552,
28
+ 'resourceDiskSizeInMB' => 20_480,
29
+ 'memoryInMB' => 768,
30
+ 'maxDataDiskCount' => 1
31
+ },
32
+ {
33
+ 'name' => 'Standard_A1',
34
+ 'numberOfCores' => 1,
35
+ 'osDiskSizeInMB' => 1_047_552,
36
+ 'resourceDiskSizeInMB' => 71_680,
37
+ 'memoryInMB' => 1792,
38
+ 'maxDataDiskCount' => 2
39
+ },
40
+ {
41
+ 'name' => 'Standard_A2',
42
+ 'numberOfCores' => 2,
43
+ 'osDiskSizeInMB' => 1_047_552,
44
+ 'resourceDiskSizeInMB' => 138_240,
45
+ 'memoryInMB' => 3584,
46
+ 'maxDataDiskCount' => 4
47
+ }
48
+ ]
44
49
  }
45
- ]
50
+ vm_mapper = Azure::ARM::Compute::Models::VirtualMachineSizeListResult.mapper
51
+ @compute_mgmt_client.deserialize(vm_mapper, vm_sizes, 'result.body').value
46
52
  end
47
53
  end
48
54
  end
@@ -1,62 +1,67 @@
1
1
  module Fog
2
2
  module Compute
3
3
  class AzureRM
4
- # This class provides the actual implemention for service calls.
4
+ # This class provides the actual implementation for service calls.
5
5
  class Real
6
6
  def list_virtual_machines(resource_group)
7
+ msg = "Listing Virtual Machines in Resource Group '#{resource_group}'"
8
+ Fog::Logger.debug msg
7
9
  begin
8
- response = @compute_mgmt_client.virtual_machines.list(resource_group)
9
- result = response.value!
10
- Azure::ARM::Compute::Models::VirtualMachineListResult.serialize_object(result.body)['value']
10
+ virtual_machines = @compute_mgmt_client.virtual_machines.list_as_lazy(resource_group)
11
11
  rescue MsRestAzure::AzureOperationError => e
12
- msg = "Error listing Virtual Machines in Resource Group '#{resource_group}'. #{e.body['error']['message']}"
13
- raise msg
12
+ raise_azure_exception(e, msg)
14
13
  end
14
+ Fog::Logger.debug "listing Virtual Machines in Resource Group '#{resource_group}' successful"
15
+ virtual_machines.value
15
16
  end
16
17
  end
17
18
  # This class provides the mock implementation for unit tests.
18
19
  class Mock
19
- def list_virtual_machines(resource_group)
20
- [
21
- {
22
- 'id' => "/subscriptions/########-####-####-####-############/resourceGroups/#{resource_group}/providers/Microsoft.Compute/virtualMachines/fog-test-server",
23
- 'name' => 'fog-test-server',
24
- 'location' => 'West US',
25
- 'properties' => {
26
- 'hardwareProfile' => {
27
- 'vmSize' => 'Basic_A0'
28
- },
29
- 'storageProfile' => {
30
- 'imageReference' => {
31
- 'publisher' => 'Canonical',
32
- 'offer' => 'UbuntuServer',
33
- 'sku' => '14.04.2-LTS',
34
- 'version' => 'latest'
20
+ def list_virtual_machines(*)
21
+ vms = {
22
+ 'value' => [
23
+ {
24
+ 'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Compute/virtualMachines/fog-test-server',
25
+ 'name' => 'fog-test-server',
26
+ 'location' => 'West US',
27
+ 'properties' => {
28
+ 'hardwareProfile' => {
29
+ 'vmSize' => 'Basic_A0'
35
30
  },
36
- 'osDisk' => {
37
- 'name' => 'fog-test-server_os_disk',
38
- 'vhd' => {
39
- 'uri' => 'http://storageAccount.blob.core.windows.net/vhds/fog-test-server_os_disk.vhd'
31
+ 'storageProfile' => {
32
+ 'imageReference' => {
33
+ 'publisher' => 'Canonical',
34
+ 'offer' => 'UbuntuServer',
35
+ 'sku' => '14.04.2-LTS',
36
+ 'version' => 'latest'
37
+ },
38
+ 'osDisk' => {
39
+ 'name' => 'fog-test-server_os_disk',
40
+ 'vhd' => {
41
+ 'uri' => 'http://storageAccount.blob.core.windows.net/vhds/fog-test-server_os_disk.vhd'
42
+ }
40
43
  }
41
- }
42
- },
43
- 'osProfile' => {
44
- 'computerName' => 'fog-test-server',
45
- 'adminUsername' => 'shaffan',
46
- 'linuxConfiguration' => {
47
- 'disablePasswordAuthentication' => false
48
- }
49
- },
50
- 'networkProfile' => {
51
- 'networkInterfaces' => [
52
- {
53
- 'id' => "/subscriptions/########-####-####-####-############/resourceGroups/#{resource_group}/providers/Microsoft.Network/networkInterfaces/fogtestnetworkinterface"
44
+ },
45
+ 'osProfile' => {
46
+ 'computerName' => 'fog-test-server',
47
+ 'adminUsername' => 'shaffan',
48
+ 'linuxConfiguration' => {
49
+ 'disablePasswordAuthentication' => false
54
50
  }
55
- ]
51
+ },
52
+ 'networkProfile' => {
53
+ 'networkInterfaces' => [
54
+ {
55
+ 'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Network/networkInterfaces/fog-test-vnet'
56
+ }
57
+ ]
58
+ }
56
59
  }
57
60
  }
58
- }
59
- ]
61
+ ]
62
+ }
63
+ vm_mapper = Azure::ARM::Compute::Models::VirtualMachineListResult.mapper
64
+ @compute_mgmt_client.deserialize(vm_mapper, vms, 'result.body').value
60
65
  end
61
66
  end
62
67
  end