fog-google 0.0.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +15 -0
- data/.rubocop.yml +20 -0
- data/.ruby-gemset +1 -0
- data/.ruby-version +1 -0
- data/.travis.yml +17 -0
- data/CONTRIBUTING.md +18 -0
- data/CONTRIBUTORS.md +41 -0
- data/Gemfile +4 -0
- data/LICENSE.md +20 -0
- data/README.md +55 -0
- data/Rakefile +34 -0
- data/examples/backend_services.rb +22 -0
- data/examples/bootstrap.rb +9 -0
- data/examples/create.rb +49 -0
- data/examples/dns/project.rb +8 -0
- data/examples/dns/zones.rb +43 -0
- data/examples/eric-fail.rb +36 -0
- data/examples/get_list_images.rb +26 -0
- data/examples/get_list_snapshots.rb +18 -0
- data/examples/image_all.rb +6 -0
- data/examples/image_create.rb +17 -0
- data/examples/l7_load_balance.rb +73 -0
- data/examples/launch_micro_instance.rb +29 -0
- data/examples/load-balance.rb +98 -0
- data/examples/metadata.rb +30 -0
- data/examples/monitoring/metric_descriptors.rb +11 -0
- data/examples/monitoring/timeseries_collection.rb +15 -0
- data/examples/monitoring/timeseries_descriptors.rb +15 -0
- data/examples/network.rb +38 -0
- data/examples/precreated_client.rb +14 -0
- data/examples/sql/flags.rb +7 -0
- data/examples/sql/instances.rb +38 -0
- data/examples/sql/operations.rb +20 -0
- data/examples/sql/ssl_certs.rb +28 -0
- data/examples/sql/tiers.rb +7 -0
- data/fog-google.gemspec +37 -0
- data/gemfiles/Gemfile.1.9.2+ +6 -0
- data/gemfiles/Gemfile.1.9.2- +9 -0
- data/lib/fog/bin/google.rb +88 -0
- data/lib/fog/google.rb +226 -0
- data/lib/fog/google/compute.rb +1068 -0
- data/lib/fog/google/dns.rb +96 -0
- data/lib/fog/google/models/compute/address.rb +94 -0
- data/lib/fog/google/models/compute/addresses.rb +40 -0
- data/lib/fog/google/models/compute/backend_service.rb +92 -0
- data/lib/fog/google/models/compute/backend_services.rb +22 -0
- data/lib/fog/google/models/compute/disk.rb +120 -0
- data/lib/fog/google/models/compute/disk_type.rb +28 -0
- data/lib/fog/google/models/compute/disk_types.rb +40 -0
- data/lib/fog/google/models/compute/disks.rb +41 -0
- data/lib/fog/google/models/compute/firewall.rb +46 -0
- data/lib/fog/google/models/compute/firewalls.rb +25 -0
- data/lib/fog/google/models/compute/flavor.rb +33 -0
- data/lib/fog/google/models/compute/flavors.rb +31 -0
- data/lib/fog/google/models/compute/forwarding_rule.rb +86 -0
- data/lib/fog/google/models/compute/forwarding_rules.rb +41 -0
- data/lib/fog/google/models/compute/global_forwarding_rule.rb +86 -0
- data/lib/fog/google/models/compute/global_forwarding_rules.rb +23 -0
- data/lib/fog/google/models/compute/http_health_check.rb +84 -0
- data/lib/fog/google/models/compute/http_health_checks.rb +26 -0
- data/lib/fog/google/models/compute/image.rb +90 -0
- data/lib/fog/google/models/compute/images.rb +73 -0
- data/lib/fog/google/models/compute/network.rb +43 -0
- data/lib/fog/google/models/compute/networks.rb +25 -0
- data/lib/fog/google/models/compute/operation.rb +75 -0
- data/lib/fog/google/models/compute/operations.rb +37 -0
- data/lib/fog/google/models/compute/project.rb +30 -0
- data/lib/fog/google/models/compute/projects.rb +20 -0
- data/lib/fog/google/models/compute/region.rb +32 -0
- data/lib/fog/google/models/compute/regions.rb +25 -0
- data/lib/fog/google/models/compute/resource_view.rb +116 -0
- data/lib/fog/google/models/compute/resource_views.rb +57 -0
- data/lib/fog/google/models/compute/route.rb +50 -0
- data/lib/fog/google/models/compute/routes.rb +25 -0
- data/lib/fog/google/models/compute/server.rb +258 -0
- data/lib/fog/google/models/compute/servers.rb +80 -0
- data/lib/fog/google/models/compute/snapshot.rb +48 -0
- data/lib/fog/google/models/compute/snapshots.rb +26 -0
- data/lib/fog/google/models/compute/target_http_proxies.rb +22 -0
- data/lib/fog/google/models/compute/target_http_proxy.rb +75 -0
- data/lib/fog/google/models/compute/target_instance.rb +74 -0
- data/lib/fog/google/models/compute/target_instances.rb +28 -0
- data/lib/fog/google/models/compute/target_pool.rb +113 -0
- data/lib/fog/google/models/compute/target_pools.rb +41 -0
- data/lib/fog/google/models/compute/url_map.rb +95 -0
- data/lib/fog/google/models/compute/url_maps.rb +22 -0
- data/lib/fog/google/models/compute/zone.rb +23 -0
- data/lib/fog/google/models/compute/zones.rb +24 -0
- data/lib/fog/google/models/dns/change.rb +40 -0
- data/lib/fog/google/models/dns/changes.rb +52 -0
- data/lib/fog/google/models/dns/project.rb +75 -0
- data/lib/fog/google/models/dns/projects.rb +25 -0
- data/lib/fog/google/models/dns/record.rb +112 -0
- data/lib/fog/google/models/dns/records.rb +52 -0
- data/lib/fog/google/models/dns/zone.rb +74 -0
- data/lib/fog/google/models/dns/zones.rb +34 -0
- data/lib/fog/google/models/monitoring/metric_descriptor.rb +20 -0
- data/lib/fog/google/models/monitoring/metric_descriptors.rb +28 -0
- data/lib/fog/google/models/monitoring/timeseries.rb +17 -0
- data/lib/fog/google/models/monitoring/timeseries_collection.rb +31 -0
- data/lib/fog/google/models/monitoring/timeseries_descriptor.rb +20 -0
- data/lib/fog/google/models/monitoring/timeseries_descriptors.rb +31 -0
- data/lib/fog/google/models/sql/backup_run.rb +34 -0
- data/lib/fog/google/models/sql/backup_runs.rb +38 -0
- data/lib/fog/google/models/sql/flag.rb +22 -0
- data/lib/fog/google/models/sql/flags.rb +21 -0
- data/lib/fog/google/models/sql/instance.rb +353 -0
- data/lib/fog/google/models/sql/instances.rb +39 -0
- data/lib/fog/google/models/sql/operation.rb +61 -0
- data/lib/fog/google/models/sql/operations.rb +49 -0
- data/lib/fog/google/models/sql/ssl_cert.rb +73 -0
- data/lib/fog/google/models/sql/ssl_certs.rb +49 -0
- data/lib/fog/google/models/sql/tier.rb +20 -0
- data/lib/fog/google/models/sql/tiers.rb +21 -0
- data/lib/fog/google/models/storage/directories.rb +39 -0
- data/lib/fog/google/models/storage/directory.rb +74 -0
- data/lib/fog/google/models/storage/file.rb +144 -0
- data/lib/fog/google/models/storage/files.rb +104 -0
- data/lib/fog/google/monitoring.rb +87 -0
- data/lib/fog/google/parsers/storage/access_control_list.rb +44 -0
- data/lib/fog/google/parsers/storage/copy_object.rb +18 -0
- data/lib/fog/google/parsers/storage/get_bucket.rb +58 -0
- data/lib/fog/google/parsers/storage/get_bucket_logging.rb +36 -0
- data/lib/fog/google/parsers/storage/get_bucket_object_versions.rb +84 -0
- data/lib/fog/google/parsers/storage/get_bucket_versioning.rb +20 -0
- data/lib/fog/google/parsers/storage/get_request_payment.rb +16 -0
- data/lib/fog/google/parsers/storage/get_service.rb +28 -0
- data/lib/fog/google/requests/compute/add_backend_service_backends.rb +29 -0
- data/lib/fog/google/requests/compute/add_region_view_resources.rb +27 -0
- data/lib/fog/google/requests/compute/add_server_access_config.rb +32 -0
- data/lib/fog/google/requests/compute/add_target_pool_health_checks.rb +27 -0
- data/lib/fog/google/requests/compute/add_target_pool_instances.rb +27 -0
- data/lib/fog/google/requests/compute/add_url_map_host_rules.rb +25 -0
- data/lib/fog/google/requests/compute/add_url_map_path_matchers.rb +29 -0
- data/lib/fog/google/requests/compute/add_zone_view_resources.rb +27 -0
- data/lib/fog/google/requests/compute/attach_disk.rb +34 -0
- data/lib/fog/google/requests/compute/delete_address.rb +24 -0
- data/lib/fog/google/requests/compute/delete_backend_service.rb +43 -0
- data/lib/fog/google/requests/compute/delete_disk.rb +48 -0
- data/lib/fog/google/requests/compute/delete_firewall.rb +23 -0
- data/lib/fog/google/requests/compute/delete_forwarding_rule.rb +49 -0
- data/lib/fog/google/requests/compute/delete_global_forwarding_rule.rb +48 -0
- data/lib/fog/google/requests/compute/delete_global_operation.rb +25 -0
- data/lib/fog/google/requests/compute/delete_http_health_check.rb +41 -0
- data/lib/fog/google/requests/compute/delete_image.rb +42 -0
- data/lib/fog/google/requests/compute/delete_network.rb +23 -0
- data/lib/fog/google/requests/compute/delete_region_operation.rb +29 -0
- data/lib/fog/google/requests/compute/delete_region_view.rb +24 -0
- data/lib/fog/google/requests/compute/delete_route.rb +23 -0
- data/lib/fog/google/requests/compute/delete_server.rb +69 -0
- data/lib/fog/google/requests/compute/delete_server_access_config.rb +26 -0
- data/lib/fog/google/requests/compute/delete_snapshot.rb +23 -0
- data/lib/fog/google/requests/compute/delete_target_http_proxy.rb +43 -0
- data/lib/fog/google/requests/compute/delete_target_instance.rb +48 -0
- data/lib/fog/google/requests/compute/delete_target_pool.rb +49 -0
- data/lib/fog/google/requests/compute/delete_url_map.rb +43 -0
- data/lib/fog/google/requests/compute/delete_zone_operation.rb +29 -0
- data/lib/fog/google/requests/compute/delete_zone_view.rb +24 -0
- data/lib/fog/google/requests/compute/detach_disk.rb +25 -0
- data/lib/fog/google/requests/compute/get_address.rb +24 -0
- data/lib/fog/google/requests/compute/get_backend_service.rb +26 -0
- data/lib/fog/google/requests/compute/get_backend_service_health.rb +27 -0
- data/lib/fog/google/requests/compute/get_backend_services.rb +23 -0
- data/lib/fog/google/requests/compute/get_disk.rb +52 -0
- data/lib/fog/google/requests/compute/get_disk_type.rb +42 -0
- data/lib/fog/google/requests/compute/get_firewall.rb +23 -0
- data/lib/fog/google/requests/compute/get_forwarding_rule.rb +46 -0
- data/lib/fog/google/requests/compute/get_global_forwarding_rule.rb +32 -0
- data/lib/fog/google/requests/compute/get_global_operation.rb +50 -0
- data/lib/fog/google/requests/compute/get_http_health_check.rb +39 -0
- data/lib/fog/google/requests/compute/get_image.rb +36 -0
- data/lib/fog/google/requests/compute/get_machine_type.rb +43 -0
- data/lib/fog/google/requests/compute/get_network.rb +23 -0
- data/lib/fog/google/requests/compute/get_project.rb +22 -0
- data/lib/fog/google/requests/compute/get_region.rb +37 -0
- data/lib/fog/google/requests/compute/get_region_operation.rb +55 -0
- data/lib/fog/google/requests/compute/get_region_view.rb +24 -0
- data/lib/fog/google/requests/compute/get_route.rb +23 -0
- data/lib/fog/google/requests/compute/get_server.rb +75 -0
- data/lib/fog/google/requests/compute/get_server_serial_port_output.rb +24 -0
- data/lib/fog/google/requests/compute/get_snapshot.rb +27 -0
- data/lib/fog/google/requests/compute/get_target_http_proxy.rb +27 -0
- data/lib/fog/google/requests/compute/get_target_instance.rb +32 -0
- data/lib/fog/google/requests/compute/get_target_pool.rb +40 -0
- data/lib/fog/google/requests/compute/get_target_pool_health.rb +29 -0
- data/lib/fog/google/requests/compute/get_url_map.rb +27 -0
- data/lib/fog/google/requests/compute/get_zone.rb +36 -0
- data/lib/fog/google/requests/compute/get_zone_operation.rb +55 -0
- data/lib/fog/google/requests/compute/get_zone_view.rb +24 -0
- data/lib/fog/google/requests/compute/insert_address.rb +25 -0
- data/lib/fog/google/requests/compute/insert_backend_service.rb +63 -0
- data/lib/fog/google/requests/compute/insert_disk.rb +113 -0
- data/lib/fog/google/requests/compute/insert_firewall.rb +43 -0
- data/lib/fog/google/requests/compute/insert_forwarding_rule.rb +60 -0
- data/lib/fog/google/requests/compute/insert_global_forwarding_rule.rb +56 -0
- data/lib/fog/google/requests/compute/insert_http_health_check.rb +59 -0
- data/lib/fog/google/requests/compute/insert_image.rb +64 -0
- data/lib/fog/google/requests/compute/insert_network.rb +29 -0
- data/lib/fog/google/requests/compute/insert_region_view.rb +25 -0
- data/lib/fog/google/requests/compute/insert_route.rb +35 -0
- data/lib/fog/google/requests/compute/insert_server.rb +191 -0
- data/lib/fog/google/requests/compute/insert_snapshot.rb +40 -0
- data/lib/fog/google/requests/compute/insert_target_http_proxy.rb +52 -0
- data/lib/fog/google/requests/compute/insert_target_instance.rb +55 -0
- data/lib/fog/google/requests/compute/insert_target_pool.rb +58 -0
- data/lib/fog/google/requests/compute/insert_url_map.rb +55 -0
- data/lib/fog/google/requests/compute/insert_zone_view.rb +27 -0
- data/lib/fog/google/requests/compute/list_addresses.rb +23 -0
- data/lib/fog/google/requests/compute/list_aggregated_addresses.rb +23 -0
- data/lib/fog/google/requests/compute/list_aggregated_disk_types.rb +40 -0
- data/lib/fog/google/requests/compute/list_aggregated_disks.rb +40 -0
- data/lib/fog/google/requests/compute/list_aggregated_machine_types.rb +22 -0
- data/lib/fog/google/requests/compute/list_aggregated_servers.rb +40 -0
- data/lib/fog/google/requests/compute/list_backend_services.rb +29 -0
- data/lib/fog/google/requests/compute/list_disk_types.rb +46 -0
- data/lib/fog/google/requests/compute/list_disks.rb +29 -0
- data/lib/fog/google/requests/compute/list_firewalls.rb +22 -0
- data/lib/fog/google/requests/compute/list_forwarding_rules.rb +29 -0
- data/lib/fog/google/requests/compute/list_global_forwarding_rules.rb +30 -0
- data/lib/fog/google/requests/compute/list_global_operations.rb +24 -0
- data/lib/fog/google/requests/compute/list_http_health_checks.rb +29 -0
- data/lib/fog/google/requests/compute/list_images.rb +29 -0
- data/lib/fog/google/requests/compute/list_machine_types.rb +30 -0
- data/lib/fog/google/requests/compute/list_networks.rb +22 -0
- data/lib/fog/google/requests/compute/list_region_operations.rb +25 -0
- data/lib/fog/google/requests/compute/list_region_view_resources.rb +25 -0
- data/lib/fog/google/requests/compute/list_region_views.rb +23 -0
- data/lib/fog/google/requests/compute/list_regions.rb +85 -0
- data/lib/fog/google/requests/compute/list_routes.rb +22 -0
- data/lib/fog/google/requests/compute/list_servers.rb +31 -0
- data/lib/fog/google/requests/compute/list_snapshots.rb +23 -0
- data/lib/fog/google/requests/compute/list_target_http_proxies.rb +30 -0
- data/lib/fog/google/requests/compute/list_target_instances.rb +30 -0
- data/lib/fog/google/requests/compute/list_target_pools.rb +29 -0
- data/lib/fog/google/requests/compute/list_url_maps.rb +29 -0
- data/lib/fog/google/requests/compute/list_zone_operations.rb +25 -0
- data/lib/fog/google/requests/compute/list_zone_view_resources.rb +25 -0
- data/lib/fog/google/requests/compute/list_zone_views.rb +23 -0
- data/lib/fog/google/requests/compute/list_zones.rb +28 -0
- data/lib/fog/google/requests/compute/remove_target_pool_health_checks.rb +27 -0
- data/lib/fog/google/requests/compute/remove_target_pool_instance.rb +27 -0
- data/lib/fog/google/requests/compute/remove_target_pool_instances.rb +27 -0
- data/lib/fog/google/requests/compute/reset_server.rb +24 -0
- data/lib/fog/google/requests/compute/set_common_instance_metadata.rb +26 -0
- data/lib/fog/google/requests/compute/set_forwarding_rule_target.rb +27 -0
- data/lib/fog/google/requests/compute/set_global_forwarding_rule_target.rb +27 -0
- data/lib/fog/google/requests/compute/set_metadata.rb +39 -0
- data/lib/fog/google/requests/compute/set_server_disk_auto_delete.rb +26 -0
- data/lib/fog/google/requests/compute/set_server_scheduling.rb +29 -0
- data/lib/fog/google/requests/compute/set_tags.rb +24 -0
- data/lib/fog/google/requests/compute/set_target_http_proxy_url_map.rb +27 -0
- data/lib/fog/google/requests/compute/start_server.rb +24 -0
- data/lib/fog/google/requests/compute/stop_server.rb +24 -0
- data/lib/fog/google/requests/compute/update_url_map.rb +39 -0
- data/lib/fog/google/requests/compute/validate_url_map.rb +24 -0
- data/lib/fog/google/requests/dns/create_change.rb +64 -0
- data/lib/fog/google/requests/dns/create_managed_zone.rb +82 -0
- data/lib/fog/google/requests/dns/delete_managed_zone.rb +35 -0
- data/lib/fog/google/requests/dns/get_change.rb +42 -0
- data/lib/fog/google/requests/dns/get_managed_zone.rb +37 -0
- data/lib/fog/google/requests/dns/get_project.rb +42 -0
- data/lib/fog/google/requests/dns/list_changes.rb +41 -0
- data/lib/fog/google/requests/dns/list_managed_zones.rb +31 -0
- data/lib/fog/google/requests/dns/list_resource_record_sets.rb +50 -0
- data/lib/fog/google/requests/monitoring/list_metric_descriptors.rb +191 -0
- data/lib/fog/google/requests/monitoring/list_timeseries.rb +68 -0
- data/lib/fog/google/requests/monitoring/list_timeseries_descriptors.rb +87 -0
- data/lib/fog/google/requests/sql/clone_instance.rb +84 -0
- data/lib/fog/google/requests/sql/delete_instance.rb +67 -0
- data/lib/fog/google/requests/sql/delete_ssl_cert.rb +68 -0
- data/lib/fog/google/requests/sql/export_instance.rb +56 -0
- data/lib/fog/google/requests/sql/get_backup_run.rb +30 -0
- data/lib/fog/google/requests/sql/get_instance.rb +48 -0
- data/lib/fog/google/requests/sql/get_operation.rb +66 -0
- data/lib/fog/google/requests/sql/get_ssl_cert.rb +66 -0
- data/lib/fog/google/requests/sql/import_instance.rb +55 -0
- data/lib/fog/google/requests/sql/insert_instance.rb +165 -0
- data/lib/fog/google/requests/sql/insert_ssl_cert.rb +80 -0
- data/lib/fog/google/requests/sql/list_backup_runs.rb +30 -0
- data/lib/fog/google/requests/sql/list_flags.rb +143 -0
- data/lib/fog/google/requests/sql/list_instances.rb +32 -0
- data/lib/fog/google/requests/sql/list_operations.rb +52 -0
- data/lib/fog/google/requests/sql/list_ssl_certs.rb +51 -0
- data/lib/fog/google/requests/sql/list_tiers.rb +82 -0
- data/lib/fog/google/requests/sql/reset_instance_ssl_config.rb +49 -0
- data/lib/fog/google/requests/sql/restart_instance.rb +47 -0
- data/lib/fog/google/requests/sql/restore_instance_backup.rb +30 -0
- data/lib/fog/google/requests/sql/set_instance_root_password.rb +54 -0
- data/lib/fog/google/requests/sql/update_instance.rb +132 -0
- data/lib/fog/google/requests/storage/copy_object.rb +68 -0
- data/lib/fog/google/requests/storage/delete_bucket.rb +41 -0
- data/lib/fog/google/requests/storage/delete_object.rb +46 -0
- data/lib/fog/google/requests/storage/get_bucket.rb +106 -0
- data/lib/fog/google/requests/storage/get_bucket_acl.rb +59 -0
- data/lib/fog/google/requests/storage/get_object.rb +108 -0
- data/lib/fog/google/requests/storage/get_object_acl.rb +70 -0
- data/lib/fog/google/requests/storage/get_object_http_url.rb +44 -0
- data/lib/fog/google/requests/storage/get_object_https_url.rb +44 -0
- data/lib/fog/google/requests/storage/get_object_torrent.rb +45 -0
- data/lib/fog/google/requests/storage/get_object_url.rb +33 -0
- data/lib/fog/google/requests/storage/get_service.rb +48 -0
- data/lib/fog/google/requests/storage/head_object.rb +60 -0
- data/lib/fog/google/requests/storage/put_bucket.rb +71 -0
- data/lib/fog/google/requests/storage/put_bucket_acl.rb +58 -0
- data/lib/fog/google/requests/storage/put_object.rb +89 -0
- data/lib/fog/google/requests/storage/put_object_acl.rb +51 -0
- data/lib/fog/google/requests/storage/put_object_url.rb +50 -0
- data/lib/fog/google/sql.rb +130 -0
- data/lib/fog/google/storage.rb +298 -0
- data/lib/fog/google/version.rb +5 -0
- data/spec/minitest_helper.rb +31 -0
- data/tests/credentials_tests.rb +73 -0
- data/tests/helper.rb +126 -0
- data/tests/helpers/collection_helper.rb +97 -0
- data/tests/helpers/compute/flavors_helper.rb +32 -0
- data/tests/helpers/compute/server_helper.rb +25 -0
- data/tests/helpers/compute/servers_helper.rb +10 -0
- data/tests/helpers/formats_helper.rb +98 -0
- data/tests/helpers/formats_helper_tests.rb +110 -0
- data/tests/helpers/mock_helper.rb +18 -0
- data/tests/helpers/model_helper.rb +31 -0
- data/tests/helpers/responds_to_helper.rb +11 -0
- data/tests/helpers/schema_validator_tests.rb +107 -0
- data/tests/helpers/succeeds_helper.rb +9 -0
- data/tests/lorem.txt +1 -0
- data/tests/models/compute/backend_service_tests.rb +6 -0
- data/tests/models/compute/backend_services_tests.rb +8 -0
- data/tests/models/compute/disk_tests.rb +9 -0
- data/tests/models/compute/disk_types_tests.rb +22 -0
- data/tests/models/compute/disks_tests.rb +9 -0
- data/tests/models/compute/forwarding_rule_tests.rb +8 -0
- data/tests/models/compute/forwarding_rules_tests.rb +8 -0
- data/tests/models/compute/global_forwarding_rule_tests.rb +7 -0
- data/tests/models/compute/global_forwarding_rules_tests.rb +7 -0
- data/tests/models/compute/http_health_check_tests.rb +5 -0
- data/tests/models/compute/http_health_checks_tests.rb +5 -0
- data/tests/models/compute/image_tests.rb +6 -0
- data/tests/models/compute/images_tests.rb +6 -0
- data/tests/models/compute/region_tests.rb +10 -0
- data/tests/models/compute/regions_tests.rb +19 -0
- data/tests/models/compute/server_tests.rb +37 -0
- data/tests/models/compute/servers_tests.rb +14 -0
- data/tests/models/compute/target_http_proxies_tests.rb +7 -0
- data/tests/models/compute/target_http_proxy_test.rb +6 -0
- data/tests/models/compute/target_instance_tests.rb +7 -0
- data/tests/models/compute/target_instances_tests.rb +7 -0
- data/tests/models/compute/target_pool_tests.rb +12 -0
- data/tests/models/compute/target_pools_tests.rb +11 -0
- data/tests/models/compute/url_map_tests.rb +6 -0
- data/tests/models/compute/url_maps_tests.rb +7 -0
- data/tests/models/dns/change_tests.rb +28 -0
- data/tests/models/dns/changes_tests.rb +36 -0
- data/tests/models/dns/projects_tests.rb +12 -0
- data/tests/models/dns/record_tests.rb +42 -0
- data/tests/models/dns/records_tests.rb +36 -0
- data/tests/models/dns/zone_tests.rb +28 -0
- data/tests/models/dns/zones_tests.rb +14 -0
- data/tests/models/monitoring/metric_descriptors_tests.rb +12 -0
- data/tests/models/monitoring/timeseries_collection_tests.rb +12 -0
- data/tests/models/monitoring/timeseries_descriptors_tests.rb +13 -0
- data/tests/models/sql/flags_tests.rb +12 -0
- data/tests/models/sql/instance_tests.rb +56 -0
- data/tests/models/sql/instances_tests.rb +32 -0
- data/tests/models/sql/operation_tests.rb +25 -0
- data/tests/models/sql/operations_tests.rb +38 -0
- data/tests/models/sql/ssl_cert_tests.rb +24 -0
- data/tests/models/sql/ssl_certs_tests.rb +39 -0
- data/tests/models/sql/tiers_tests.rb +12 -0
- data/tests/requests/compute/backend_service_tests.rb +83 -0
- data/tests/requests/compute/disk_tests.rb +74 -0
- data/tests/requests/compute/disk_type_tests.rb +45 -0
- data/tests/requests/compute/firewall_tests.rb +88 -0
- data/tests/requests/compute/forwarding_rules_tests.rb +83 -0
- data/tests/requests/compute/global_forwarding_rules_tests.rb +83 -0
- data/tests/requests/compute/http_health_checks_tests.rb +83 -0
- data/tests/requests/compute/image_tests.rb +83 -0
- data/tests/requests/compute/network_tests.rb +75 -0
- data/tests/requests/compute/operation_tests.rb +20 -0
- data/tests/requests/compute/region_tests.rb +39 -0
- data/tests/requests/compute/server_tests.rb +84 -0
- data/tests/requests/compute/target_http_proxies_test.rb +79 -0
- data/tests/requests/compute/target_instances_tests.rb +83 -0
- data/tests/requests/compute/target_pools_tests.rb +82 -0
- data/tests/requests/compute/url_maps_tests.rb +82 -0
- data/tests/requests/compute/zone_tests.rb +37 -0
- data/tests/requests/dns/change_tests.rb +86 -0
- data/tests/requests/dns/managed_zone_tests.rb +66 -0
- data/tests/requests/dns/project_tests.rb +29 -0
- data/tests/requests/dns/record_tests.rb +49 -0
- data/tests/requests/monitoring/metric_descriptor_tests.rb +25 -0
- data/tests/requests/monitoring/timeseries_collection_tests.rb +25 -0
- data/tests/requests/monitoring/timeseries_descriptor_tests.rb +26 -0
- data/tests/requests/sql/flag_tests.rb +27 -0
- data/tests/requests/sql/instance_tests.rb +129 -0
- data/tests/requests/sql/operation_tests.rb +42 -0
- data/tests/requests/sql/ssl_cert_tests.rb +61 -0
- data/tests/requests/sql/tier_tests.rb +25 -0
- data/tests/requests/storage/bucket_tests.rb +77 -0
- data/tests/requests/storage/object_tests.rb +84 -0
- metadata +625 -0
@@ -0,0 +1,35 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
class Mock
|
5
|
+
def insert_route(name, network, dest_range, priority, options = {})
|
6
|
+
Fog::Mock.not_implemented
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
class Real
|
11
|
+
def insert_route(name, network, dest_range, priority, options = {})
|
12
|
+
api_method = @compute.routes.insert
|
13
|
+
parameters = {
|
14
|
+
'project' => @project,
|
15
|
+
}
|
16
|
+
body_object = {
|
17
|
+
'name' => name,
|
18
|
+
'network' => network,
|
19
|
+
'destRange' => dest_range,
|
20
|
+
'priority' => priority,
|
21
|
+
}
|
22
|
+
body_object['description'] = options[:description] if options[:description]
|
23
|
+
unless options[:tags].nil? || options[:tags].empty?
|
24
|
+
body_object['tags'] = options[:tags]
|
25
|
+
end
|
26
|
+
body_object['nextHopInstance'] = options[:next_hop_instance] if options[:next_hop_instance]
|
27
|
+
body_object['nextHopGateway'] = options[:next_hop_gateway] if options[:next_hop_gateway]
|
28
|
+
body_object['nextHopIp'] = options[:next_hop_ip] if options[:next_hop_ip]
|
29
|
+
|
30
|
+
request(api_method, parameters, body_object)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,191 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
class Mock
|
5
|
+
include Shared
|
6
|
+
|
7
|
+
def handle_disks(options, zone_name)
|
8
|
+
disks = []
|
9
|
+
i = 0
|
10
|
+
options.delete('disks').each do |disk|
|
11
|
+
disk = Disk.new(disk) unless disk.is_a? Disk
|
12
|
+
disks << {
|
13
|
+
"kind"=>"compute#attachedDisk",
|
14
|
+
"index"=>i,
|
15
|
+
"type"=>"PERSISTENT",
|
16
|
+
"mode"=>"READ_WRITE",
|
17
|
+
"source"=>"https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/disks/#{disk.name}",
|
18
|
+
"deviceName"=>"persistent-disk-#{i}",
|
19
|
+
"boot"=>true
|
20
|
+
}
|
21
|
+
i+=1
|
22
|
+
end
|
23
|
+
disks
|
24
|
+
end
|
25
|
+
|
26
|
+
def insert_server(server_name, zone_name, options={}, *deprecated_args)
|
27
|
+
# check that zone exists
|
28
|
+
get_zone(zone_name)
|
29
|
+
|
30
|
+
if options['disks'].nil? or options['disks'].empty?
|
31
|
+
raise ArgumentError.new "Empty value for field 'disks'. Boot disk must be specified"
|
32
|
+
end
|
33
|
+
id = Fog::Mock.random_numbers(19).to_s
|
34
|
+
self.data[:servers][server_name] = {
|
35
|
+
"kind" => "compute#instance",
|
36
|
+
"id" => id,
|
37
|
+
"creationTimestamp" => Time.now.iso8601,
|
38
|
+
"zone" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}",
|
39
|
+
"status" => "PROVISIONING",
|
40
|
+
"name" => server_name,
|
41
|
+
"tags" => { "fingerprint" => "42WmSpB8rSM=" },
|
42
|
+
"machineType" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/machineTypes/#{options['machineType']}",
|
43
|
+
"canIpForward" => false,
|
44
|
+
"networkInterfaces" => [
|
45
|
+
{
|
46
|
+
"network" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/global/networks/default",
|
47
|
+
"networkIP" => Fog::Mock.random_ip,
|
48
|
+
"name" => "nic0",
|
49
|
+
"accessConfigs" => [
|
50
|
+
{
|
51
|
+
"kind" => "compute#accessConfig",
|
52
|
+
"type" => "ONE_TO_ONE_NAT",
|
53
|
+
"name" => "External NAT",
|
54
|
+
"natIP" => Fog::Mock.random_ip
|
55
|
+
}
|
56
|
+
]
|
57
|
+
}
|
58
|
+
],
|
59
|
+
"disks" => handle_disks(options, zone_name),
|
60
|
+
"metadata" => {
|
61
|
+
"kind" => "compute#metadata",
|
62
|
+
"fingerprint" => "5_hasd_gC3E=",
|
63
|
+
"items" => [
|
64
|
+
{
|
65
|
+
"key" => "sshKeys",
|
66
|
+
"value" => "sysadmin:ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAgEA1zc7mx+0H8Roywet/L0aVX6MUdkDfzd/17kZhprAbpUXYOILv9AG4lIzQk6xGxDIltghytjfVGme/4A42Sb0Z9LN0pxB4KnWTNoOSHPJtp6jbXpq6PdN9r3Z5NKQg0A/Tfw7gt2N0GDsj6vpK8VbHHdW78JAVUxql18ootJxjaksdocsiHNK8iA6/v9qiLRhX3fOgtK7KpxxdZxLRzFg9vkp8jcGISgpZt27kOgXWhR5YLhi8pRJookzphO5O4yhflgoHoAE65XkfrsRCe0HU5QTbY2jH88rBVkq0KVlZh/lEsuwfmG4d77kEqaCGGro+j1Wrvo2K3DSQ+rEcvPp2CYRUySjhaeLF18UzQLtxNeoN14QOYqlm9ITdkCnmq5w4Wn007MjSOFp8LEq2RekrnddGXjg1/vgmXtaVSGzJAlXwtVfZor3dTRmF0JCpr7DsiupBaDFtLUlGFFlSKmPDVMPOOB5wajexmcvSp2Vu4U3yP8Lai/9/ZxMdsGPhpdCsWVL83B5tF4oYj1HVIycbYIxIIfFqOxZcCru3CMfe9jmzKgKLv2UtkfOS8jpS/Os2gAiB3wPweH3agvtwYAYBVMDwt5cnrhgHYWoOz7ABD8KgmCrD7Y9HikiCqIUNkgUFd9YmjcYi5FkU5rFXIawN7efs341lsdf923lsdf923fs= johndoe@acme"
|
67
|
+
}
|
68
|
+
]
|
69
|
+
},
|
70
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/instances/#{server_name}"
|
71
|
+
}
|
72
|
+
|
73
|
+
operation = self.random_operation
|
74
|
+
self.data[:operations][operation] = {
|
75
|
+
"kind" => "compute#operation",
|
76
|
+
"id" => Fog::Mock.random_numbers(19).to_s,
|
77
|
+
"name" => operation,
|
78
|
+
"zone" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}",
|
79
|
+
"operationType" => "insert",
|
80
|
+
"targetLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/instances/#{server_name}",
|
81
|
+
"targetId" => id,
|
82
|
+
"status" => Fog::Compute::Google::Operation::PENDING_STATE,
|
83
|
+
"user" => "123456789012-qwertyuiopasdfghjkl1234567890qwe@developer.gserviceaccount.com",
|
84
|
+
"progress" => 0,
|
85
|
+
"insertTime" => Time.now.iso8601,
|
86
|
+
"startTime" => Time.now.iso8601,
|
87
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/operations/#{operation}"
|
88
|
+
}
|
89
|
+
|
90
|
+
build_excon_response(self.data[:operations][operation])
|
91
|
+
end
|
92
|
+
end
|
93
|
+
|
94
|
+
class Real
|
95
|
+
include Shared
|
96
|
+
|
97
|
+
def handle_disks(options)
|
98
|
+
disks = []
|
99
|
+
# An array of persistent disks. You must supply a boot disk as the first disk in
|
100
|
+
# this array and mark it as a boot disk using the disks[].boot property.
|
101
|
+
options.delete('disks').each do |disk|
|
102
|
+
if disk.is_a? Disk
|
103
|
+
disks << disk.get_object
|
104
|
+
else
|
105
|
+
disks << disk
|
106
|
+
end
|
107
|
+
end
|
108
|
+
disks.first['boot'] = true
|
109
|
+
disks
|
110
|
+
end
|
111
|
+
|
112
|
+
def format_metadata(metadata)
|
113
|
+
{ "items" => metadata.map {|k,v| {"key" => k, "value" => v}} }
|
114
|
+
end
|
115
|
+
|
116
|
+
def insert_server(server_name, zone_name, options={}, *deprecated_args)
|
117
|
+
if deprecated_args.length > 0 or not options.is_a? Hash
|
118
|
+
raise ArgumentError.new 'Too many parameters specified. This may be the cause of code written for an outdated'\
|
119
|
+
' version of fog. Usage: server_name, zone_name, [options]'
|
120
|
+
end
|
121
|
+
api_method = @compute.instances.insert
|
122
|
+
parameters = {
|
123
|
+
'project' => @project,
|
124
|
+
'zone' => zone_name,
|
125
|
+
}
|
126
|
+
body_object = {:name => server_name}
|
127
|
+
|
128
|
+
body_object['machineType'] = @api_url + @project + "/zones/#{zone_name}/machineTypes/#{options.delete 'machineType'}"
|
129
|
+
network = nil
|
130
|
+
if options.key? 'network'
|
131
|
+
network = options.delete 'network'
|
132
|
+
else
|
133
|
+
network = GOOGLE_COMPUTE_DEFAULT_NETWORK
|
134
|
+
end
|
135
|
+
|
136
|
+
# ExternalIP is default value for server creation
|
137
|
+
access_config = {'type' => 'ONE_TO_ONE_NAT', 'name' => 'External NAT'}
|
138
|
+
# leave natIP undefined to use an IP from a shared ephemeral IP address pool
|
139
|
+
if options.key? 'externalIp'
|
140
|
+
access_config['natIP'] = options.delete 'externalIp'
|
141
|
+
# If set to 'false', that would mean user does no want to allocate an external IP
|
142
|
+
access_config = nil if access_config['natIP'] == false
|
143
|
+
end
|
144
|
+
|
145
|
+
networkInterfaces = []
|
146
|
+
if ! network.nil?
|
147
|
+
networkInterface = { 'network' => @api_url + @project + "/global/networks/#{network}" }
|
148
|
+
networkInterface['accessConfigs'] = [access_config] if access_config
|
149
|
+
networkInterfaces << networkInterface
|
150
|
+
end
|
151
|
+
|
152
|
+
scheduling = {
|
153
|
+
'automaticRestart' => false,
|
154
|
+
'onHostMaintenance' => "MIGRATE"
|
155
|
+
}
|
156
|
+
if options.key? 'auto_restart'
|
157
|
+
scheduling['automaticRestart'] = options.delete 'auto_restart'
|
158
|
+
scheduling['automaticRestart'] = scheduling['automaticRestart'].class == TrueClass
|
159
|
+
end
|
160
|
+
if options.key? 'on_host_maintenance'
|
161
|
+
ohm = options.delete 'on_host_maintenance'
|
162
|
+
scheduling['onHostMaintenance'] = (ohm.respond_to?("upcase") &&
|
163
|
+
ohm.upcase == "MIGRATE" && "MIGRATE") || "TERMINATE"
|
164
|
+
end
|
165
|
+
body_object['scheduling'] = scheduling
|
166
|
+
|
167
|
+
# @see https://developers.google.com/compute/docs/networking#canipforward
|
168
|
+
if options.key? 'can_ip_forward'
|
169
|
+
body_object['canIpForward'] = options.delete 'can_ip_forward'
|
170
|
+
end
|
171
|
+
|
172
|
+
# TODO: add other networks
|
173
|
+
body_object['networkInterfaces'] = networkInterfaces
|
174
|
+
|
175
|
+
if options['disks'].nil? or options['disks'].empty?
|
176
|
+
raise ArgumentError.new "Empty value for field 'disks'. Boot disk must be specified"
|
177
|
+
end
|
178
|
+
body_object['disks'] = handle_disks(options)
|
179
|
+
|
180
|
+
options['metadata'] = format_metadata options['metadata'] if options['metadata']
|
181
|
+
|
182
|
+
body_object['tags'] = { 'items' => options.delete('tags') } if options['tags']
|
183
|
+
|
184
|
+
body_object.merge!(options) # Adds in all remaining options that weren't explicitly handled.
|
185
|
+
|
186
|
+
request(api_method, parameters, body_object=body_object)
|
187
|
+
end
|
188
|
+
end
|
189
|
+
end
|
190
|
+
end
|
191
|
+
end
|
@@ -0,0 +1,40 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
class Mock
|
5
|
+
def insert_snapshot(snap_name)
|
6
|
+
Fog::Mock.not_implemented
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
class Real
|
11
|
+
def insert_snapshot(disk_name, zone_name, project=@project, opts={})
|
12
|
+
# This is unfortunate, since we might be called from 2 contexts
|
13
|
+
# 1. disk.snapshot <-- here validation of disk_name is not needed
|
14
|
+
# 2. snapshot.create <-- here we must validate the disk_name
|
15
|
+
#
|
16
|
+
# Validation would involve 'get'ing the disk by that name. This is
|
17
|
+
# redundant (and expensive) for case (1) which is likely the common
|
18
|
+
# codepath. So we won't do it.
|
19
|
+
|
20
|
+
api_method = @compute.disks.create_snapshot
|
21
|
+
|
22
|
+
parameters = {
|
23
|
+
'disk' => disk_name,
|
24
|
+
'zone' => zone_name,
|
25
|
+
'project' => @project,
|
26
|
+
}
|
27
|
+
|
28
|
+
snap_name = opts.delete('name')
|
29
|
+
raise ArgumentError.new('Must specify snapshot name') unless snap_name
|
30
|
+
body_object = { 'name' => snap_name }
|
31
|
+
|
32
|
+
# Merge in any remaining options (description)
|
33
|
+
body_object.merge!(opts)
|
34
|
+
|
35
|
+
request(api_method, parameters, body_object)
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
@@ -0,0 +1,52 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
class Mock
|
5
|
+
def insert_target_http_proxy(name, options={})
|
6
|
+
id = Fog::Mock.random_numbers(19).to_s
|
7
|
+
self.data[:target_http_proxies][name] = {
|
8
|
+
"kind" => "compute#targetHttpProxy",
|
9
|
+
"id" => id,
|
10
|
+
"creationTimestamp" => Time.now.iso8601,
|
11
|
+
"name" => name,
|
12
|
+
"description" => '',
|
13
|
+
"urlMap" => options["urlMap"],
|
14
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/global/targetHttpProxies/#{name}"
|
15
|
+
}
|
16
|
+
|
17
|
+
operation = self.random_operation
|
18
|
+
self.data[:operations][operation] = {
|
19
|
+
"kind" => "compute#operation",
|
20
|
+
"id" => Fog::Mock.random_numbers(19).to_s,
|
21
|
+
"name" => operation,
|
22
|
+
"zone" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/global",
|
23
|
+
"operationType" => "insert",
|
24
|
+
"targetLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/global/targetHttpProxies/#{name}",
|
25
|
+
"targetId" => id,
|
26
|
+
"status" => Fog::Compute::Google::Operation::PENDING_STATE,
|
27
|
+
"user" => "123456789012-qwertyuiopasdfghjkl1234567890qwe@developer.gserviceaccount.com",
|
28
|
+
"progress" => 0,
|
29
|
+
"insertTime" => Time.now.iso8601,
|
30
|
+
"startTime" => Time.now.iso8601,
|
31
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/global/operations/#{operation}"
|
32
|
+
}
|
33
|
+
|
34
|
+
build_excon_response(self.data[:operations][operation])
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
class Real
|
39
|
+
def insert_target_http_proxy(name, opts={})
|
40
|
+
api_method = @compute.target_http_proxies.insert
|
41
|
+
parameters = {
|
42
|
+
'project' => @project
|
43
|
+
}
|
44
|
+
body_object = { 'name' => name }
|
45
|
+
body_object.merge!(opts)
|
46
|
+
|
47
|
+
request(api_method, parameters, body_object)
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
class Mock
|
5
|
+
def insert_target_instance(target_instance, zone_name, opts = {})
|
6
|
+
id = Fog::Mock.random_numbers(19).to_s
|
7
|
+
self.data[:target_instances][target_instance] = {
|
8
|
+
"kind" => "compute#targetInstance",
|
9
|
+
"id" => id,
|
10
|
+
"creationTimestamp" => Time.now.iso8601,
|
11
|
+
"name" => target_instance,
|
12
|
+
"description" => '',
|
13
|
+
"natPolicy" => '',
|
14
|
+
"zone" => zone_name,
|
15
|
+
"instance" => opts['instance'],
|
16
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/targetInstances/#{target_instance}"
|
17
|
+
}
|
18
|
+
|
19
|
+
operation = self.random_operation
|
20
|
+
self.data[:operations][operation] = {
|
21
|
+
"kind" => "compute#operation",
|
22
|
+
"id" => Fog::Mock.random_numbers(19).to_s,
|
23
|
+
"name" => operation,
|
24
|
+
"zone" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}",
|
25
|
+
"operationType" => "insert",
|
26
|
+
"targetLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/targetInstances/#{target_instance}",
|
27
|
+
"targetId" => id,
|
28
|
+
"status" => Fog::Compute::Google::Operation::PENDING_STATE,
|
29
|
+
"user" => "123456789012-qwertyuiopasdfghjkl1234567890qwe@developer.gserviceaccount.com",
|
30
|
+
"progress" => 0,
|
31
|
+
"insertTime" => Time.now.iso8601,
|
32
|
+
"startTime" => Time.now.iso8601,
|
33
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/operations/#{operation}"
|
34
|
+
}
|
35
|
+
|
36
|
+
build_excon_response(self.data[:operations][operation])
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
class Real
|
41
|
+
def insert_target_instance(target_instance_name, zone_name, opts = {})
|
42
|
+
api_method = @compute.target_instances.insert
|
43
|
+
parameters = {
|
44
|
+
'project' => @project,
|
45
|
+
'zone' => zone_name,
|
46
|
+
}
|
47
|
+
body_object = { 'name' => target_pool_name }
|
48
|
+
body_object.merge!(opts)
|
49
|
+
|
50
|
+
request(api_method, parameters, body_object=body_object)
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
@@ -0,0 +1,58 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
class Mock
|
5
|
+
def insert_target_pool(name, region_name, opts = {})
|
6
|
+
# check that region exists
|
7
|
+
get_region(region_name)
|
8
|
+
|
9
|
+
id = Fog::Mock.random_numbers(19).to_s
|
10
|
+
self.data[:target_pools][name] = {
|
11
|
+
"kind" => "compute#targetPools",
|
12
|
+
"id" => id,
|
13
|
+
"creationTimestamp" => Time.now.iso8601,
|
14
|
+
"name" => name,
|
15
|
+
"description" => '',
|
16
|
+
"region" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/regions/#{region_name}",
|
17
|
+
"instances" => opts['instances'],
|
18
|
+
"healthChecks" => opts['healthChecks'],
|
19
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/regions/#{region_name}/targetPools/#{name}"
|
20
|
+
}
|
21
|
+
|
22
|
+
operation = self.random_operation
|
23
|
+
self.data[:operations][operation] = {
|
24
|
+
"kind" => "compute#operation",
|
25
|
+
"id" => Fog::Mock.random_numbers(19).to_s,
|
26
|
+
"name" => operation,
|
27
|
+
"region" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/regions/#{region_name}",
|
28
|
+
"operationType" => "insert",
|
29
|
+
"targetLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/regions/#{region_name}/targetPools/#{name}",
|
30
|
+
"targetId" => id,
|
31
|
+
"status" => Fog::Compute::Google::Operation::PENDING_STATE,
|
32
|
+
"user" => "123456789012-qwertyuiopasdfghjkl1234567890qwe@developer.gserviceaccount.com",
|
33
|
+
"progress" => 0,
|
34
|
+
"insertTime" => Time.now.iso8601,
|
35
|
+
"startTime" => Time.now.iso8601,
|
36
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/regions/#{region_name}/operations/#{operation}"
|
37
|
+
}
|
38
|
+
|
39
|
+
build_excon_response(self.data[:operations][operation])
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
class Real
|
44
|
+
def insert_target_pool(target_pool_name, region_name, opts = {})
|
45
|
+
api_method = @compute.target_pools.insert
|
46
|
+
parameters = {
|
47
|
+
'project' => @project,
|
48
|
+
'region' => region_name
|
49
|
+
}
|
50
|
+
body_object = { 'name' => target_pool_name }
|
51
|
+
body_object.merge!(opts)
|
52
|
+
|
53
|
+
request(api_method, parameters, body_object=body_object)
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
class Mock
|
5
|
+
def insert_url_map(url_map_name, opts)
|
6
|
+
id = Fog::Mock.random_numbers(19).to_s
|
7
|
+
self.data[:url_maps][url_map_name] = {
|
8
|
+
"kind" => "compute#urlMap",
|
9
|
+
"id" => id,
|
10
|
+
"creationTimestamp" => Time.now.iso8601,
|
11
|
+
"name" => url_map_name,
|
12
|
+
"description" => '',
|
13
|
+
"hostRules" => [],
|
14
|
+
"pathMatchers" => [],
|
15
|
+
"tests" => [],
|
16
|
+
"defaultService" => opts['defaultService'],
|
17
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/global/urlMaps/#{url_map_name}"
|
18
|
+
}
|
19
|
+
|
20
|
+
operation = self.random_operation
|
21
|
+
self.data[:operations][operation] = {
|
22
|
+
"kind" => "compute#operation",
|
23
|
+
"id" => Fog::Mock.random_numbers(19).to_s,
|
24
|
+
"name" => operation,
|
25
|
+
"zone" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/global",
|
26
|
+
"operationType" => "insert",
|
27
|
+
"targetLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/global/urlMaps/#{url_map_name}",
|
28
|
+
"targetId" => id,
|
29
|
+
"status" => Fog::Compute::Google::Operation::PENDING_STATE,
|
30
|
+
"user" => "123456789012-qwertyuiopasdfghjkl1234567890qwe@developer.gserviceaccount.com",
|
31
|
+
"progress" => 0,
|
32
|
+
"insertTime" => Time.now.iso8601,
|
33
|
+
"startTime" => Time.now.iso8601,
|
34
|
+
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/global/operations/#{operation}"
|
35
|
+
}
|
36
|
+
|
37
|
+
build_excon_response(self.data[:operations][operation])
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
class Real
|
42
|
+
def insert_url_map(url_map_name, opts = {})
|
43
|
+
api_method = @compute.url_maps.insert
|
44
|
+
parameters = {
|
45
|
+
'project' => @project,
|
46
|
+
}
|
47
|
+
body_object = { 'name' => url_map_name }
|
48
|
+
body_object.merge!(opts)
|
49
|
+
|
50
|
+
request(api_method, parameters, body_object=body_object)
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|