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
@@ -54,7 +54,7 @@ module Fog
54
54
  end
55
55
  end
56
56
 
57
- # This class provides the actual implemention for service calls.
57
+ # This class provides the actual implementation for service calls.
58
58
  class Real
59
59
  def initialize(options)
60
60
  begin
@@ -0,0 +1,56 @@
1
+ require 'fog/azurerm/core'
2
+ module Fog
3
+ module TrafficManager
4
+ # This class registers models, requests and collections
5
+ class AzureRM < Fog::Service
6
+ requires :tenant_id
7
+ requires :client_id
8
+ requires :client_secret
9
+ requires :subscription_id
10
+
11
+ request_path 'fog/azurerm/requests/traffic_manager'
12
+ request :create_traffic_manager_profile
13
+ request :delete_traffic_manager_profile
14
+ request :get_traffic_manager_profile
15
+ request :list_traffic_manager_profiles
16
+
17
+ request :create_traffic_manager_endpoint
18
+ request :delete_traffic_manager_endpoint
19
+ request :get_traffic_manager_endpoint
20
+
21
+ model_path 'fog/azurerm/models/traffic_manager'
22
+ model :traffic_manager_profile
23
+ collection :traffic_manager_profiles
24
+
25
+ model :traffic_manager_end_point
26
+ collection :traffic_manager_end_points
27
+
28
+ # This class provides the actual implementation for service calls.
29
+ class Real
30
+ def initialize(options)
31
+ begin
32
+ require 'azure_mgmt_traffic_manager'
33
+ rescue LoadError => e
34
+ retry if require('rubygems')
35
+ raise e.message
36
+ end
37
+
38
+ credentials = Fog::Credentials::AzureRM.get_credentials(options[:tenant_id], options[:client_id], options[:client_secret])
39
+ @traffic_mgmt_client = ::Azure::ARM::TrafficManager::TrafficManagerManagementClient.new(credentials)
40
+ @traffic_mgmt_client.subscription_id = options[:subscription_id]
41
+ end
42
+ end
43
+ # This class provides the mock implementation for unit tests.
44
+ class Mock
45
+ def initialize(_options = {})
46
+ begin
47
+ require 'azure_mgmt_traffic_manager'
48
+ rescue LoadError => e
49
+ retry if require('rubygems')
50
+ raise e.message
51
+ end
52
+ end
53
+ end
54
+ end
55
+ end
56
+ end
@@ -8,6 +8,26 @@ def get_virtual_network_from_id(subnet_id)
8
8
  subnet_id.split('/')[8]
9
9
  end
10
10
 
11
+ # Extract Endpoint type from (String)
12
+ def get_end_point_type(endpoint_type)
13
+ endpoint_type.split('/')[2]
14
+ end
15
+
16
+ # Extract Traffic Manager Profile Name from Endpoint id(String)
17
+ def get_traffic_manager_profile_name_from_endpoint_id(endpoint_id)
18
+ endpoint_id.split('/')[8]
19
+ end
20
+
21
+ def get_record_type(type)
22
+ type.split('/').last
23
+ end
24
+
25
+ def raise_azure_exception(exception, msg)
26
+ message = "Exception in #{msg} #{exception.body['error']['message'] unless exception.body['error']['message'].nil?} Type: #{exception.class} \n "
27
+ Fog::Logger.debug exception.backtrace
28
+ raise message
29
+ end
30
+
11
31
  # Make sure if input_params(Hash) contains all keys present in required_params(Array)
12
32
  def validate_params(required_params, input_params)
13
33
  missing_params = required_params.select { |param| param unless input_params.key?(param) }
@@ -16,3 +36,11 @@ def validate_params(required_params, input_params)
16
36
  raise(ArgumentError, "Missing Parameters: #{missing_params.join(', ')} required for this operation")
17
37
  end
18
38
  end
39
+
40
+ def get_resource_from_resource_id(resource_id, position)
41
+ data = resource_id.split('/') unless resource_id.nil?
42
+
43
+ raise 'Invalid Resource ID' if data.count < 9 && data.count != 5
44
+
45
+ data[position]
46
+ end
@@ -1,5 +1,5 @@
1
1
  module Fog
