far-gem 0.5.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.arclint +8 -0
- data/.codeclimate.yml +17 -0
- data/.gitignore +6 -0
- data/.hound.yml +2 -0
- data/.rubocop.yml +38 -0
- data/.travis.yml +47 -0
- data/CHANGELOG.md +356 -0
- data/CONTRIBUTING.md +40 -0
- data/CONTRIBUTORS.md +12 -0
- data/Gemfile +3 -0
- data/LICENSE.md +20 -0
- data/README.md +96 -0
- data/fog-azure-rm.gemspec +37 -0
- data/lib/fog/azurerm.rb +88 -0
- data/lib/fog/azurerm/application_gateway.rb +75 -0
- data/lib/fog/azurerm/async_response.rb +44 -0
- data/lib/fog/azurerm/compute.rb +102 -0
- data/lib/fog/azurerm/config.rb +1 -0
- data/lib/fog/azurerm/constants.rb +71 -0
- data/lib/fog/azurerm/credentials.rb +40 -0
- data/lib/fog/azurerm/dns.rb +70 -0
- data/lib/fog/azurerm/docs/application_gateway.md +245 -0
- data/lib/fog/azurerm/docs/compute.md +499 -0
- data/lib/fog/azurerm/docs/dns.md +149 -0
- data/lib/fog/azurerm/docs/key_vault.md +91 -0
- data/lib/fog/azurerm/docs/network.md +1132 -0
- data/lib/fog/azurerm/docs/resources.md +178 -0
- data/lib/fog/azurerm/docs/sql.md +170 -0
- data/lib/fog/azurerm/docs/storage.md +398 -0
- data/lib/fog/azurerm/docs/structure.md +53 -0
- data/lib/fog/azurerm/docs/traffic_manager.md +161 -0
- data/lib/fog/azurerm/key_vault.rb +51 -0
- data/lib/fog/azurerm/models/application_gateway/backend_address_pool.rb +24 -0
- data/lib/fog/azurerm/models/application_gateway/backend_http_setting.rb +28 -0
- data/lib/fog/azurerm/models/application_gateway/frontend_ip_configuration.rb +26 -0
- data/lib/fog/azurerm/models/application_gateway/frontend_port.rb +20 -0
- data/lib/fog/azurerm/models/application_gateway/gateway.rb +617 -0
- data/lib/fog/azurerm/models/application_gateway/gateways.rb +30 -0
- data/lib/fog/azurerm/models/application_gateway/http_listener.rb +30 -0
- data/lib/fog/azurerm/models/application_gateway/ip_configuration.rb +26 -0
- data/lib/fog/azurerm/models/application_gateway/probe.rb +30 -0
- data/lib/fog/azurerm/models/application_gateway/request_routing_rule.rb +27 -0
- data/lib/fog/azurerm/models/application_gateway/ssl_certificate.rb +24 -0
- data/lib/fog/azurerm/models/application_gateway/url_path_map.rb +30 -0
- data/lib/fog/azurerm/models/compute/availability_set.rb +67 -0
- data/lib/fog/azurerm/models/compute/availability_sets.rb +35 -0
- data/lib/fog/azurerm/models/compute/caching_types.rb +13 -0
- data/lib/fog/azurerm/models/compute/creation_data.rb +23 -0
- data/lib/fog/azurerm/models/compute/data_disk.rb +26 -0
- data/lib/fog/azurerm/models/compute/disk_create_option.rb +16 -0
- data/lib/fog/azurerm/models/compute/disk_create_option_types.rb +13 -0
- data/lib/fog/azurerm/models/compute/encryption_settings.rb +29 -0
- data/lib/fog/azurerm/models/compute/image_disk_reference.rb +15 -0
- data/lib/fog/azurerm/models/compute/managed_disk.rb +77 -0
- data/lib/fog/azurerm/models/compute/managed_disks.rb +43 -0
- data/lib/fog/azurerm/models/compute/operation_status_response.rb +18 -0
- data/lib/fog/azurerm/models/compute/server.rb +268 -0
- data/lib/fog/azurerm/models/compute/servers.rb +47 -0
- data/lib/fog/azurerm/models/compute/virtual_machine_extension.rb +76 -0
- data/lib/fog/azurerm/models/compute/virtual_machine_extensions.rb +31 -0
- data/lib/fog/azurerm/models/dns/a_record.rb +15 -0
- data/lib/fog/azurerm/models/dns/cname_record.rb +15 -0
- data/lib/fog/azurerm/models/dns/record_set.rb +103 -0
- data/lib/fog/azurerm/models/dns/record_sets.rb +34 -0
- data/lib/fog/azurerm/models/dns/zone.rb +58 -0
- data/lib/fog/azurerm/models/dns/zones.rb +29 -0
- data/lib/fog/azurerm/models/key_vault/access_policy_entry.rb +27 -0
- data/lib/fog/azurerm/models/key_vault/vault.rb +78 -0
- data/lib/fog/azurerm/models/key_vault/vaults.rb +27 -0
- data/lib/fog/azurerm/models/network/express_route_circuit.rb +86 -0
- data/lib/fog/azurerm/models/network/express_route_circuit_authorization.rb +50 -0
- data/lib/fog/azurerm/models/network/express_route_circuit_authorizations.rb +28 -0
- data/lib/fog/azurerm/models/network/express_route_circuit_peering.rb +91 -0
- data/lib/fog/azurerm/models/network/express_route_circuit_peerings.rb +27 -0
- data/lib/fog/azurerm/models/network/express_route_circuits.rb +30 -0
- data/lib/fog/azurerm/models/network/express_route_service_provider.rb +29 -0
- data/lib/fog/azurerm/models/network/express_route_service_providers.rb +18 -0
- data/lib/fog/azurerm/models/network/frontend_ip_configuration.rb +27 -0
- data/lib/fog/azurerm/models/network/inbound_nat_pool.rb +26 -0
- data/lib/fog/azurerm/models/network/inbound_nat_rule.rb +26 -0
- data/lib/fog/azurerm/models/network/ipallocation_method.rb +12 -0
- data/lib/fog/azurerm/models/network/load_balancer.rb +249 -0
- data/lib/fog/azurerm/models/network/load_balancers.rb +36 -0
- data/lib/fog/azurerm/models/network/load_balancing_rule.rb +37 -0
- data/lib/fog/azurerm/models/network/local_network_gateway.rb +62 -0
- data/lib/fog/azurerm/models/network/local_network_gateways.rb +27 -0
- data/lib/fog/azurerm/models/network/network_interface.rb +121 -0
- data/lib/fog/azurerm/models/network/network_interfaces.rb +30 -0
- data/lib/fog/azurerm/models/network/network_security_group.rb +114 -0
- data/lib/fog/azurerm/models/network/network_security_groups.rb +30 -0
- data/lib/fog/azurerm/models/network/network_security_rule.rb +66 -0
- data/lib/fog/azurerm/models/network/network_security_rules.rb +31 -0
- data/lib/fog/azurerm/models/network/path_rule.rb +30 -0
- data/lib/fog/azurerm/models/network/probe.rb +28 -0
- data/lib/fog/azurerm/models/network/public_ip.rb +70 -0
- data/lib/fog/azurerm/models/network/public_ips.rb +30 -0
- data/lib/fog/azurerm/models/network/security_rule_access.rb +12 -0
- data/lib/fog/azurerm/models/network/security_rule_direction.rb +12 -0
- data/lib/fog/azurerm/models/network/security_rule_protocol.rb +13 -0
- data/lib/fog/azurerm/models/network/subnet.rb +66 -0
- data/lib/fog/azurerm/models/network/subnets.rb +31 -0
- data/lib/fog/azurerm/models/network/virtual_network.rb +109 -0
- data/lib/fog/azurerm/models/network/virtual_network_gateway.rb +137 -0
- data/lib/fog/azurerm/models/network/virtual_network_gateway_connection.rb +76 -0
- data/lib/fog/azurerm/models/network/virtual_network_gateway_connections.rb +27 -0
- data/lib/fog/azurerm/models/network/virtual_network_gateways.rb +30 -0
- data/lib/fog/azurerm/models/network/virtual_networks.rb +36 -0
- data/lib/fog/azurerm/models/network/vpn_client_configuration.rb +34 -0
- data/lib/fog/azurerm/models/network/vpn_client_revoked_certificates.rb +22 -0
- data/lib/fog/azurerm/models/network/vpn_client_root_certificates.rb +22 -0
- data/lib/fog/azurerm/models/resources/azure_resource.rb +25 -0
- data/lib/fog/azurerm/models/resources/azure_resources.rb +32 -0
- data/lib/fog/azurerm/models/resources/dependency.rb +27 -0
- data/lib/fog/azurerm/models/resources/deployment.rb +65 -0
- data/lib/fog/azurerm/models/resources/deployments.rb +30 -0
- data/lib/fog/azurerm/models/resources/provider.rb +27 -0
- data/lib/fog/azurerm/models/resources/provider_resource_type.rb +22 -0
- data/lib/fog/azurerm/models/resources/resource_group.rb +34 -0
- data/lib/fog/azurerm/models/resources/resource_groups.rb +29 -0
- data/lib/fog/azurerm/models/sql/firewall_rule.rb +48 -0
- data/lib/fog/azurerm/models/sql/firewall_rules.rb +32 -0
- data/lib/fog/azurerm/models/sql/sql_database.rb +67 -0
- data/lib/fog/azurerm/models/sql/sql_databases.rb +32 -0
- data/lib/fog/azurerm/models/sql/sql_server.rb +50 -0
- data/lib/fog/azurerm/models/sql/sql_servers.rb +31 -0
- data/lib/fog/azurerm/models/storage/directories.rb +75 -0
- data/lib/fog/azurerm/models/storage/directory.rb +151 -0
- data/lib/fog/azurerm/models/storage/file.rb +263 -0
- data/lib/fog/azurerm/models/storage/files.rb +183 -0
- data/lib/fog/azurerm/models/storage/kind.rb +12 -0
- data/lib/fog/azurerm/models/storage/sku_name.rb +15 -0
- data/lib/fog/azurerm/models/storage/sku_tier.rb +12 -0
- data/lib/fog/azurerm/models/storage/storage_account.rb +92 -0
- data/lib/fog/azurerm/models/storage/storage_accounts.rb +47 -0
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_end_point.rb +82 -0
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_end_points.rb +30 -0
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_profile.rb +90 -0
- data/lib/fog/azurerm/models/traffic_manager/traffic_manager_profiles.rb +27 -0
- data/lib/fog/azurerm/network.rb +178 -0
- data/lib/fog/azurerm/requests/application_gateway/check_ag_exists.rb +31 -0
- data/lib/fog/azurerm/requests/application_gateway/create_or_update_application_gateway.rb +302 -0
- data/lib/fog/azurerm/requests/application_gateway/delete_application_gateway.rb +26 -0
- data/lib/fog/azurerm/requests/application_gateway/get_application_gateway.rb +159 -0
- data/lib/fog/azurerm/requests/application_gateway/list_application_gateways.rb +29 -0
- data/lib/fog/azurerm/requests/application_gateway/start_application_gateway.rb +27 -0
- data/lib/fog/azurerm/requests/application_gateway/stop_application_gateway.rb +27 -0
- data/lib/fog/azurerm/requests/application_gateway/update_sku_attributes.rb +28 -0
- data/lib/fog/azurerm/requests/application_gateway/update_subnet_id_in_gateway_ip_configuration.rb +29 -0
- data/lib/fog/azurerm/requests/compute/attach_data_disk_to_vm.rb +208 -0
- data/lib/fog/azurerm/requests/compute/check_availability_set_exists.rb +31 -0
- data/lib/fog/azurerm/requests/compute/check_managed_disk_exists.rb +33 -0
- data/lib/fog/azurerm/requests/compute/check_vm_exists.rb +39 -0
- data/lib/fog/azurerm/requests/compute/check_vm_extension_exists.rb +31 -0
- data/lib/fog/azurerm/requests/compute/check_vm_status.rb +38 -0
- data/lib/fog/azurerm/requests/compute/create_availability_set.rb +64 -0
- data/lib/fog/azurerm/requests/compute/create_image.rb +68 -0
- data/lib/fog/azurerm/requests/compute/create_or_update_managed_disk.rb +121 -0
- data/lib/fog/azurerm/requests/compute/create_or_update_vm_extension.rb +63 -0
- data/lib/fog/azurerm/requests/compute/create_virtual_machine.rb +403 -0
- data/lib/fog/azurerm/requests/compute/deallocate_virtual_machine.rb +35 -0
- data/lib/fog/azurerm/requests/compute/delete_availability_set.rb +27 -0
- data/lib/fog/azurerm/requests/compute/delete_image.rb +29 -0
- data/lib/fog/azurerm/requests/compute/delete_managed_disk.rb +29 -0
- data/lib/fog/azurerm/requests/compute/delete_virtual_machine.rb +35 -0
- data/lib/fog/azurerm/requests/compute/delete_vm_extension.rb +28 -0
- data/lib/fog/azurerm/requests/compute/detach_data_disk_from_vm.rb +102 -0
- data/lib/fog/azurerm/requests/compute/generalize_virtual_machine.rb +35 -0
- data/lib/fog/azurerm/requests/compute/get_availability_set.rb +32 -0
- data/lib/fog/azurerm/requests/compute/get_image.rb +45 -0
- data/lib/fog/azurerm/requests/compute/get_managed_disk.rb +64 -0
- data/lib/fog/azurerm/requests/compute/get_virtual_machine.rb +88 -0
- data/lib/fog/azurerm/requests/compute/get_vm_extension.rb +46 -0
- data/lib/fog/azurerm/requests/compute/grant_access_to_managed_disk.rb +30 -0
- data/lib/fog/azurerm/requests/compute/list_availability_sets.rb +40 -0
- data/lib/fog/azurerm/requests/compute/list_available_sizes_for_virtual_machine.rb +64 -0
- data/lib/fog/azurerm/requests/compute/list_managed_disks_by_rg.rb +66 -0
- data/lib/fog/azurerm/requests/compute/list_managed_disks_in_subscription.rb +66 -0
- data/lib/fog/azurerm/requests/compute/list_virtual_machines.rb +69 -0
- data/lib/fog/azurerm/requests/compute/power_off_virtual_machine.rb +35 -0
- data/lib/fog/azurerm/requests/compute/redeploy_virtual_machine.rb +35 -0
- data/lib/fog/azurerm/requests/compute/restart_virtual_machine.rb +35 -0
- data/lib/fog/azurerm/requests/compute/revoke_access_to_managed_disk.rb +33 -0
- data/lib/fog/azurerm/requests/compute/start_virtual_machine.rb +35 -0
- data/lib/fog/azurerm/requests/dns/check_record_set_exists.rb +31 -0
- data/lib/fog/azurerm/requests/dns/check_zone_exists.rb +34 -0
- data/lib/fog/azurerm/requests/dns/create_or_update_record_set.rb +72 -0
- data/lib/fog/azurerm/requests/dns/create_or_update_zone.rb +56 -0
- data/lib/fog/azurerm/requests/dns/delete_record_set.rb +28 -0
- data/lib/fog/azurerm/requests/dns/delete_zone.rb +28 -0
- data/lib/fog/azurerm/requests/dns/get_record_set.rb +47 -0
- data/lib/fog/azurerm/requests/dns/get_records_from_record_set.rb +32 -0
- data/lib/fog/azurerm/requests/dns/get_zone.rb +41 -0
- data/lib/fog/azurerm/requests/dns/list_record_sets.rb +63 -0
- data/lib/fog/azurerm/requests/dns/list_zones.rb +72 -0
- data/lib/fog/azurerm/requests/key_vault/check_vault_exists.rb +31 -0
- data/lib/fog/azurerm/requests/key_vault/create_or_update_vault.rb +106 -0
- data/lib/fog/azurerm/requests/key_vault/delete_vault.rb +28 -0
- data/lib/fog/azurerm/requests/key_vault/get_vault.rb +54 -0
- data/lib/fog/azurerm/requests/key_vault/list_vaults.rb +56 -0
- data/lib/fog/azurerm/requests/network/add_address_prefixes_in_virtual_network.rb +68 -0
- data/lib/fog/azurerm/requests/network/add_dns_servers_in_virtual_network.rb +76 -0
- data/lib/fog/azurerm/requests/network/add_security_rules.rb +154 -0
- data/lib/fog/azurerm/requests/network/add_subnets_in_virtual_network.rb +71 -0
- data/lib/fog/azurerm/requests/network/attach_network_security_group_to_subnet.rb +57 -0
- data/lib/fog/azurerm/requests/network/attach_resource_to_nic.rb +89 -0
- data/lib/fog/azurerm/requests/network/attach_route_table_to_subnet.rb +57 -0
- data/lib/fog/azurerm/requests/network/check_express_route_cir_auth_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_express_route_circuit_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_load_balancer_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_local_net_gateway_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_net_sec_group_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_net_sec_rule_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_network_interface_exists.rb +31 -0
- data/lib/fog/azurerm/requests/network/check_public_ip_exists.rb +33 -0
- data/lib/fog/azurerm/requests/network/check_subnet_exists.rb +32 -0
- data/lib/fog/azurerm/requests/network/check_virtual_network_exists.rb +33 -0
- data/lib/fog/azurerm/requests/network/check_vnet_gateway_connection_exists.rb +32 -0
- data/lib/fog/azurerm/requests/network/check_vnet_gateway_exists.rb +32 -0
- data/lib/fog/azurerm/requests/network/create_load_balancer.rb +189 -0
- data/lib/fog/azurerm/requests/network/create_or_update_express_route_circuit.rb +111 -0
- data/lib/fog/azurerm/requests/network/create_or_update_express_route_circuit_authorization.rb +51 -0
- data/lib/fog/azurerm/requests/network/create_or_update_express_route_circuit_peering.rb +79 -0
- data/lib/fog/azurerm/requests/network/create_or_update_local_network_gateway.rb +79 -0
- data/lib/fog/azurerm/requests/network/create_or_update_network_interface.rb +121 -0
- data/lib/fog/azurerm/requests/network/create_or_update_network_security_group.rb +178 -0
- data/lib/fog/azurerm/requests/network/create_or_update_network_security_rule.rb +59 -0
- data/lib/fog/azurerm/requests/network/create_or_update_public_ip.rb +61 -0
- data/lib/fog/azurerm/requests/network/create_or_update_virtual_network.rb +111 -0
- data/lib/fog/azurerm/requests/network/create_or_update_virtual_network_gateway.rb +159 -0
- data/lib/fog/azurerm/requests/network/create_or_update_virtual_network_gateway_connection.rb +83 -0
- data/lib/fog/azurerm/requests/network/create_subnet.rb +54 -0
- data/lib/fog/azurerm/requests/network/delete_express_route_circuit.rb +28 -0
- data/lib/fog/azurerm/requests/network/delete_express_route_circuit_authorization.rb +29 -0
- data/lib/fog/azurerm/requests/network/delete_express_route_circuit_peering.rb +28 -0
- data/lib/fog/azurerm/requests/network/delete_load_balancer.rb +28 -0
- data/lib/fog/azurerm/requests/network/delete_local_network_gateway.rb +29 -0
- data/lib/fog/azurerm/requests/network/delete_network_interface.rb +28 -0
- data/lib/fog/azurerm/requests/network/delete_network_security_group.rb +30 -0
- data/lib/fog/azurerm/requests/network/delete_network_security_rule.rb +30 -0
- data/lib/fog/azurerm/requests/network/delete_public_ip.rb +27 -0
- data/lib/fog/azurerm/requests/network/delete_subnet.rb +28 -0
- data/lib/fog/azurerm/requests/network/delete_virtual_network.rb +28 -0
- data/lib/fog/azurerm/requests/network/delete_virtual_network_gateway.rb +28 -0
- data/lib/fog/azurerm/requests/network/delete_virtual_network_gateway_connection.rb +29 -0
- data/lib/fog/azurerm/requests/network/detach_network_security_group_from_subnet.rb +51 -0
- data/lib/fog/azurerm/requests/network/detach_resource_from_nic.rb +81 -0
- data/lib/fog/azurerm/requests/network/detach_route_table_from_subnet.rb +51 -0
- data/lib/fog/azurerm/requests/network/get_available_ipaddresses_count.rb +23 -0
- data/lib/fog/azurerm/requests/network/get_connection_shared_key.rb +25 -0
- data/lib/fog/azurerm/requests/network/get_express_route_circuit.rb +51 -0
- data/lib/fog/azurerm/requests/network/get_express_route_circuit_authorization.rb +35 -0
- data/lib/fog/azurerm/requests/network/get_express_route_circuit_peering.rb +48 -0
- data/lib/fog/azurerm/requests/network/get_load_balancer.rb +170 -0
- data/lib/fog/azurerm/requests/network/get_local_network_gateway.rb +47 -0
- data/lib/fog/azurerm/requests/network/get_network_interface.rb +60 -0
- data/lib/fog/azurerm/requests/network/get_network_security_group.rb +165 -0
- data/lib/fog/azurerm/requests/network/get_network_security_rule.rb +47 -0
- data/lib/fog/azurerm/requests/network/get_public_ip.rb +41 -0
- data/lib/fog/azurerm/requests/network/get_subnet.rb +37 -0
- data/lib/fog/azurerm/requests/network/get_virtual_network.rb +62 -0
- data/lib/fog/azurerm/requests/network/get_virtual_network_gateway.rb +45 -0
- data/lib/fog/azurerm/requests/network/get_virtual_network_gateway_connection.rb +47 -0
- data/lib/fog/azurerm/requests/network/list_express_route_circuit_authorizations.rb +37 -0
- data/lib/fog/azurerm/requests/network/list_express_route_circuit_peerings.rb +44 -0
- data/lib/fog/azurerm/requests/network/list_express_route_circuits.rb +53 -0
- data/lib/fog/azurerm/requests/network/list_express_route_service_providers.rb +37 -0
- data/lib/fog/azurerm/requests/network/list_load_balancers.rb +31 -0
- data/lib/fog/azurerm/requests/network/list_load_balancers_in_subscription.rb +31 -0
- data/lib/fog/azurerm/requests/network/list_local_network_gateways.rb +50 -0
- data/lib/fog/azurerm/requests/network/list_network_interfaces.rb +67 -0
- data/lib/fog/azurerm/requests/network/list_network_security_groups.rb +169 -0
- data/lib/fog/azurerm/requests/network/list_network_security_rules.rb +51 -0
- data/lib/fog/azurerm/requests/network/list_public_ips.rb +46 -0
- data/lib/fog/azurerm/requests/network/list_subnets.rb +55 -0
- data/lib/fog/azurerm/requests/network/list_virtual_network_gateway_connections.rb +50 -0
- data/lib/fog/azurerm/requests/network/list_virtual_network_gateways.rb +43 -0
- data/lib/fog/azurerm/requests/network/list_virtual_networks.rb +74 -0
- data/lib/fog/azurerm/requests/network/list_virtual_networks_in_subscription.rb +74 -0
- data/lib/fog/azurerm/requests/network/remove_address_prefixes_from_virtual_network.rb +69 -0
- data/lib/fog/azurerm/requests/network/remove_dns_servers_from_virtual_network.rb +69 -0
- data/lib/fog/azurerm/requests/network/remove_security_rule.rb +157 -0
- data/lib/fog/azurerm/requests/network/remove_subnets_from_virtual_network.rb +59 -0
- data/lib/fog/azurerm/requests/network/reset_connection_shared_key.rb +36 -0
- data/lib/fog/azurerm/requests/network/set_connection_shared_key.rb +36 -0
- data/lib/fog/azurerm/requests/resources/check_azure_resource_exists.rb +40 -0
- data/lib/fog/azurerm/requests/resources/check_deployment_exists.rb +30 -0
- data/lib/fog/azurerm/requests/resources/check_resource_group_exists.rb +30 -0
- data/lib/fog/azurerm/requests/resources/create_deployment.rb +97 -0
- data/lib/fog/azurerm/requests/resources/create_resource_group.rb +40 -0
- data/lib/fog/azurerm/requests/resources/delete_deployment.rb +28 -0
- data/lib/fog/azurerm/requests/resources/delete_resource_group.rb +28 -0
- data/lib/fog/azurerm/requests/resources/delete_resource_tag.rb +44 -0
- data/lib/fog/azurerm/requests/resources/get_deployment.rb +81 -0
- data/lib/fog/azurerm/requests/resources/get_resource_group.rb +47 -0
- data/lib/fog/azurerm/requests/resources/list_deployments.rb +77 -0
- data/lib/fog/azurerm/requests/resources/list_resource_groups.rb +51 -0
- data/lib/fog/azurerm/requests/resources/list_tagged_resources.rb +50 -0
- data/lib/fog/azurerm/requests/resources/tag_resource.rb +43 -0
- data/lib/fog/azurerm/requests/sql/check_database_exists.rb +21 -0
- data/lib/fog/azurerm/requests/sql/check_firewall_rule_exists.rb +21 -0
- data/lib/fog/azurerm/requests/sql/check_sql_server_exists.rb +21 -0
- data/lib/fog/azurerm/requests/sql/create_or_update_database.rb +71 -0
- data/lib/fog/azurerm/requests/sql/create_or_update_firewall_rule.rb +42 -0
- data/lib/fog/azurerm/requests/sql/create_or_update_sql_server.rb +53 -0
- data/lib/fog/azurerm/requests/sql/delete_database.rb +28 -0
- data/lib/fog/azurerm/requests/sql/delete_firewall_rule.rb +29 -0
- data/lib/fog/azurerm/requests/sql/delete_sql_server.rb +29 -0
- data/lib/fog/azurerm/requests/sql/get_database.rb +42 -0
- data/lib/fog/azurerm/requests/sql/get_firewall_rule.rb +37 -0
- data/lib/fog/azurerm/requests/sql/get_sql_server.rb +34 -0
- data/lib/fog/azurerm/requests/sql/list_databases.rb +58 -0
- data/lib/fog/azurerm/requests/sql/list_firewall_rules.rb +49 -0
- data/lib/fog/azurerm/requests/sql/list_sql_servers.rb +44 -0
- data/lib/fog/azurerm/requests/storage/acquire_blob_lease.rb +32 -0
- data/lib/fog/azurerm/requests/storage/acquire_container_lease.rb +32 -0
- data/lib/fog/azurerm/requests/storage/check_container_exists.rb +30 -0
- data/lib/fog/azurerm/requests/storage/check_storage_account_exists.rb +37 -0
- data/lib/fog/azurerm/requests/storage/check_storage_account_name_availability.rb +44 -0
- data/lib/fog/azurerm/requests/storage/commit_blob_blocks.rb +30 -0
- data/lib/fog/azurerm/requests/storage/compare_container_blobs.rb +148 -0
- data/lib/fog/azurerm/requests/storage/copy_blob.rb +30 -0
- data/lib/fog/azurerm/requests/storage/copy_blob_from_uri.rb +30 -0
- data/lib/fog/azurerm/requests/storage/create_block_blob.rb +108 -0
- data/lib/fog/azurerm/requests/storage/create_container.rb +40 -0
- data/lib/fog/azurerm/requests/storage/create_disk.rb +62 -0
- data/lib/fog/azurerm/requests/storage/create_page_blob.rb +31 -0
- data/lib/fog/azurerm/requests/storage/create_storage_account.rb +66 -0
- data/lib/fog/azurerm/requests/storage/delete_blob.rb +32 -0
- data/lib/fog/azurerm/requests/storage/delete_container.rb +31 -0
- data/lib/fog/azurerm/requests/storage/delete_disk.rb +36 -0
- data/lib/fog/azurerm/requests/storage/delete_storage_account.rb +27 -0
- data/lib/fog/azurerm/requests/storage/get_blob.rb +163 -0
- data/lib/fog/azurerm/requests/storage/get_blob_http_url.rb +39 -0
- data/lib/fog/azurerm/requests/storage/get_blob_https_url.rb +39 -0
- data/lib/fog/azurerm/requests/storage/get_blob_properties.rb +55 -0
- data/lib/fog/azurerm/requests/storage/get_blob_url.rb +28 -0
- data/lib/fog/azurerm/requests/storage/get_container_acl.rb +30 -0
- data/lib/fog/azurerm/requests/storage/get_container_properties.rb +41 -0
- data/lib/fog/azurerm/requests/storage/get_container_url.rb +34 -0
- data/lib/fog/azurerm/requests/storage/get_storage_access_keys.rb +32 -0
- data/lib/fog/azurerm/requests/storage/get_storage_account.rb +36 -0
- data/lib/fog/azurerm/requests/storage/list_blobs.rb +168 -0
- data/lib/fog/azurerm/requests/storage/list_containers.rb +73 -0
- data/lib/fog/azurerm/requests/storage/list_storage_account_for_rg.rb +49 -0
- data/lib/fog/azurerm/requests/storage/list_storage_accounts.rb +49 -0
- data/lib/fog/azurerm/requests/storage/multipart_save_block_blob.rb +110 -0
- data/lib/fog/azurerm/requests/storage/put_blob_block.rb +30 -0
- data/lib/fog/azurerm/requests/storage/put_blob_metadata.rb +31 -0
- data/lib/fog/azurerm/requests/storage/put_blob_pages.rb +30 -0
- data/lib/fog/azurerm/requests/storage/put_blob_properties.rb +31 -0
- data/lib/fog/azurerm/requests/storage/put_container_acl.rb +31 -0
- data/lib/fog/azurerm/requests/storage/put_container_metadata.rb +31 -0
- data/lib/fog/azurerm/requests/storage/release_blob_lease.rb +30 -0
- data/lib/fog/azurerm/requests/storage/release_container_lease.rb +30 -0
- data/lib/fog/azurerm/requests/storage/save_page_blob.rb +111 -0
- data/lib/fog/azurerm/requests/storage/update_storage_account.rb +59 -0
- data/lib/fog/azurerm/requests/storage/wait_blob_copy_operation_to_finish.rb +56 -0
- data/lib/fog/azurerm/requests/traffic_manager/check_traffic_manager_endpoint_exists.rb +31 -0
- data/lib/fog/azurerm/requests/traffic_manager/check_traffic_manager_profile_exists.rb +31 -0
- data/lib/fog/azurerm/requests/traffic_manager/create_or_update_traffic_manager_endpoint.rb +54 -0
- data/lib/fog/azurerm/requests/traffic_manager/create_or_update_traffic_manager_profile.rb +130 -0
- data/lib/fog/azurerm/requests/traffic_manager/delete_traffic_manager_endpoint.rb +28 -0
- data/lib/fog/azurerm/requests/traffic_manager/delete_traffic_manager_profile.rb +26 -0
- data/lib/fog/azurerm/requests/traffic_manager/get_traffic_manager_endpoint.rb +39 -0
- data/lib/fog/azurerm/requests/traffic_manager/get_traffic_manager_profile.rb +80 -0
- data/lib/fog/azurerm/requests/traffic_manager/list_traffic_manager_profiles.rb +82 -0
- data/lib/fog/azurerm/resources.rb +71 -0
- data/lib/fog/azurerm/sql.rb +66 -0
- data/lib/fog/azurerm/storage.rb +136 -0
- data/lib/fog/azurerm/traffic_manager.rb +62 -0
- data/lib/fog/azurerm/utilities/general.rb +179 -0
- data/lib/fog/azurerm/utilities/logger_messages.yml +19 -0
- data/lib/fog/azurerm/version.rb +5 -0
- data/rake-script.sh +10 -0
- data/rakefile +29 -0
- data/test/api_stub.rb +145 -0
- data/test/api_stub/models/application_gateway/gateway.rb +165 -0
- data/test/api_stub/models/compute/availability_set.rb +69 -0
- data/test/api_stub/models/compute/managed_disk.rb +59 -0
- data/test/api_stub/models/compute/server.rb +268 -0
- data/test/api_stub/models/compute/virtual_machine_extension.rb +31 -0
- data/test/api_stub/models/dns/record_set.rb +57 -0
- data/test/api_stub/models/dns/zone.rb +29 -0
- data/test/api_stub/models/key_vault/vault.rb +39 -0
- data/test/api_stub/models/network/express_route_circuit.rb +47 -0
- data/test/api_stub/models/network/express_route_circuit_authorization.rb +22 -0
- data/test/api_stub/models/network/express_route_circuit_peering.rb +33 -0
- data/test/api_stub/models/network/express_route_service_provider.rb +29 -0
- data/test/api_stub/models/network/load_balancer.rb +154 -0
- data/test/api_stub/models/network/local_network_gateway.rb +31 -0
- data/test/api_stub/models/network/network_interface.rb +72 -0
- data/test/api_stub/models/network/network_security_group.rb +95 -0
- data/test/api_stub/models/network/network_security_rule.rb +30 -0
- data/test/api_stub/models/network/public_ip.rb +36 -0
- data/test/api_stub/models/network/subnet.rb +36 -0
- data/test/api_stub/models/network/virtual_network.rb +62 -0
- data/test/api_stub/models/network/virtual_network_gateway.rb +26 -0
- data/test/api_stub/models/network/virtual_network_gateway_connection.rb +31 -0
- data/test/api_stub/models/resources/deployment.rb +116 -0
- data/test/api_stub/models/resources/resource.rb +43 -0
- data/test/api_stub/models/resources/resource_group.rb +24 -0
- data/test/api_stub/models/sql/sql_database.rb +30 -0
- data/test/api_stub/models/sql/sql_firewall_rule.rb +24 -0
- data/test/api_stub/models/sql/sql_server.rb +24 -0
- data/test/api_stub/models/storage/directory.rb +178 -0
- data/test/api_stub/models/storage/file.rb +181 -0
- data/test/api_stub/models/storage/storageaccount.rb +22 -0
- data/test/api_stub/models/traffic_manager/traffic_manager_end_point.rb +27 -0
- data/test/api_stub/models/traffic_manager/traffic_manager_profile.rb +75 -0
- data/test/api_stub/requests/application_gateway/gateway.rb +461 -0
- data/test/api_stub/requests/compute/availability_set.rb +114 -0
- data/test/api_stub/requests/compute/image.rb +41 -0
- data/test/api_stub/requests/compute/managed_disk.rb +102 -0
- data/test/api_stub/requests/compute/virtual_machine.rb +1018 -0
- data/test/api_stub/requests/compute/virtual_machine_extension.rb +46 -0
- data/test/api_stub/requests/dns/record_set.rb +75 -0
- data/test/api_stub/requests/dns/zone.rb +52 -0
- data/test/api_stub/requests/key_vault/vault.rb +95 -0
- data/test/api_stub/requests/network/express_route_circuit.rb +100 -0
- data/test/api_stub/requests/network/express_route_circuit_authorization.rb +31 -0
- data/test/api_stub/requests/network/express_route_circuit_peering.rb +62 -0
- data/test/api_stub/requests/network/express_route_service_provider.rb +30 -0
- data/test/api_stub/requests/network/load_balancer.rb +388 -0
- data/test/api_stub/requests/network/local_network_gateway.rb +62 -0
- data/test/api_stub/requests/network/network_interface.rb +264 -0
- data/test/api_stub/requests/network/network_security_group.rb +225 -0
- data/test/api_stub/requests/network/network_security_rule.rb +72 -0
- data/test/api_stub/requests/network/public_ip.rb +71 -0
- data/test/api_stub/requests/network/subnet.rb +71 -0
- data/test/api_stub/requests/network/virtual_network.rb +125 -0
- data/test/api_stub/requests/network/virtual_network_gateway.rb +49 -0
- data/test/api_stub/requests/network/virtual_network_gateway_connection.rb +68 -0
- data/test/api_stub/requests/resources/deployment.rb +68 -0
- data/test/api_stub/requests/resources/resource.rb +45 -0
- data/test/api_stub/requests/resources/resource_group.rb +51 -0
- data/test/api_stub/requests/sql/database.rb +71 -0
- data/test/api_stub/requests/sql/firewall_rule.rb +50 -0
- data/test/api_stub/requests/sql/sql_server.rb +49 -0
- data/test/api_stub/requests/storage/directory.rb +89 -0
- data/test/api_stub/requests/storage/file.rb +243 -0
- data/test/api_stub/requests/storage/storageaccount.rb +126 -0
- data/test/api_stub/requests/traffic_manager/traffic_manager_endpoint.rb +41 -0
- data/test/api_stub/requests/traffic_manager/traffic_manager_profile.rb +166 -0
- data/test/integration/README.md +14 -0
- data/test/integration/application_gateway.rb +260 -0
- data/test/integration/availability_set.rb +184 -0
- data/test/integration/blob.rb +297 -0
- data/test/integration/container.rb +160 -0
- data/test/integration/credentials/azure.yml +5 -0
- data/test/integration/data_disk.rb +90 -0
- data/test/integration/deployment.rb +78 -0
- data/test/integration/express_route_circuit.rb +139 -0
- data/test/integration/external_load_balancer.rb +156 -0
- data/test/integration/internal_load_balancer.rb +145 -0
- data/test/integration/key_vault.rb +99 -0
- data/test/integration/local_network_gateway.rb +91 -0
- data/test/integration/managed_disk.rb +118 -0
- data/test/integration/network_interface.rb +157 -0
- data/test/integration/network_security_group.rb +134 -0
- data/test/integration/network_security_rule.rb +102 -0
- data/test/integration/public_ip.rb +84 -0
- data/test/integration/record_set.rb +126 -0
- data/test/integration/resource_group.rb +62 -0
- data/test/integration/resource_tag.rb +93 -0
- data/test/integration/server.rb +356 -0
- data/test/integration/server_custom_image.rb +227 -0
- data/test/integration/sql_server.rb +183 -0
- data/test/integration/storage_account.rb +135 -0
- data/test/integration/subnet.rb +122 -0
- data/test/integration/traffic_manager.rb +142 -0
- data/test/integration/virtual_machine_extension.rb +165 -0
- data/test/integration/virtual_network.rb +163 -0
- data/test/integration/virtual_network_gateway.rb +119 -0
- data/test/integration/virtual_network_gateway_connection.rb +221 -0
- data/test/integration/virtual_network_gateway_connection_to_express_route.rb +123 -0
- data/test/integration/zone.rb +81 -0
- data/test/models/application_gateway/test_gateway.rb +136 -0
- data/test/models/application_gateway/test_gateways.rb +55 -0
- data/test/models/compute/test_availability_set.rb +57 -0
- data/test/models/compute/test_availability_sets.rb +55 -0
- data/test/models/compute/test_data_disk.rb +23 -0
- data/test/models/compute/test_managed_disk.rb +62 -0
- data/test/models/compute/test_managed_disks.rb +68 -0
- data/test/models/compute/test_server.rb +236 -0
- data/test/models/compute/test_servers.rb +56 -0
- data/test/models/compute/test_virtual_machine_extension.rb +61 -0
- data/test/models/compute/test_virtual_machine_extensions.rb +49 -0
- data/test/models/dns/test_record_set.rb +86 -0
- data/test/models/dns/test_record_sets.rb +66 -0
- data/test/models/dns/test_zone.rb +51 -0
- data/test/models/dns/test_zones.rb +51 -0
- data/test/models/key_vault/test_vault.rb +40 -0
- data/test/models/key_vault/test_vaults.rb +55 -0
- data/test/models/network/test_express_route_circuit.rb +52 -0
- data/test/models/network/test_express_route_circuit_authorization.rb +50 -0
- data/test/models/network/test_express_route_circuit_authorizations.rb +56 -0
- data/test/models/network/test_express_route_circuit_peering.rb +53 -0
- data/test/models/network/test_express_route_circuit_peerings.rb +43 -0
- data/test/models/network/test_express_route_circuits.rb +55 -0
- data/test/models/network/test_express_route_service_providers.rb +30 -0
- data/test/models/network/test_load_balancer.rb +52 -0
- data/test/models/network/test_load_balancers.rb +55 -0
- data/test/models/network/test_local_network_gateway.rb +53 -0
- data/test/models/network/test_local_network_gateways.rb +55 -0
- data/test/models/network/test_network_interface.rb +97 -0
- data/test/models/network/test_network_interfaces.rb +55 -0
- data/test/models/network/test_network_security_group.rb +87 -0
- data/test/models/network/test_network_security_groups.rb +54 -0
- data/test/models/network/test_network_security_rule.rb +44 -0
- data/test/models/network/test_network_security_rules.rb +55 -0
- data/test/models/network/test_public_ip.rb +62 -0
- data/test/models/network/test_public_ips.rb +55 -0
- data/test/models/network/test_subnet.rb +83 -0
- data/test/models/network/test_subnets.rb +56 -0
- data/test/models/network/test_virtual_network.rb +107 -0
- data/test/models/network/test_virtual_network_gateway.rb +62 -0
- data/test/models/network/test_virtual_network_gateway_connection.rb +59 -0
- data/test/models/network/test_virtual_network_gateway_connections.rb +55 -0
- data/test/models/network/test_virtual_network_gateways.rb +55 -0
- data/test/models/network/test_virtual_networks.rb +67 -0
- data/test/models/resources/test_deployment.rb +55 -0
- data/test/models/resources/test_deployments.rb +51 -0
- data/test/models/resources/test_resource.rb +22 -0
- data/test/models/resources/test_resource_group.rb +45 -0
- data/test/models/resources/test_resource_groups.rb +51 -0
- data/test/models/resources/test_resources.rb +52 -0
- data/test/models/sql/test_database.rb +68 -0
- data/test/models/sql/test_databases.rb +42 -0
- data/test/models/sql/test_firewall_rule.rb +55 -0
- data/test/models/sql/test_firewall_rules.rb +42 -0
- data/test/models/sql/test_sql_server.rb +58 -0
- data/test/models/sql/test_sql_servers.rb +41 -0
- data/test/models/storage/test_directories.rb +74 -0
- data/test/models/storage/test_directory.rb +178 -0
- data/test/models/storage/test_file.rb +294 -0
- data/test/models/storage/test_files.rb +234 -0
- data/test/models/storage/test_storage_account.rb +89 -0
- data/test/models/storage/test_storage_accounts.rb +78 -0
- data/test/models/traffic_manager/test_traffic_manager_end_point.rb +54 -0
- data/test/models/traffic_manager/test_traffic_manager_end_points.rb +56 -0
- data/test/models/traffic_manager/test_traffic_manager_profile.rb +63 -0
- data/test/models/traffic_manager/test_traffic_manager_profiles.rb +55 -0
- data/test/requests/application_gateway/test_check_ag_exists.rb +38 -0
- data/test/requests/application_gateway/test_create_or_update_application_gateway.rb +35 -0
- data/test/requests/application_gateway/test_delete_application_gateway.rb +23 -0
- data/test/requests/application_gateway/test_get_application_gateway.rb +24 -0
- data/test/requests/application_gateway/test_list_application_gateways.rb +24 -0
- data/test/requests/application_gateway/test_start_application_gateway.rb +25 -0
- data/test/requests/application_gateway/test_stop_application_gateway.rb +25 -0
- data/test/requests/compute/test_attach_data_disk_to_vm.rb +105 -0
- data/test/requests/compute/test_check_availability_set_exists.rb +38 -0
- data/test/requests/compute/test_check_managed_disk_exists.rb +38 -0
- data/test/requests/compute/test_check_vm_exists.rb +38 -0
- data/test/requests/compute/test_check_vm_extension_exists.rb +38 -0
- data/test/requests/compute/test_create_availability_set.rb +112 -0
- data/test/requests/compute/test_create_image.rb +27 -0
- data/test/requests/compute/test_create_or_update_managed_disk.rb +38 -0
- data/test/requests/compute/test_create_virtual_machine.rb +90 -0
- data/test/requests/compute/test_create_vm_extension.rb +35 -0
- data/test/requests/compute/test_deallocate_virtual_machine.rb +32 -0
- data/test/requests/compute/test_delete_availability_set.rb +23 -0
- data/test/requests/compute/test_delete_image.rb +23 -0
- data/test/requests/compute/test_delete_managed_disk.rb +23 -0
- data/test/requests/compute/test_delete_virtual_machine.rb +32 -0
- data/test/requests/compute/test_detach_data_disk_from_vm.rb +32 -0
- data/test/requests/compute/test_generalize_virtual_machine.rb +32 -0
- data/test/requests/compute/test_get_availability_set.rb +24 -0
- data/test/requests/compute/test_get_image.rb +23 -0
- data/test/requests/compute/test_get_managed_disk.rb +24 -0
- data/test/requests/compute/test_get_virtual_machine.rb +24 -0
- data/test/requests/compute/test_get_vm_extension.rb +26 -0
- data/test/requests/compute/test_get_vm_status.rb +25 -0
- data/test/requests/compute/test_grant_access_to_managed_disk.rb +26 -0
- data/test/requests/compute/test_list_availability_sets.rb +24 -0
- data/test/requests/compute/test_list_available_sizes_for_virtual_machine.rb +33 -0
- data/test/requests/compute/test_list_managed_disks_by_rg.rb +24 -0
- data/test/requests/compute/test_list_managed_disks_in_subscription.rb +24 -0
- data/test/requests/compute/test_list_virtual_machines.rb +24 -0
- data/test/requests/compute/test_power_off_virtual_machine.rb +32 -0
- data/test/requests/compute/test_redeploy_virtual_machine.rb +33 -0
- data/test/requests/compute/test_restart_virtual_machine.rb +32 -0
- data/test/requests/compute/test_revoke_access_to_managed_disk.rb +24 -0
- data/test/requests/compute/test_start_virtual_machine.rb +32 -0
- data/test/requests/compute/test_update_vm_extension.rb +35 -0
- data/test/requests/dns/test_check_record_set_exists.rb +38 -0
- data/test/requests/dns/test_check_zone_exists.rb +49 -0
- data/test/requests/dns/test_create_record_set.rb +46 -0
- data/test/requests/dns/test_create_zone.rb +37 -0
- data/test/requests/dns/test_delete_record_set.rb +24 -0
- data/test/requests/dns/test_delete_zone.rb +24 -0
- data/test/requests/dns/test_get_record_set.rb +24 -0
- data/test/requests/dns/test_get_records_from_record_set.rb +42 -0
- data/test/requests/dns/test_get_zone.rb +35 -0
- data/test/requests/dns/test_list_record_sets.rb +35 -0
- data/test/requests/dns/test_list_zones.rb +26 -0
- data/test/requests/key_vault/test_check_vault_exists.rb +38 -0
- data/test/requests/key_vault/test_create_or_update_vault.rb +25 -0
- data/test/requests/key_vault/test_delete_vault.rb +23 -0
- data/test/requests/key_vault/test_get_vault.rb +24 -0
- data/test/requests/key_vault/test_list_vaults.rb +24 -0
- data/test/requests/network/test_add_address_prefixes_in_virtual_network.rb +29 -0
- data/test/requests/network/test_add_dns_servers_in_virtual_network.rb +29 -0
- data/test/requests/network/test_add_security_rules.rb +43 -0
- data/test/requests/network/test_add_subnets_in_virtual_network.rb +29 -0
- data/test/requests/network/test_attach_network_security_group_to_subnet.rb +26 -0
- data/test/requests/network/test_attach_resource_to_nic.rb +43 -0
- data/test/requests/network/test_attach_route_table_to_subnet.rb +26 -0
- data/test/requests/network/test_check_express_route_cir_auth_exists.rb +38 -0
- data/test/requests/network/test_check_express_route_circuit_exists.rb +38 -0
- data/test/requests/network/test_check_load_balancer_exists.rb +38 -0
- data/test/requests/network/test_check_local_net_gateway_exists.rb +38 -0
- data/test/requests/network/test_check_net_sec_group_exists.rb +38 -0
- data/test/requests/network/test_check_net_sec_rule_exists.rb +38 -0
- data/test/requests/network/test_check_network_interface_exists.rb +38 -0
- data/test/requests/network/test_check_public_ip_exists.rb +37 -0
- data/test/requests/network/test_check_subnet_exists.rb +38 -0
- data/test/requests/network/test_check_virtual_network_exists.rb +40 -0
- data/test/requests/network/test_check_vnet_gateway_connection_exists.rb +38 -0
- data/test/requests/network/test_check_vnet_gateway_exists.rb +38 -0
- data/test/requests/network/test_create_express_route_circuit.rb +39 -0
- data/test/requests/network/test_create_express_route_circuit_authorization.rb +35 -0
- data/test/requests/network/test_create_express_route_circuit_peering.rb +37 -0
- data/test/requests/network/test_create_load_balancer.rb +50 -0
- data/test/requests/network/test_create_local_network_gateway.rb +36 -0
- data/test/requests/network/test_create_network_interface.rb +43 -0
- data/test/requests/network/test_create_or_update_network_security_group.rb +39 -0
- data/test/requests/network/test_create_or_update_network_security_rule.rb +28 -0
- data/test/requests/network/test_create_or_update_virtual_network.rb +57 -0
- data/test/requests/network/test_create_public_ip.rb +36 -0
- data/test/requests/network/test_create_subnet.rb +35 -0
- data/test/requests/network/test_create_virtual_network_gateway.rb +37 -0
- data/test/requests/network/test_create_virtual_network_gateway_connection.rb +36 -0
- data/test/requests/network/test_delete_express_route_circuit.rb +24 -0
- data/test/requests/network/test_delete_express_route_circuit_authorization.rb +23 -0
- data/test/requests/network/test_delete_express_route_circuit_peering.rb +24 -0
- data/test/requests/network/test_delete_load_balancer.rb +24 -0
- data/test/requests/network/test_delete_local_network_gateway.rb +23 -0
- data/test/requests/network/test_delete_network_interface.rb +24 -0
- data/test/requests/network/test_delete_network_security_group.rb +25 -0
- data/test/requests/network/test_delete_network_security_rule.rb +25 -0
- data/test/requests/network/test_delete_public_ip.rb +24 -0
- data/test/requests/network/test_delete_subnet.rb +24 -0
- data/test/requests/network/test_delete_virtual_network.rb +24 -0
- data/test/requests/network/test_delete_virtual_network_gateway.rb +24 -0
- data/test/requests/network/test_delete_virtual_network_gateway_connection.rb +23 -0
- data/test/requests/network/test_detach_network_security_group_from_subnet.rb +26 -0
- data/test/requests/network/test_detach_resource_from_nic.rb +41 -0
- data/test/requests/network/test_detach_route_table_from_subnet.rb +26 -0
- data/test/requests/network/test_get_available_ipaddresses_count.rb +18 -0
- data/test/requests/network/test_get_connection_shared_key.rb +24 -0
- data/test/requests/network/test_get_express_route_circuit.rb +24 -0
- data/test/requests/network/test_get_express_route_circuit_authorization.rb +24 -0
- data/test/requests/network/test_get_express_route_circuit_peering.rb +24 -0
- data/test/requests/network/test_get_load_balancer.rb +24 -0
- data/test/requests/network/test_get_local_network_gateway.rb +24 -0
- data/test/requests/network/test_get_network_interface.rb +24 -0
- data/test/requests/network/test_get_network_security_group.rb +26 -0
- data/test/requests/network/test_get_network_security_rule.rb +26 -0
- data/test/requests/network/test_get_public_ip.rb +26 -0
- data/test/requests/network/test_get_subnet.rb +26 -0
- data/test/requests/network/test_get_virtual_network.rb +26 -0
- data/test/requests/network/test_get_virtual_network_gateway.rb +24 -0
- data/test/requests/network/test_get_virtual_network_gateway_connection.rb +24 -0
- data/test/requests/network/test_list_express_route_circuit_authorizations.rb +24 -0
- data/test/requests/network/test_list_express_route_circuit_peerings.rb +24 -0
- data/test/requests/network/test_list_express_route_circuits.rb +26 -0
- data/test/requests/network/test_list_express_route_service_providers.rb +24 -0
- data/test/requests/network/test_list_load_balancers.rb +24 -0
- data/test/requests/network/test_list_local_network_gateways.rb +24 -0
- data/test/requests/network/test_list_network_interfaces.rb +24 -0
- data/test/requests/network/test_list_network_security_groups.rb +26 -0
- data/test/requests/network/test_list_network_security_rules.rb +26 -0
- data/test/requests/network/test_list_public_ips.rb +24 -0
- data/test/requests/network/test_list_subnets.rb +24 -0
- data/test/requests/network/test_list_virtual_network_gateway_connections.rb +24 -0
- data/test/requests/network/test_list_virtual_network_gateways.rb +24 -0
- data/test/requests/network/test_list_virtual_networks.rb +24 -0
- data/test/requests/network/test_list_virtual_networks_in_subscription.rb +24 -0
- data/test/requests/network/test_remove_address_prefixes_from_virtual_network.rb +29 -0
- data/test/requests/network/test_remove_dns_servers_from_virtual_network.rb +29 -0
- data/test/requests/network/test_remove_security_rule.rb +29 -0
- data/test/requests/network/test_remove_subnets_from_virtual_network.rb +29 -0
- data/test/requests/network/test_reset_connection_shared_key.rb +23 -0
- data/test/requests/network/test_set_connection_shared_key.rb +23 -0
- data/test/requests/network/test_update_public_ip.rb +35 -0
- data/test/requests/resources/test_check_azure_resource_exists.rb +22 -0
- data/test/requests/resources/test_check_deployment_exists.rb +29 -0
- data/test/requests/resources/test_check_resource_group_exists.rb +29 -0
- data/test/requests/resources/test_create_deployment.rb +32 -0
- data/test/requests/resources/test_create_resource_group.rb +25 -0
- data/test/requests/resources/test_delete_deployment.rb +25 -0
- data/test/requests/resources/test_delete_resource_group.rb +24 -0
- data/test/requests/resources/test_delete_resource_tag.rb +35 -0
- data/test/requests/resources/test_get_deployment.rb +24 -0
- data/test/requests/resources/test_get_resource_group.rb +24 -0
- data/test/requests/resources/test_list_deployments.rb +25 -0
- data/test/requests/resources/test_list_resource_groups.rb +24 -0
- data/test/requests/resources/test_list_tagged_resources.rb +24 -0
- data/test/requests/resources/test_tag_resource.rb +35 -0
- data/test/requests/sql/test_create_or_update_database.rb +25 -0
- data/test/requests/sql/test_create_or_update_firewall_rule.rb +25 -0
- data/test/requests/sql/test_create_or_update_sql_server.rb +25 -0
- data/test/requests/sql/test_delete_database.rb +23 -0
- data/test/requests/sql/test_delete_firewall_rule.rb +23 -0
- data/test/requests/sql/test_delete_sql_server.rb +23 -0
- data/test/requests/sql/test_get_database.rb +24 -0
- data/test/requests/sql/test_get_firewall_rule.rb +24 -0
- data/test/requests/sql/test_get_sql_server.rb +24 -0
- data/test/requests/sql/test_list_databases.rb +24 -0
- data/test/requests/sql/test_list_firewall_rules.rb +24 -0
- data/test/requests/sql/test_list_sql_servers.rb +24 -0
- data/test/requests/storage/test_acquire_blob_lease.rb +36 -0
- data/test/requests/storage/test_acquire_container_lease.rb +36 -0
- data/test/requests/storage/test_check_container_exists.rb +18 -0
- data/test/requests/storage/test_check_storage_account_exists.rb +41 -0
- data/test/requests/storage/test_check_storage_account_name_availability.rb +35 -0
- data/test/requests/storage/test_commit_blob_blocks.rb +34 -0
- data/test/requests/storage/test_compare_container_blobs.rb +36 -0
- data/test/requests/storage/test_copy_blob.rb +36 -0
- data/test/requests/storage/test_copy_blob_from_uri.rb +36 -0
- data/test/requests/storage/test_create_block_blob.rb +80 -0
- data/test/requests/storage/test_create_container.rb +36 -0
- data/test/requests/storage/test_create_disk.rb +70 -0
- data/test/requests/storage/test_create_page_blob.rb +34 -0
- data/test/requests/storage/test_create_storage_account.rb +34 -0
- data/test/requests/storage/test_delete_blob.rb +42 -0
- data/test/requests/storage/test_delete_container.rb +42 -0
- data/test/requests/storage/test_delete_disk.rb +30 -0
- data/test/requests/storage/test_delete_storage_account.rb +28 -0
- data/test/requests/storage/test_get_blob.rb +141 -0
- data/test/requests/storage/test_get_blob_http_url.rb +30 -0
- data/test/requests/storage/test_get_blob_https_url.rb +30 -0
- data/test/requests/storage/test_get_blob_properties.rb +45 -0
- data/test/requests/storage/test_get_blob_url.rb +75 -0
- data/test/requests/storage/test_get_container_acl.rb +37 -0
- data/test/requests/storage/test_get_container_properties.rb +45 -0
- data/test/requests/storage/test_get_container_url.rb +33 -0
- data/test/requests/storage/test_get_storage_access_keys.rb +24 -0
- data/test/requests/storage/test_get_storage_account.rb +25 -0
- data/test/requests/storage/test_list_blobs.rb +77 -0
- data/test/requests/storage/test_list_containers.rb +54 -0
- data/test/requests/storage/test_list_storage_accounts.rb +37 -0
- data/test/requests/storage/test_list_storage_accounts_for_rg.rb +37 -0
- data/test/requests/storage/test_multipart_save_block_blob.rb +105 -0
- data/test/requests/storage/test_put_blob_block.rb +34 -0
- data/test/requests/storage/test_put_blob_metadata.rb +36 -0
- data/test/requests/storage/test_put_blob_pages.rb +34 -0
- data/test/requests/storage/test_put_blob_properties.rb +39 -0
- data/test/requests/storage/test_put_container_acl.rb +34 -0
- data/test/requests/storage/test_put_container_metadata.rb +36 -0
- data/test/requests/storage/test_release_blob_lease.rb +34 -0
- data/test/requests/storage/test_release_container_lease.rb +34 -0
- data/test/requests/storage/test_save_page_blob.rb +115 -0
- data/test/requests/storage/test_update_storage_account.rb +34 -0
- data/test/requests/storage/test_wait_blob_copy_operation_to_finish.rb +148 -0
- data/test/requests/traffic_manager/test_check_traffic_manager_endpoint_exists.rb +38 -0
- data/test/requests/traffic_manager/test_check_traffic_manager_profile_exists.rb +38 -0
- data/test/requests/traffic_manager/test_create_traffic_manager_endpoint.rb +25 -0
- data/test/requests/traffic_manager/test_create_traffic_manager_profile.rb +25 -0
- data/test/requests/traffic_manager/test_delete_traffic_manager_endpoint.rb +23 -0
- data/test/requests/traffic_manager/test_delete_traffic_manager_profile.rb +23 -0
- data/test/requests/traffic_manager/test_get_traffic_manager_endpoint.rb +24 -0
- data/test/requests/traffic_manager/test_get_traffic_manager_profile.rb +24 -0
- data/test/requests/traffic_manager/test_list_traffic_manager_profiles.rb +24 -0
- data/test/requests/traffic_manager/test_update_traffic_manager_endpoint.rb +27 -0
- data/test/requests/traffic_manager/test_update_traffic_manager_profile.rb +27 -0
- data/test/smoke_tests/compute/test_resource_group_smoke.rb +37 -0
- data/test/test_credentials.rb +63 -0
- data/test/test_helper.rb +831 -0
- metadata +1050 -0
@@ -0,0 +1,126 @@
|
|
1
|
+
module ApiStub
|
2
|
+
module Requests
|
3
|
+
module Storage
|
4
|
+
# Mock class for Storage Requests
|
5
|
+
class StorageAccount
|
6
|
+
def self.storage_account_request(storage_mgmt_client)
|
7
|
+
storage_account_hash = {
|
8
|
+
'id' => '/subscriptions/########-####-####-####-############/resourceGroups/fog_test_rg/providers/Microsoft.Storage/storageAccounts/fog-test-storage-account',
|
9
|
+
'name' => 'fog-test-storage-account',
|
10
|
+
'location' => 'west us',
|
11
|
+
'sku' =>
|
12
|
+
{
|
13
|
+
'name' => 'Standard_LRS'
|
14
|
+
}
|
15
|
+
}
|
16
|
+
storage_account_mapper = Azure::ARM::Storage::Models::StorageAccount.mapper
|
17
|
+
storage_mgmt_client.deserialize(storage_account_mapper, storage_account_hash, 'hash')
|
18
|
+
end
|
19
|
+
|
20
|
+
def self.create_storage_account
|
21
|
+
storage_acc_obj = Azure::ARM::Storage::Models::StorageAccount.new
|
22
|
+
storage_acc_obj.id = '1'
|
23
|
+
storage_acc_obj.name = 'fog_test_storage_account'
|
24
|
+
storage_acc_obj.type = nil
|
25
|
+
storage_acc_obj.location = 'west us'
|
26
|
+
storage_acc_obj.tags = nil
|
27
|
+
storage_acc_obj.properties = nil
|
28
|
+
storage_acc_obj
|
29
|
+
end
|
30
|
+
|
31
|
+
def self.storage_account_arguments
|
32
|
+
{
|
33
|
+
resource_group: 'gateway-RG',
|
34
|
+
name: 'fog_test_storage_account',
|
35
|
+
sku_name: 'Standard',
|
36
|
+
location: 'West US',
|
37
|
+
replication: 'LRS',
|
38
|
+
encryption: true
|
39
|
+
}
|
40
|
+
end
|
41
|
+
|
42
|
+
def self.list_storage_accounts_for_rg(storage_mgmt_client)
|
43
|
+
list_storage_accounts_hash = {
|
44
|
+
'value' =>
|
45
|
+
[
|
46
|
+
{
|
47
|
+
'id' => '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Storage/storageAccounts/{accountName}',
|
48
|
+
'name' => 'accountName1',
|
49
|
+
'location' => 'account geo region',
|
50
|
+
'tags' =>
|
51
|
+
{
|
52
|
+
'key1' => 'value1',
|
53
|
+
'key2' => 'value2'
|
54
|
+
},
|
55
|
+
'type' => 'Microsoft.Storage/StorageAccount',
|
56
|
+
'properties' =>
|
57
|
+
{
|
58
|
+
'lastGeoFailoverTime' => '',
|
59
|
+
'creationTime' => '2016-05-18T07:24:40Z'
|
60
|
+
}
|
61
|
+
}
|
62
|
+
]
|
63
|
+
}
|
64
|
+
storage_account_list_mapper = Azure::ARM::Storage::Models::StorageAccountListResult.mapper
|
65
|
+
storage_mgmt_client.deserialize(storage_account_list_mapper, list_storage_accounts_hash, 'hash')
|
66
|
+
end
|
67
|
+
|
68
|
+
def self.list_storage_accounts(storage_mgmt_client)
|
69
|
+
list_storage_accounts_hash = {
|
70
|
+
'value' =>
|
71
|
+
[
|
72
|
+
{
|
73
|
+
'id' => '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Storage/storageAccounts/{accountName}',
|
74
|
+
'name' => 'accountName1',
|
75
|
+
'type' => 'Microsoft.Storage/StorageAccount',
|
76
|
+
'location' => 'account geo region',
|
77
|
+
'tags' =>
|
78
|
+
{
|
79
|
+
'key1' => 'value1',
|
80
|
+
'key2' => 'value2'
|
81
|
+
},
|
82
|
+
'properties' =>
|
83
|
+
{
|
84
|
+
'lastGeoFailoverTime' => '',
|
85
|
+
'creationTime' => '2016-05-18T07:24:40Z'
|
86
|
+
}
|
87
|
+
}
|
88
|
+
]
|
89
|
+
}
|
90
|
+
storage_account_list_mapper = Azure::ARM::Storage::Models::StorageAccountListResult.mapper
|
91
|
+
storage_mgmt_client.deserialize(storage_account_list_mapper, list_storage_accounts_hash, 'hash')
|
92
|
+
end
|
93
|
+
|
94
|
+
def self.true_case_for_check_name_availability(storage_mgmt_client)
|
95
|
+
check_name_availability_hash = {
|
96
|
+
'nameAvailable' => true,
|
97
|
+
'reason' => 'AccountNameInvalid|AlreadyExists',
|
98
|
+
'message' => 'error message'
|
99
|
+
}
|
100
|
+
storage_account_check_name_avaiablability_mapper = Azure::ARM::Storage::Models::CheckNameAvailabilityResult.mapper
|
101
|
+
storage_mgmt_client.deserialize(storage_account_check_name_avaiablability_mapper, check_name_availability_hash, 'hash')
|
102
|
+
end
|
103
|
+
|
104
|
+
def self.false_case_for_check_name_availability(storage_mgmt_client)
|
105
|
+
check_name_availability_hash = {
|
106
|
+
'nameAvailable' => false,
|
107
|
+
'reason' => 'AccountNameInvalid|AlreadyExists',
|
108
|
+
'message' => 'error message'
|
109
|
+
}
|
110
|
+
storage_account_check_name_avaiablability_mapper = Azure::ARM::Storage::Models::CheckNameAvailabilityResult.mapper
|
111
|
+
storage_mgmt_client.deserialize(storage_account_check_name_avaiablability_mapper, check_name_availability_hash, 'hash')
|
112
|
+
end
|
113
|
+
|
114
|
+
def self.list_keys_response
|
115
|
+
key1 = Azure::ARM::Storage::Models::StorageAccountKey.new
|
116
|
+
key1.key_name = 'key1'
|
117
|
+
key1.value = 'YWNjZXNzLWtleQ=='
|
118
|
+
key1.permissions = 'Full'
|
119
|
+
storage_account_key_list = Azure::ARM::Storage::Models::StorageAccountListKeysResult.new
|
120
|
+
storage_account_key_list.keys = [key1]
|
121
|
+
storage_account_key_list
|
122
|
+
end
|
123
|
+
end
|
124
|
+
end
|
125
|
+
end
|
126
|
+
end
|
@@ -0,0 +1,41 @@
|
|
1
|
+
module ApiStub
|
2
|
+
module Requests
|
3
|
+
module TrafficManager
|
4
|
+
# Mock class for raffic Manager End Point Requests
|
5
|
+
class TrafficManagerEndPoint
|
6
|
+
def self.create_traffic_manager_endpoint_response(traffic_manager_client)
|
7
|
+
body = '{
|
8
|
+
"id": "/subscriptions/######/resourceGroups/fog-test-rg/providers/Microsoft.Network/trafficManagerProfiles/fog-test-profile/externalEndpoints/fog-test-end-point?api-version=2015-11-01",
|
9
|
+
"name": "fog-test-end-point",
|
10
|
+
"type": "Microsoft.Network/trafficManagerProfiles/externalEndpoints",
|
11
|
+
"properties": {
|
12
|
+
"endpointStatus": "Enabled",
|
13
|
+
"endpointMonitorStatus": "Online",
|
14
|
+
"target": "test.com",
|
15
|
+
"weight": 10,
|
16
|
+
"priority": 5,
|
17
|
+
"endpointLocation": "northeurope"
|
18
|
+
}
|
19
|
+
}'
|
20
|
+
endpoint_mapper = Azure::ARM::TrafficManager::Models::Endpoint.mapper
|
21
|
+
traffic_manager_client.deserialize(endpoint_mapper, Fog::JSON.decode(body), 'result.body')
|
22
|
+
end
|
23
|
+
|
24
|
+
def self.endpoint_hash
|
25
|
+
{
|
26
|
+
resource_group: 'resource-group',
|
27
|
+
name: 'name',
|
28
|
+
traffic_manager_profile_name: 'traffic_manager_profile_name',
|
29
|
+
type: 'type',
|
30
|
+
target_resource_id: 'target_resource_id',
|
31
|
+
target: 'target',
|
32
|
+
weight: 'weight',
|
33
|
+
priority: 'priority',
|
34
|
+
endpoint_location: 'endpoint_location',
|
35
|
+
min_child_endpoints: 'min_child_endpoints'
|
36
|
+
}
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
@@ -0,0 +1,166 @@
|
|
1
|
+
module ApiStub
|
2
|
+
module Requests
|
3
|
+
module TrafficManager
|
4
|
+
# Mock class for Traffic Manager Profile Requests
|
5
|
+
class TrafficManagerProfile
|
6
|
+
def self.create_traffic_manager_profile_response(traffic_manager_client)
|
7
|
+
body = '{
|
8
|
+
"location": "global",
|
9
|
+
"tags": {},
|
10
|
+
"id": "/subscriptions/###/resourceGroups/fog-test-rg/Microsoft.Network/trafficManagerProfiles/fog-test-profile",
|
11
|
+
"name": "fog-test-profile",
|
12
|
+
"type": "Microsoft.Network/trafficManagerProfiles",
|
13
|
+
"properties": {
|
14
|
+
"profileStatus": "Enabled",
|
15
|
+
"trafficRoutingMethod": "Performance",
|
16
|
+
"dnsConfig": {
|
17
|
+
"relativeName": "fog-test-app",
|
18
|
+
"fqdn": "myapp.trafficmanager.net",
|
19
|
+
"ttl": 30
|
20
|
+
},
|
21
|
+
"monitorConfig": {
|
22
|
+
"profileMonitorStatus": "Online",
|
23
|
+
"protocol": "http",
|
24
|
+
"port": 80,
|
25
|
+
"path": "/monitorpage.aspx"
|
26
|
+
},
|
27
|
+
"endpoints": [{
|
28
|
+
"id": "{ARM resource ID of this endpoint}",
|
29
|
+
"name": "{endpoint-name}",
|
30
|
+
"type": "Microsoft.Network/trafficManagerProfiles/azureEndpoints",
|
31
|
+
"properties": {
|
32
|
+
"endpointStatus": "Enabled",
|
33
|
+
"endpointMonitorStatus": "Online",
|
34
|
+
"targetResourceId": "{resource ID of target resource in Azure}",
|
35
|
+
"target": "myapp.azurewebsites.net",
|
36
|
+
"weight": 10,
|
37
|
+
"priority": 3,
|
38
|
+
"endpointLocation": "centralus"
|
39
|
+
}
|
40
|
+
}, {
|
41
|
+
"id": "{ARM resource ID of this endpoint}",
|
42
|
+
"name": "{endpoint-name}",
|
43
|
+
"type": "Microsoft.Network/trafficManagerProfiles/externalEndpoints",
|
44
|
+
"properties": {
|
45
|
+
"endpointStatus": "Enabled",
|
46
|
+
"endpointMonitorStatus": "Online",
|
47
|
+
"target": "myendpoint.contoso.com",
|
48
|
+
"weight": 10,
|
49
|
+
"priority": 5,
|
50
|
+
"endpointLocation": "northeurope"
|
51
|
+
}
|
52
|
+
}, {
|
53
|
+
"id": "{ARM resource ID of this endpoint}",
|
54
|
+
"name": "{endpoint-name}",
|
55
|
+
"type": "Microsoft.Network/trafficManagerProfiles/nestedEndpoints",
|
56
|
+
"properties": {
|
57
|
+
"endpointStatus": "Enabled",
|
58
|
+
"endpointMonitorStatus": "Online",
|
59
|
+
"targetResourceId": "{resource ID of child Traffic Manager profile}",
|
60
|
+
"weight": 10,
|
61
|
+
"priority": 1,
|
62
|
+
"endpointLocation": "westeurope",
|
63
|
+
"minChildEndpoints": 1
|
64
|
+
}
|
65
|
+
}]
|
66
|
+
}
|
67
|
+
}'
|
68
|
+
profile_mapper = Azure::ARM::TrafficManager::Models::Profile.mapper
|
69
|
+
traffic_manager_client.deserialize(profile_mapper, Fog::JSON.decode(body), 'result.body')
|
70
|
+
end
|
71
|
+
|
72
|
+
def self.list_traffic_manager_profiles_response(traffic_manager_client)
|
73
|
+
body = '{
|
74
|
+
"values": [{
|
75
|
+
"location": "global",
|
76
|
+
"tags": {},
|
77
|
+
"id": "/subscriptions/###/resourceGroups/fog-test-rg/Microsoft.Network/trafficManagerProfiles/fog-test-profile",
|
78
|
+
"name": "fog-test-profile",
|
79
|
+
"type": "Microsoft.Network/trafficManagerProfiles",
|
80
|
+
"properties": {
|
81
|
+
"profileStatus": "Enabled",
|
82
|
+
"trafficRoutingMethod": "Performance",
|
83
|
+
"dnsConfig": {
|
84
|
+
"relativeName": "fog-test-app",
|
85
|
+
"fqdn": "myapp.trafficmanager.net",
|
86
|
+
"ttl": 30
|
87
|
+
},
|
88
|
+
"monitorConfig": {
|
89
|
+
"profileMonitorStatus": "Online",
|
90
|
+
"protocol": "http",
|
91
|
+
"port": 80,
|
92
|
+
"path": "/monitorpage.aspx"
|
93
|
+
},
|
94
|
+
"endpoints": [{
|
95
|
+
"id": "{ARM resource ID of this endpoint}",
|
96
|
+
"name": "{endpoint-name}",
|
97
|
+
"type": "Microsoft.Network/trafficManagerProfiles/azureEndpoints",
|
98
|
+
"properties": {
|
99
|
+
"endpointStatus": "Enabled",
|
100
|
+
"endpointMonitorStatus": "Online",
|
101
|
+
"targetResourceId": "{resource ID of target resource in Azure}",
|
102
|
+
"target": "myapp.azurewebsites.net",
|
103
|
+
"weight": 10,
|
104
|
+
"priority": 3,
|
105
|
+
"endpointLocation": "centralus"
|
106
|
+
}
|
107
|
+
}, {
|
108
|
+
"id": "{ARM resource ID of this endpoint}",
|
109
|
+
"name": "{endpoint-name}",
|
110
|
+
"type": "Microsoft.Network/trafficManagerProfiles/externalEndpoints",
|
111
|
+
"properties": {
|
112
|
+
"endpointStatus": "Enabled",
|
113
|
+
"endpointMonitorStatus": "Online",
|
114
|
+
"target": "myendpoint.contoso.com",
|
115
|
+
"weight": 10,
|
116
|
+
"priority": 5,
|
117
|
+
"endpointLocation": "northeurope"
|
118
|
+
}
|
119
|
+
}, {
|
120
|
+
"id": "{ARM resource ID of this endpoint}",
|
121
|
+
"name": "{endpoint-name}",
|
122
|
+
"type": "Microsoft.Network/trafficManagerProfiles/nestedEndpoints",
|
123
|
+
"properties": {
|
124
|
+
"endpointStatus": "Enabled",
|
125
|
+
"endpointMonitorStatus": "Online",
|
126
|
+
"targetResourceId": "{resource ID of child Traffic Manager profile}",
|
127
|
+
"weight": 10,
|
128
|
+
"priority": 1,
|
129
|
+
"endpointLocation": "westeurope",
|
130
|
+
"minChildEndpoints": 1
|
131
|
+
}
|
132
|
+
}]
|
133
|
+
}
|
134
|
+
}]
|
135
|
+
}'
|
136
|
+
profile_mapper = Azure::ARM::TrafficManager::Models::ProfileListResult.mapper
|
137
|
+
traffic_manager_client.deserialize(profile_mapper, Fog::JSON.decode(body), 'result.body')
|
138
|
+
end
|
139
|
+
|
140
|
+
def self.profile_hash
|
141
|
+
{
|
142
|
+
resource_group: 'resource_group',
|
143
|
+
name: 'name',
|
144
|
+
traffic_routing_method: 'traffic_routing_method',
|
145
|
+
relative_name: 'relative_name',
|
146
|
+
ttl: 'ttl',
|
147
|
+
protocol: 'protocol',
|
148
|
+
port: 'port',
|
149
|
+
path: 'path',
|
150
|
+
endpoints: [{
|
151
|
+
name: 'endpoint2',
|
152
|
+
traffic_manager_profile_name: 'test-tmp',
|
153
|
+
resource_group: 'TestRG-TM',
|
154
|
+
type: 'externalEndpoints',
|
155
|
+
target: 'test-app.com',
|
156
|
+
endpoint_location: 'eastus',
|
157
|
+
endpoint_status: 'Enabled',
|
158
|
+
priority: 5,
|
159
|
+
weight: 10
|
160
|
+
}]
|
161
|
+
}
|
162
|
+
end
|
163
|
+
end
|
164
|
+
end
|
165
|
+
end
|
166
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
# Integration Tests
|
2
|
+
|
3
|
+
To run Integration Tests, first enter following information from your Azure subscription in **credentials\azure.yml** file:
|
4
|
+
|
5
|
+
- tenant_id
|
6
|
+
- client_id
|
7
|
+
- client_secret
|
8
|
+
- subscription_id
|
9
|
+
|
10
|
+
Then run **ruby file_name.rb** to run integration test for a specific service e.g. For integration tests of storage account, run:
|
11
|
+
|
12
|
+
**ruby storage_account.rb**
|
13
|
+
|
14
|
+
Also make sure the **DEBUG** flag is set in your fog environment to see proper logging.
|
@@ -0,0 +1,260 @@
|
|
1
|
+
require 'fog/azurerm'
|
2
|
+
require 'yaml'
|
3
|
+
|
4
|
+
########################################################################################################################
|
5
|
+
###################### Services object required by all actions ######################
|
6
|
+
###################### Keep it Uncommented! ######################
|
7
|
+
########################################################################################################################
|
8
|
+
|
9
|
+
azure_credentials = YAML.load_file(File.expand_path('credentials/azure.yml', __dir__))
|
10
|
+
|
11
|
+
resource = Fog::Resources::AzureRM.new(
|
12
|
+
tenant_id: azure_credentials['tenant_id'],
|
13
|
+
client_id: azure_credentials['client_id'],
|
14
|
+
client_secret: azure_credentials['client_secret'],
|
15
|
+
subscription_id: azure_credentials['subscription_id']
|
16
|
+
)
|
17
|
+
|
18
|
+
application_gateway = Fog::ApplicationGateway::AzureRM.new(
|
19
|
+
tenant_id: azure_credentials['tenant_id'],
|
20
|
+
client_id: azure_credentials['client_id'],
|
21
|
+
client_secret: azure_credentials['client_secret'],
|
22
|
+
subscription_id: azure_credentials['subscription_id']
|
23
|
+
)
|
24
|
+
|
25
|
+
network = Fog::Network::AzureRM.new(
|
26
|
+
tenant_id: azure_credentials['tenant_id'],
|
27
|
+
client_id: azure_credentials['client_id'],
|
28
|
+
client_secret: azure_credentials['client_secret'],
|
29
|
+
subscription_id: azure_credentials['subscription_id']
|
30
|
+
)
|
31
|
+
|
32
|
+
########################################################################################################################
|
33
|
+
###################### Resource names #####################
|
34
|
+
########################################################################################################################
|
35
|
+
|
36
|
+
time = current_time
|
37
|
+
resource_group_name = "TestRG-AG-#{time}"
|
38
|
+
virtual_network_name = "Vnet#{time}"
|
39
|
+
subnet_name = "Sub#{time}"
|
40
|
+
public_ip_name = "Pip#{time}"
|
41
|
+
app_gateway_name = "AG#{time}"
|
42
|
+
|
43
|
+
########################################################################################################################
|
44
|
+
###################### Prerequisites #####################
|
45
|
+
########################################################################################################################
|
46
|
+
|
47
|
+
begin
|
48
|
+
resource_group = resource.resource_groups.create(
|
49
|
+
name: resource_group_name,
|
50
|
+
location: LOCATION
|
51
|
+
)
|
52
|
+
|
53
|
+
network.virtual_networks.create(
|
54
|
+
name: virtual_network_name,
|
55
|
+
location: LOCATION,
|
56
|
+
resource_group: resource_group_name,
|
57
|
+
dns_servers: %w(10.1.0.0 10.2.0.0),
|
58
|
+
address_prefixes: %w(10.1.0.0/16 10.2.0.0/16)
|
59
|
+
)
|
60
|
+
|
61
|
+
network.subnets.create(
|
62
|
+
name: subnet_name,
|
63
|
+
resource_group: resource_group_name,
|
64
|
+
virtual_network_name: virtual_network_name,
|
65
|
+
address_prefix: '10.2.0.0/24'
|
66
|
+
)
|
67
|
+
|
68
|
+
network.public_ips.create(
|
69
|
+
name: public_ip_name,
|
70
|
+
resource_group: resource_group_name,
|
71
|
+
location: LOCATION,
|
72
|
+
public_ip_allocation_method: Fog::ARM::Network::Models::IPAllocationMethod::Dynamic
|
73
|
+
)
|
74
|
+
|
75
|
+
########################################################################################################################
|
76
|
+
###################### Check for Application Gateway ######################
|
77
|
+
########################################################################################################################
|
78
|
+
|
79
|
+
flag = application_gateway.gateways.check_application_gateway_exists(resource_group_name, app_gateway_name)
|
80
|
+
puts "Application Gateway doesn't exist." unless flag
|
81
|
+
|
82
|
+
#######################################################################################################################
|
83
|
+
##################### Create Application Gateway ######################
|
84
|
+
#######################################################################################################################
|
85
|
+
|
86
|
+
tags = { key1: 'value1', key2: 'value2' }
|
87
|
+
|
88
|
+
app_gateway = application_gateway.gateways.create(
|
89
|
+
name: app_gateway_name,
|
90
|
+
location: LOCATION,
|
91
|
+
resource_group: resource_group_name,
|
92
|
+
tags: tags,
|
93
|
+
sku_name: 'Standard_Medium',
|
94
|
+
sku_tier: 'Standard',
|
95
|
+
sku_capacity: '2',
|
96
|
+
gateway_ip_configurations: [
|
97
|
+
{
|
98
|
+
name: 'gatewayIpConfigName',
|
99
|
+
subnet_id: "/subscriptions/#{azure_credentials['subscription_id']}/resourcegroups/#{resource_group_name}/providers/Microsoft.Network/virtualNetworks/#{virtual_network_name}/subnets/#{subnet_name}"
|
100
|
+
}
|
101
|
+
],
|
102
|
+
frontend_ip_configurations: [
|
103
|
+
{
|
104
|
+
name: 'frontendIpConfig',
|
105
|
+
private_ip_allocation_method: Fog::ARM::Network::Models::IPAllocationMethod::Dynamic,
|
106
|
+
public_ip_address_id: "/subscriptions/#{azure_credentials['subscription_id']}/resourcegroups/#{resource_group_name}/providers/Microsoft.Network/publicIPAddresses/#{public_ip_name}",
|
107
|
+
private_ip_address: '10.0.1.5'
|
108
|
+
}
|
109
|
+
],
|
110
|
+
frontend_ports: [
|
111
|
+
{
|
112
|
+
name: 'frontendPort',
|
113
|
+
port: 65_502
|
114
|
+
}
|
115
|
+
],
|
116
|
+
backend_address_pools: [
|
117
|
+
{
|
118
|
+
name: 'backendAddressPool',
|
119
|
+
ip_addresses: [
|
120
|
+
{
|
121
|
+
ipAddress: '10.0.1.6'
|
122
|
+
|
123
|
+
}
|
124
|
+
]
|
125
|
+
}
|
126
|
+
],
|
127
|
+
backend_http_settings_list: [
|
128
|
+
{
|
129
|
+
name: 'gateway_settings',
|
130
|
+
port: 80,
|
131
|
+
protocol: 'Http',
|
132
|
+
cookie_based_affinity: 'Enabled',
|
133
|
+
request_timeout: '30'
|
134
|
+
}
|
135
|
+
],
|
136
|
+
http_listeners: [
|
137
|
+
{
|
138
|
+
name: 'gateway_listener',
|
139
|
+
frontend_ip_config_id: "/subscriptions/#{azure_credentials['subscription_id']}/resourceGroups/#{resource_group_name}/providers/Microsoft.Network/applicationGateways/#{app_gateway_name}/frontendIPConfigurations/frontendIpConfig",
|
140
|
+
frontend_port_id: "/subscriptions/#{azure_credentials['subscription_id']}/resourceGroups/#{resource_group_name}/providers/Microsoft.Network/applicationGateways/#{app_gateway_name}/frontendPorts/frontendPort",
|
141
|
+
protocol: 'Http',
|
142
|
+
host_name: '',
|
143
|
+
require_server_name_indication: 'false'
|
144
|
+
}
|
145
|
+
],
|
146
|
+
request_routing_rules: [
|
147
|
+
{
|
148
|
+
name: 'gateway_request_route_rule',
|
149
|
+
type: 'Basic',
|
150
|
+
http_listener_id: "/subscriptions/#{azure_credentials['subscription_id']}/resourceGroups/#{resource_group_name}/providers/Microsoft.Network/applicationGateways/#{app_gateway_name}/httpListeners/gateway_listener",
|
151
|
+
backend_address_pool_id: "/subscriptions/#{azure_credentials['subscription_id']}/resourceGroups/#{resource_group_name}/providers/Microsoft.Network/applicationGateways/#{app_gateway_name}/backendAddressPools/backendAddressPool",
|
152
|
+
backend_http_settings_id: "/subscriptions/#{azure_credentials['subscription_id']}/resourceGroups/#{resource_group_name}/providers/Microsoft.Network/applicationGateways/#{app_gateway_name}/backendHttpSettingsCollection/gateway_settings",
|
153
|
+
url_path_map: ''
|
154
|
+
}
|
155
|
+
]
|
156
|
+
)
|
157
|
+
puts "Created application gateway #{app_gateway.name}"
|
158
|
+
|
159
|
+
########################################################################################################################
|
160
|
+
###################### Get Application Gateway ######################
|
161
|
+
########################################################################################################################
|
162
|
+
|
163
|
+
app_gateway = application_gateway.gateways.get(resource_group_name, app_gateway_name)
|
164
|
+
puts "Get application gateway: #{app_gateway.name}"
|
165
|
+
|
166
|
+
########################################################################################################################
|
167
|
+
###################### Update sku attributes (Name and Capacity) #########################
|
168
|
+
########################################################################################################################
|
169
|
+
|
170
|
+
app_gateway.update_sku('Standard_Small', '1')
|
171
|
+
puts 'Updated application gateway sku'
|
172
|
+
|
173
|
+
########################################################################################################################
|
174
|
+
###################### Stop Application Gateway #########################
|
175
|
+
########################################################################################################################
|
176
|
+
|
177
|
+
app_gateway.stop
|
178
|
+
puts 'Application Gateway stopped!'
|
179
|
+
|
180
|
+
########################################################################################################################
|
181
|
+
###################### Update gateway ip configuration (Subnet id) #########################
|
182
|
+
########################################################################################################################
|
183
|
+
|
184
|
+
subnet_id = network.subnets.create(
|
185
|
+
name: "#{subnet_name}1",
|
186
|
+
resource_group: resource_group_name,
|
187
|
+
virtual_network_name: virtual_network_name,
|
188
|
+
address_prefix: '10.1.0.0/24'
|
189
|
+
).id
|
190
|
+
|
191
|
+
app_gateway.update_gateway_ip_configuration(subnet_id)
|
192
|
+
puts 'Updated Application Gateway ip configuration'
|
193
|
+
|
194
|
+
########################################################################################################################
|
195
|
+
###################### Start Application Gateway #########################
|
196
|
+
########################################################################################################################
|
197
|
+
|
198
|
+
app_gateway.start
|
199
|
+
puts 'Application Gateway started!'
|
200
|
+
|
201
|
+
########################################################################################################################
|
202
|
+
###################### Add/Remove Frontend ports #########################
|
203
|
+
########################################################################################################################
|
204
|
+
|
205
|
+
app_gateway.add_frontend_port(name: 'frontendPort1', port: 80)
|
206
|
+
puts 'Added Frontend port in application gateway'
|
207
|
+
|
208
|
+
app_gateway.remove_frontend_port(name: 'frontendPort1', port: 80)
|
209
|
+
puts 'Removed Frontend port in application gateway'
|
210
|
+
|
211
|
+
#######################################################################################################################
|
212
|
+
##################### Add/Remove Probes #########################
|
213
|
+
#######################################################################################################################
|
214
|
+
|
215
|
+
app_gateway.add_probe(
|
216
|
+
name: 'Probe1',
|
217
|
+
protocol: 'http',
|
218
|
+
host: 'localhost',
|
219
|
+
path: '/fog-test',
|
220
|
+
interval: 60,
|
221
|
+
timeout: 300,
|
222
|
+
unhealthy_threshold: 5
|
223
|
+
)
|
224
|
+
puts 'Added probe in application gateway'
|
225
|
+
|
226
|
+
app_gateway.remove_probe(
|
227
|
+
name: 'Probe1',
|
228
|
+
protocol: 'http',
|
229
|
+
host: 'localhost',
|
230
|
+
path: '/fog-test',
|
231
|
+
interval: 60,
|
232
|
+
timeout: 300,
|
233
|
+
unhealthy_threshold: 5
|
234
|
+
)
|
235
|
+
puts 'Removed probe in application gateway'
|
236
|
+
|
237
|
+
########################################################################################################################
|
238
|
+
###################### Destroy Application Gateway ######################
|
239
|
+
########################################################################################################################
|
240
|
+
|
241
|
+
puts "Deleted application gateway: #{app_gateway.destroy}"
|
242
|
+
|
243
|
+
########################################################################################################################
|
244
|
+
###################### CleanUp ######################
|
245
|
+
########################################################################################################################
|
246
|
+
|
247
|
+
pubip = network.public_ips.get(resource_group_name, public_ip_name)
|
248
|
+
pubip.destroy
|
249
|
+
|
250
|
+
vnet = network.virtual_networks.get(resource_group_name, virtual_network_name)
|
251
|
+
vnet.destroy
|
252
|
+
|
253
|
+
resource_group = resource.resource_groups.get(resource_group_name)
|
254
|
+
resource_group.destroy
|
255
|
+
|
256
|
+
puts 'Integration Test for application gateway ran successfully'
|
257
|
+
rescue
|
258
|
+
puts 'Integration Test for application gateway is failing'
|
259
|
+
resource_group.destroy unless resource_group.nil?
|
260
|
+
end
|