2
2
  module AzureRM
3
- VERSION = '0.0.4'.freeze
3
+ VERSION = '0.0.5'.freeze
4
4
  end
5
5
  end
data/test/api_stub.rb CHANGED
@@ -4,7 +4,6 @@ require File.expand_path 'api_stub/models/resources/resource_group', __dir__
4
4
  require File.expand_path 'api_stub/models/resources/deployment', __dir__
5
5
  require File.expand_path 'api_stub/models/resources/resource', __dir__
6
6
  require File.expand_path 'api_stub/models/storage/storageaccount', __dir__
7
- require File.expand_path 'api_stub/models/storage/data_disk', __dir__
8
7
  require File.expand_path 'api_stub/models/storage/blob', __dir__
9
8
  require File.expand_path 'api_stub/models/storage/container', __dir__
10
9
  require File.expand_path 'api_stub/models/network/public_ip', __dir__
@@ -13,9 +12,13 @@ require File.expand_path 'api_stub/models/network/virtual_network', __dir__
13
12
  require File.expand_path 'api_stub/models/network/network_interface', __dir__
14
13
  require File.expand_path 'api_stub/models/network/load_balancer', __dir__
15
14
  require File.expand_path 'api_stub/models/network/network_security_group', __dir__
16
- require File.expand_path 'api_stub/models/network/application_gateway', __dir__
17
- require File.expand_path 'api_stub/models/network/traffic_manager_end_point', __dir__
18
- require File.expand_path 'api_stub/models/network/traffic_manager_profile', __dir__
15
+ require File.expand_path 'api_stub/models/application_gateway/gateway', __dir__
16
+ require File.expand_path 'api_stub/models/network/virtual_network_gateway', __dir__
17
+ require File.expand_path 'api_stub/models/network/express_route_circuit', __dir__
18
+ require File.expand_path 'api_stub/models/network/express_route_circuit_peering', __dir__
19
+ require File.expand_path 'api_stub/models/network/express_route_service_provider', __dir__
20
+ require File.expand_path 'api_stub/models/traffic_manager/traffic_manager_end_point', __dir__
21
+ require File.expand_path 'api_stub/models/traffic_manager/traffic_manager_profile', __dir__
19
22
  require File.expand_path 'api_stub/models/dns/zone', __dir__
20
23
  require File.expand_path 'api_stub/models/dns/record_set', __dir__
21
24
 
@@ -33,9 +36,13 @@ require File.expand_path 'api_stub/requests/network/virtual_network', __dir__
33
36
  require File.expand_path 'api_stub/requests/network/network_interface', __dir__
34
37
  require File.expand_path 'api_stub/requests/network/load_balancer', __dir__
35
38
  require File.expand_path 'api_stub/requests/network/network_security_group', __dir__
36
- require File.expand_path 'api_stub/requests/network/application_gateway', __dir__
37
- require File.expand_path 'api_stub/requests/network/traffic_manager_endpoint', __dir__
38
- require File.expand_path 'api_stub/requests/network/traffic_manager_profile', __dir__
39
+ require File.expand_path 'api_stub/requests/application_gateway/gateway', __dir__
40
+ require File.expand_path 'api_stub/requests/network/virtual_network_gateway', __dir__
41
+ require File.expand_path 'api_stub/requests/network/express_route_circuit', __dir__
42
+ require File.expand_path 'api_stub/requests/network/express_route_circuit_peering', __dir__
43
+ require File.expand_path 'api_stub/requests/network/express_route_service_provider', __dir__
44
+ require File.expand_path 'api_stub/requests/traffic_manager/traffic_manager_endpoint', __dir__
45
+ require File.expand_path 'api_stub/requests/traffic_manager/traffic_manager_profile', __dir__
39
46
  require File.expand_path 'api_stub/requests/dns/zone', __dir__
40
47
  require File.expand_path 'api_stub/requests/dns/record_set', __dir__
41
48
 
@@ -1,8 +1,8 @@
1
1
  module ApiStub
2
2
  module Models
3
- module Network
4
- class ApplicationGateway
5
- def self.create_application_gateway_response
3
+ module ApplicationGateway
4
+ class Gateway
5
+ def self.create_application_gateway_response(gateway_client)
6
6
  gateway = '{
7
7
  "id": "/subscriptions/{guid}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/ag-demoagplat",
8
8
  "name": "gateway",
@@ -59,9 +59,9 @@ module ApiStub
59
59
  "protocol": "<probeProtocol>",
60
60
  "host": "<probeHost>",
61
61
  "path": "<probePath>",
62
- "interval": "<probeIntervalInSec>",
63
- "timeout": "<probeTimeoutInSec>",
64
- "unhealthyThreshold": "<probeUnhealthyThreshold>"
62
+ "interval": "30",
63
+ "timeout": "20",
64
+ "unhealthyThreshold": "20"
65
65
  }
66
66
  }],
67
67
  "backendAddressPools": [{
@@ -127,7 +127,8 @@ module ApiStub
127
127
  "provisioningState": "Succeeded"
128
128
  }
129
129
  }'
130
- JSON.parse(gateway)
130
+ gateway_mapper = Azure::ARM::Network::Models::ApplicationGateway.mapper
131
+ gateway_client.deserialize(gateway_mapper, JSON.load(gateway), 'result.body')
131
132
  end
132
133
  end
133
134
  end
@@ -3,17 +3,46 @@ module ApiStub
3
3
  module Compute
4
4
  # Mock class for Availability Set Model
5
5
  class AvailabilitySet
6
- def self.create_availability_set_response
7
- {
6
+ def self.create_availability_set_response(sdk_compute_client)
7
+ avail_set = {
8
8
  'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Compute/availabilitySets/fog-test-availability-set',
9
9
  'name' => 'fog-test-availability-set',
10
10
  'type' => 'Microsoft.Compute/availabilitySets',
11
11
  'location' => 'westus',
12
- 'properties' => {
13
- 'platformUpdateDomainCount' => 5,
14
- 'platformFaultDomainCount' => 3
15
- }
12
+ 'platformUpdateDomainCount' => UPDATE_DOMAIN_COUNT,
13
+ 'platformFaultDomainCount' => FAULT_DOMAIN_COUNT
14
+
16
15
  }
16
+ result_mapper = Azure::ARM::Compute::Models::AvailabilitySet.mapper
17
+ sdk_compute_client.deserialize(result_mapper, avail_set, 'result.body')
18
+ end
19
+
20
+ def self.list_availability_set_response(sdk_compute_client)
21
+ avail_set = {
22
+ 'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Compute/availabilitySets/fog-test-availability-set',
23
+ 'name' => 'fog-test-availability-set',
24
+ 'type' => 'Microsoft.Compute/availabilitySets',
25
+ 'location' => 'westus',
26
+ 'platformUpdateDomainCount' => UPDATE_DOMAIN_COUNT,
27
+ 'platformFaultDomainCount' => FAULT_DOMAIN_COUNT
28
+
29
+ }
30
+ result_mapper = Azure::ARM::Compute::Models::AvailabilitySet.mapper
31
+ sdk_compute_client.deserialize(result_mapper, avail_set, 'result.body')
32
+ end
33
+
34
+ def self.get_availability_set_response(sdk_compute_client)
35
+ avail_set = {
36
+ 'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Compute/availabilitySets/fog-test-availability-set',
37
+ 'name' => 'fog-test-availability-set',
38
+ 'type' => 'Microsoft.Compute/availabilitySets',
39
+ 'location' => 'westus',
40
+ 'platformUpdateDomainCount' => UPDATE_DOMAIN_COUNT,
41
+ 'platformFaultDomainCount' => FAULT_DOMAIN_COUNT
42
+
43
+ }
44
+ result_mapper = Azure::ARM::Compute::Models::AvailabilitySet.mapper
45
+ sdk_compute_client.deserialize(result_mapper, avail_set, 'result.body')
17
46
  end
18
47
  end
19
48
  end
@@ -3,8 +3,8 @@ module ApiStub
3
3
  module Compute
4
4
  # Mock class for Server Model
5
5
  class Server
6
- def self.create_linux_virtual_machine_response
7
- {
6
+ def self.create_linux_virtual_machine_response(compute_client)
7
+ body = {
8
8
  'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Compute/virtualMachines/fog-test-server',
9
9
  'name' => 'fog-test-server',
10
10
  'location' => 'West US',
@@ -52,10 +52,12 @@ module ApiStub
52
52
  }
53
53
  }
54
54
  }
55
+ vm_mapper = Azure::ARM::Compute::Models::VirtualMachine.mapper
56
+ compute_client.deserialize(vm_mapper, body, 'result.body')
55
57
  end
56
58
 
57
- def self.create_windows_virtual_machine_response
58
- {
59
+ def self.create_windows_virtual_machine_response(compute_client)
60
+ body = {
59
61
  'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Compute/virtualMachines/fog-test-server',
60
62
  'name' => 'fog-test-server',
61
63
  'location' => 'West US',
@@ -88,12 +90,6 @@ module ApiStub
88
90
  'certificateUrl' => 'certificateUrl'
89
91
  }]
90
92
  },
91
- 'additionalUnattendContent' => {
92
- 'pass' => 'oobesystem',
93
- 'component' => 'Microsoft-Windows-Shell-Setup',
94
- 'settingName' => 'FirstLogonCommands|AutoLogon',
95
- 'content' => '<XML unattend content>'
96
- },
97
93
  'enableAutomaticUpdates' => true
98
94
  },
99
95
  'secrets' => []
@@ -107,9 +103,11 @@ module ApiStub
107
103
  }
108
104
  }
109
105
  }
106
+ vm_mapper = Azure::ARM::Compute::Models::VirtualMachine.mapper
107
+ compute_client.deserialize(vm_mapper, body, 'result.body')
110
108
  end
111
109
 
112
- def self.list_available_sizes_for_virtual_machine_response
110
+ def self.list_available_sizes_for_virtual_machine_response(compute_client)
113
111
  body = '{
114
112
  "value": [
115
113
  {
@@ -122,13 +120,12 @@ module ApiStub
122
120
  }
123
121
  ]
124
122
  }'
125
- result = MsRestAzure::AzureOperationResponse.new(MsRest::HttpOperationRequest.new('', '', ''), Faraday::Response.new)
126
- result.body = Azure::ARM::Compute::Models::VirtualMachineSizeListResult.deserialize_object(JSON.load(body))
127
- result.body.value
123
+ vm_mapper = Azure::ARM::Compute::Models::VirtualMachineSizeListResult.mapper
124
+ compute_client.deserialize(vm_mapper, JSON.load(body), 'result.body').value
128
125
  end
129
126
 
130
- def self.attach_data_disk_response
131
- {
127
+ def self.attach_data_disk_response(compute_client)
128
+ body = {
132
129
  'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog-test-rg/providers/Microsoft.Compute/virtualMachines/fog-test-server',
133
130
  'name' => 'fog-test-server',
134
131
  'location' => 'West US',
@@ -184,6 +181,8 @@ module ApiStub
184
181
  }
185
182
  }
186
183
  }
184
+ vm_mapper = Azure::ARM::Compute::Models::VirtualMachine.mapper
185
+ compute_client.deserialize(vm_mapper, body, 'result.body')
187
186
  end
188
187
  end
189
188
  end
@@ -53,6 +53,26 @@ module ApiStub
53
53
  }
54
54
  }
55
55
  end
56
+
57
+ def self.response_for_cname
58
+ {
59
+ 'id' => '/subscriptions/########-####-####-####-############/resourceGroups/EdgeMonitoring2/providers/Microsoft.Network/dnszones/edgemonitoring2.com./CNAME/www',
60
+ 'location' => 'global',
61
+ 'name' => 'www',
62
+ 'tags' => {},
63
+ 'type' => 'Microsoft.Network/dnszones/CNAME',
64
+ 'etag' => '5b83020b-b59c-44be-8f19-a052ebe80fe7',
65
+ 'properties' => {
66
+ 'metadata' => 'nil',
67
+ 'fqdn' => 'fog-test-record_set.fog-test-zone.com.',
68
+ 'TTL' => '60',
69
+ 'CNAMERecord' =>
70
+ {
71
+ 'cname' => 'test.fog.com'
72
+ }
73
+ }
74
+ }
75
+ end
56
76
  end
57
77
  end
58
78
  end
@@ -0,0 +1,47 @@
1
+ module ApiStub
2
+ module Models
3
+ module Network
4
+ # Mock class for Express Route Circuit Model
5
+ class ExpressRouteCircuit
6
+ def self.create_express_route_circuit_response(network_client)
7
+ circuit = '{
8
+ "name": "<circuit name>",
9
+ "id": "/subscriptions/{guid}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/testCircuit",
10
+ "location": "<location>",
11
+ "tags": {
12
+ "key1": "value1",
13
+ "key2": "value2"
14
+ },
15
+ "sku": {
16
+ "name": "Standard_MeteredData",
17
+ "tier": "Standard",
18
+ "family": "MeteredData"
19
+ },
20
+ "properties": {
21
+ "serviceProviderProperties": {
22
+ "serviceProviderName": "serviceProviderName",
23
+ "peeringLocation": "<peering location>",
24
+ "bandwidthInMbps": 100
25
+ },
26
+ "peerings": [
27
+ {
28
+ "name": "AzurePublicPeering",
29
+ "id": "/subscriptions/{guid}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}",
30
+ "properties": {
31
+ "peeringType": "AzurePublicPeering",
32
+ "peerASN": 100,
33
+ "PrimaryPeerAddressPrefix": "192.168.1.0/30",
34
+ "SecondaryPeerAddressPrefix": "192.168.2.0/30",
35
+ "vlanId": 200
36
+ }
37
+ }
38
+ ]
39
+ }
40
+ }'
41
+ express_route_circuit_mapper = Azure::ARM::Network::Models::ExpressRouteCircuit.mapper
42
+ network_client.deserialize(express_route_circuit_mapper, JSON.load(circuit), 'result.body')
43
+ end
44
+ end
45
+ end
46
+ end
47
+ end
@@ -0,0 +1,33 @@
1
+ module ApiStub
2
+ module Models
3
+ module Network
4
+ # Mock class for Express Route Circuit Peering Model
5
+ class ExpressRouteCircuitPeering
6
+ def self.create_express_route_circuit_peering_response(network_client)
7
+ peering = '{
8
+ "name": "MicrosoftPeering",
9
+ "id": "/subscriptions/{guid}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}",
10
+ "properties": {
11
+ "peeringType": "MicrosoftPeering",
12
+ "peerASN": 100,
13
+ "primaryPeerAddressPrefix": "192.168.1.0/30",
14
+ "secondaryPeerAddressPrefix": "192.168.2.0/30",
15
+ "vlanId": 200,
16
+ "microsoftPeeringConfig": {
17
+ "advertisedpublicprefixes": [
18
+ "11.2.3.4/30",
19
+ "12.2.3.4/30"
20
+ ],
21
+ "advertisedPublicPrefixState": "NotConfigured ",
22
+ "customerAsn": 200,
23
+ "routingRegistryName": "<name>"
24
+ }
25
+ }
26
+ }'
27
+ express_route_circuit_peering_mapper = Azure::ARM::Network::Models::ExpressRouteCircuitPeering.mapper
28
+ network_client.deserialize(express_route_circuit_peering_mapper, JSON.load(peering), 'result.body')
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,29 @@
1
+ module ApiStub
2
+ module Models
3
+ module Network
4
+ # Mock class for Express Route Service Provider Model
5
+ class ExpressRouteServiceProvider
6
+ def self.list_express_route_service_provider_response(network_client)
7
+ service_provider = '{
8
+ "value": [
9
+ {
10
+ "name": "providername",
11
+ "peeringLocations": [
12
+ "location1",
13
+ "location2"
14
+ ],
15
+ "bandwidthsOffered": [
16
+ {
17
+ "offerName": "100Mbps",
18
+ "valueInMbps": 100
19
+ }
20
+ ]
21
+ }
22
+ ]}'
23
+ express_route_servcie_provider_mapper = Azure::ARM::Network::Models::ExpressRouteServiceProviderListResult.mapper
24
+ network_client.deserialize(express_route_servcie_provider_mapper, JSON.load(service_provider), 'result.body').value
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end