fog 0.9.0 → 0.10.0
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +7 -4
- data/bin/fog +4 -1
- data/changelog.txt +464 -0
- data/docs/index.markdown +2 -2
- data/fog.gemspec +11 -11
- data/lib/fog.rb +1 -1
- data/lib/fog/aws/auto_scaling.rb +221 -0
- data/lib/fog/aws/cloud_formation.rb +1 -1
- data/lib/fog/aws/cloud_watch.rb +110 -0
- data/lib/fog/aws/elb.rb +58 -26
- data/lib/fog/aws/iam.rb +65 -13
- data/lib/fog/aws/models/auto_scaling/activities.rb +30 -0
- data/lib/fog/aws/models/auto_scaling/activity.rb +29 -0
- data/lib/fog/aws/models/auto_scaling/configuration.rb +63 -0
- data/lib/fog/aws/models/auto_scaling/configurations.rb +35 -0
- data/lib/fog/aws/models/auto_scaling/group.rb +140 -0
- data/lib/fog/aws/models/auto_scaling/groups.rb +35 -0
- data/lib/fog/aws/models/auto_scaling/instance.rb +60 -0
- data/lib/fog/aws/models/auto_scaling/instances.rb +30 -0
- data/lib/fog/aws/models/cloud_watch/metric.rb +14 -0
- data/lib/fog/aws/models/cloud_watch/metric_statistic.rb +46 -0
- data/lib/fog/aws/models/cloud_watch/metric_statistics.rb +23 -0
- data/lib/fog/aws/models/cloud_watch/metrics.rb +32 -0
- data/lib/fog/aws/models/elb/listener.rb +6 -0
- data/lib/fog/aws/models/elb/listeners.rb +2 -2
- data/lib/fog/aws/models/elb/load_balancer.rb +8 -5
- data/lib/fog/aws/models/rds/server.rb +3 -1
- data/lib/fog/aws/parsers/auto_scaling/basic.rb +28 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_adjustment_types.rb +39 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_auto_scaling_groups.rb +126 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_auto_scaling_instances.rb +43 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_launch_configurations.rb +94 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_metric_collection_types.rb +66 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_policies.rb +66 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_scaling_activities.rb +47 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_scaling_process_types.rb +39 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_scheduled_actions.rb +46 -0
- data/lib/fog/aws/parsers/auto_scaling/put_scaling_policy.rb +30 -0
- data/lib/fog/aws/parsers/auto_scaling/terminate_instance_in_auto_scaling_group.rb +35 -0
- data/lib/fog/aws/parsers/cloud_watch/get_metric_statistics.rb +42 -0
- data/lib/fog/aws/parsers/cloud_watch/list_metrics.rb +58 -0
- data/lib/fog/aws/parsers/cloud_watch/put_metric_data.rb +26 -0
- data/lib/fog/aws/parsers/elb/describe_load_balancers.rb +1 -1
- data/lib/fog/aws/parsers/iam/get_group_policy.rb +27 -0
- data/lib/fog/aws/parsers/iam/list_account_aliases.rb +28 -0
- data/lib/fog/aws/parsers/rds/db_engine_version_parser.rb +35 -0
- data/lib/fog/aws/parsers/rds/db_parser.rb +1 -1
- data/lib/fog/aws/parsers/rds/describe_db_engine_versions.rb +39 -0
- data/lib/fog/aws/parsers/rds/describe_db_reserved_instances.rb +43 -0
- data/lib/fog/aws/parsers/sns/add_permission.rb +24 -0
- data/lib/fog/aws/parsers/sns/confirm_subscription.rb +24 -0
- data/lib/fog/aws/parsers/sns/create_topic.rb +24 -0
- data/lib/fog/aws/parsers/sns/delete_topic.rb +24 -0
- data/lib/fog/aws/parsers/sns/get_topic_attributes.rb +32 -0
- data/lib/fog/aws/parsers/sns/list_subscriptions.rb +29 -0
- data/lib/fog/aws/parsers/sns/list_topics.rb +26 -0
- data/lib/fog/aws/parsers/sns/publish.rb +24 -0
- data/lib/fog/aws/parsers/sns/remove_permission.rb +24 -0
- data/lib/fog/aws/parsers/sns/set_topic_attributes.rb +24 -0
- data/lib/fog/aws/parsers/sns/subscribe.rb +24 -0
- data/lib/fog/aws/parsers/sns/unsubscribe.rb +24 -0
- data/lib/fog/aws/parsers/sqs/basic.rb +23 -0
- data/lib/fog/aws/parsers/sqs/create_queue.rb +26 -0
- data/lib/fog/aws/parsers/sqs/get_queue_attributes.rb +35 -0
- data/lib/fog/aws/parsers/sqs/list_queues.rb +25 -0
- data/lib/fog/aws/parsers/sqs/receive_message.rb +41 -0
- data/lib/fog/aws/parsers/sqs/send_message.rb +28 -0
- data/lib/fog/aws/rds.rb +3 -1
- data/lib/fog/aws/requests/auto_scaling/create_auto_scaling_group.rb +108 -0
- data/lib/fog/aws/requests/auto_scaling/create_launch_configuration.rb +105 -0
- data/lib/fog/aws/requests/auto_scaling/delete_auto_scaling_group.rb +45 -0
- data/lib/fog/aws/requests/auto_scaling/delete_launch_configuration.rb +48 -0
- data/lib/fog/aws/requests/auto_scaling/delete_policy.rb +47 -0
- data/lib/fog/aws/requests/auto_scaling/delete_scheduled_action.rb +48 -0
- data/lib/fog/aws/requests/auto_scaling/describe_adjustment_types.rb +52 -0
- data/lib/fog/aws/requests/auto_scaling/describe_auto_scaling_groups.rb +128 -0
- data/lib/fog/aws/requests/auto_scaling/describe_auto_scaling_instances.rb +96 -0
- data/lib/fog/aws/requests/auto_scaling/describe_launch_configurations.rb +108 -0
- data/lib/fog/aws/requests/auto_scaling/describe_metric_collection_types.rb +60 -0
- data/lib/fog/aws/requests/auto_scaling/describe_policies.rb +85 -0
- data/lib/fog/aws/requests/auto_scaling/describe_scaling_activities.rb +88 -0
- data/lib/fog/aws/requests/auto_scaling/describe_scaling_process_types.rb +54 -0
- data/lib/fog/aws/requests/auto_scaling/describe_scheduled_actions.rb +83 -0
- data/lib/fog/aws/requests/auto_scaling/disable_metrics_collection.rb +56 -0
- data/lib/fog/aws/requests/auto_scaling/enable_metrics_collection.rb +66 -0
- data/lib/fog/aws/requests/auto_scaling/execute_policy.rb +50 -0
- data/lib/fog/aws/requests/auto_scaling/put_scaling_policy.rb +66 -0
- data/lib/fog/aws/requests/auto_scaling/put_scheduled_update_group_action.rb +57 -0
- data/lib/fog/aws/requests/auto_scaling/resume_processes.rb +50 -0
- data/lib/fog/aws/requests/auto_scaling/set_desired_capacity.rb +87 -0
- data/lib/fog/aws/requests/auto_scaling/set_instance_health.rb +55 -0
- data/lib/fog/aws/requests/auto_scaling/suspend_processes.rb +57 -0
- data/lib/fog/aws/requests/auto_scaling/terminate_instance_in_auto_scaling_group.rb +65 -0
- data/lib/fog/aws/requests/auto_scaling/update_auto_scaling_group.rb +79 -0
- data/lib/fog/aws/requests/cloud_watch/get_metric_statistics.rb +48 -0
- data/lib/fog/aws/requests/cloud_watch/list_metrics.rb +38 -0
- data/lib/fog/aws/requests/cloud_watch/put_metric_data.rb +73 -0
- data/lib/fog/aws/requests/elb/configure_health_check.rb +24 -0
- data/lib/fog/aws/requests/elb/create_app_cookie_stickiness_policy.rb +21 -0
- data/lib/fog/aws/requests/elb/create_lb_cookie_stickiness_policy.rb +21 -0
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +55 -0
- data/lib/fog/aws/requests/elb/create_load_balancer_listeners.rb +28 -0
- data/lib/fog/aws/requests/elb/delete_load_balancer.rb +18 -0
- data/lib/fog/aws/requests/elb/delete_load_balancer_listeners.rb +20 -1
- data/lib/fog/aws/requests/elb/delete_load_balancer_policy.rb +23 -0
- data/lib/fog/aws/requests/elb/deregister_instances_from_load_balancer.rb +21 -5
- data/lib/fog/aws/requests/elb/describe_instance_health.rb +35 -0
- data/lib/fog/aws/requests/elb/describe_load_balancers.rb +29 -0
- data/lib/fog/aws/requests/elb/disable_availability_zones_for_load_balancer.rb +18 -5
- data/lib/fog/aws/requests/elb/enable_availability_zones_for_load_balancer.rb +18 -3
- data/lib/fog/aws/requests/elb/register_instances_with_load_balancer.rb +22 -5
- data/lib/fog/aws/requests/elb/set_load_balancer_listener_ssl_certificate.rb +40 -0
- data/lib/fog/aws/requests/elb/set_load_balancer_policies_of_listener.rb +37 -0
- data/lib/fog/aws/requests/iam/create_account_alias.rb +19 -0
- data/lib/fog/aws/requests/iam/delete_account_alias.rb +19 -0
- data/lib/fog/aws/requests/iam/delete_server_certificate.rb +14 -0
- data/lib/fog/aws/requests/iam/get_group_policy.rb +36 -0
- data/lib/fog/aws/requests/iam/get_server_certificate.rb +50 -0
- data/lib/fog/aws/requests/iam/list_account_aliases.rb +18 -0
- data/lib/fog/aws/requests/iam/list_server_certificates.rb +12 -0
- data/lib/fog/aws/requests/iam/put_group_policy.rb +1 -1
- data/lib/fog/aws/requests/iam/put_user_policy.rb +1 -1
- data/lib/fog/aws/requests/iam/upload_server_certificate.rb +53 -5
- data/lib/fog/aws/requests/rds/describe_db_engine_versions.rb +34 -0
- data/lib/fog/aws/requests/rds/describe_db_reserved_instances.rb +42 -0
- data/lib/fog/aws/requests/simpledb/get_attributes.rb +29 -17
- data/lib/fog/aws/requests/simpledb/select.rb +11 -3
- data/lib/fog/aws/requests/sns/add_permission.rb +26 -0
- data/lib/fog/aws/requests/sns/confirm_subscription.rb +33 -0
- data/lib/fog/aws/requests/sns/create_topic.rb +29 -0
- data/lib/fog/aws/requests/sns/delete_topic.rb +29 -0
- data/lib/fog/aws/requests/sns/get_topic_attributes.rb +29 -0
- data/lib/fog/aws/requests/sns/list_subscriptions.rb +29 -0
- data/lib/fog/aws/requests/sns/list_subscriptions_by_topic.rb +31 -0
- data/lib/fog/aws/requests/sns/list_topics.rb +29 -0
- data/lib/fog/aws/requests/sns/publish.rb +34 -0
- data/lib/fog/aws/requests/sns/remove_permission.rb +26 -0
- data/lib/fog/aws/requests/sns/set_topic_attributes.rb +33 -0
- data/lib/fog/aws/requests/sns/subscribe.rb +33 -0
- data/lib/fog/aws/requests/sns/unsubscribe.rb +29 -0
- data/lib/fog/aws/requests/sqs/change_message_visibility.rb +33 -0
- data/lib/fog/aws/requests/sqs/create_queue.rb +31 -0
- data/lib/fog/aws/requests/sqs/delete_message.rb +31 -0
- data/lib/fog/aws/requests/sqs/delete_queue.rb +29 -0
- data/lib/fog/aws/requests/sqs/get_queue_attributes.rb +31 -0
- data/lib/fog/aws/requests/sqs/list_queues.rb +28 -0
- data/lib/fog/aws/requests/sqs/receive_message.rb +34 -0
- data/lib/fog/aws/requests/sqs/send_message.rb +31 -0
- data/lib/fog/aws/requests/sqs/set_queue_attributes.rb +33 -0
- data/lib/fog/aws/sns.rb +112 -0
- data/lib/fog/aws/sqs.rb +115 -0
- data/lib/fog/bin.rb +1 -0
- data/lib/fog/bin/aws.rb +16 -0
- data/lib/fog/bin/brightbox.rb +1 -1
- data/lib/fog/bin/ninefold.rb +5 -0
- data/lib/fog/bin/vcloud.rb +30 -0
- data/lib/fog/bin/virtual_box.rb +5 -1
- data/lib/fog/cdn/rackspace.rb +16 -8
- data/lib/fog/compute.rb +4 -1
- data/lib/fog/compute/aws.rb +16 -4
- data/lib/fog/compute/bluebox.rb +2 -2
- data/lib/fog/compute/brightbox.rb +4 -4
- data/lib/fog/compute/go_grid.rb +2 -2
- data/lib/fog/compute/linode.rb +2 -2
- data/lib/fog/compute/models/aws/server.rb +17 -3
- data/lib/fog/compute/models/aws/spot_request.rb +93 -0
- data/lib/fog/compute/models/aws/spot_requests.rb +48 -0
- data/lib/fog/compute/models/aws/volume.rb +13 -13
- data/lib/fog/compute/models/bluebox/server.rb +4 -4
- data/lib/fog/compute/models/go_grid/server.rb +2 -2
- data/lib/fog/compute/models/ninefold/server.rb +18 -14
- data/lib/fog/compute/models/rackspace/flavor.rb +3 -2
- data/lib/fog/compute/models/rackspace/server.rb +2 -2
- data/lib/fog/compute/models/slicehost/server.rb +1 -1
- data/lib/fog/compute/models/vcloud/catalog.rb +22 -0
- data/lib/fog/compute/models/vcloud/catalog_item.rb +29 -0
- data/lib/fog/compute/models/vcloud/catalog_items.rb +32 -0
- data/lib/fog/compute/models/vcloud/catalogs.rb +39 -0
- data/lib/fog/compute/models/vcloud/ip.rb +42 -0
- data/lib/fog/compute/models/vcloud/ips.rb +33 -0
- data/lib/fog/compute/models/vcloud/network.rb +65 -0
- data/lib/fog/compute/models/vcloud/networks.rb +34 -0
- data/lib/fog/compute/models/vcloud/server.rb +291 -0
- data/lib/fog/compute/models/vcloud/servers.rb +58 -0
- data/lib/fog/compute/models/vcloud/task.rb +21 -0
- data/lib/fog/compute/models/vcloud/tasks.rb +32 -0
- data/lib/fog/compute/models/vcloud/vdc.rb +56 -0
- data/lib/fog/compute/models/vcloud/vdcs.rb +40 -0
- data/lib/fog/compute/models/virtual_box/server.rb +2 -2
- data/lib/fog/compute/ninefold.rb +3 -3
- data/lib/fog/compute/parsers/aws/cancel_spot_instance_requests.rb +30 -0
- data/lib/fog/compute/parsers/aws/describe_instances.rb +9 -4
- data/lib/fog/compute/parsers/aws/describe_placement_groups.rb +30 -0
- data/lib/fog/compute/parsers/aws/describe_reserved_instances.rb +1 -1
- data/lib/fog/compute/parsers/aws/describe_reserved_instances_offerings.rb +2 -2
- data/lib/fog/compute/parsers/aws/describe_spot_price_history.rb +34 -0
- data/lib/fog/compute/parsers/aws/purchase_reserved_instances_offering.rb +24 -0
- data/lib/fog/compute/parsers/aws/run_instances.rb +17 -16
- data/lib/fog/compute/parsers/aws/spot_datafeed_subscription.rb +29 -0
- data/lib/fog/compute/parsers/aws/spot_instance_requests.rb +67 -0
- data/lib/fog/compute/rackspace.rb +6 -5
- data/lib/fog/compute/requests/aws/cancel_spot_instance_requests.rb +34 -0
- data/lib/fog/compute/requests/aws/create_placement_group.rb +34 -0
- data/lib/fog/compute/requests/aws/create_spot_datafeed_subscription.rb +41 -0
- data/lib/fog/compute/requests/aws/delete_placement_group.rb +32 -0
- data/lib/fog/compute/requests/aws/delete_spot_datafeed_subscription.rb +28 -0
- data/lib/fog/compute/requests/aws/describe_placement_groups.rb +35 -0
- data/lib/fog/compute/requests/aws/describe_reserved_instances.rb +14 -0
- data/lib/fog/compute/requests/aws/describe_reserved_instances_offerings.rb +25 -0
- data/lib/fog/compute/requests/aws/describe_spot_datafeed_subscription.rb +35 -0
- data/lib/fog/compute/requests/aws/describe_spot_instance_requests.rb +47 -0
- data/lib/fog/compute/requests/aws/describe_spot_price_history.rb +37 -0
- data/lib/fog/compute/requests/aws/describe_volumes.rb +1 -1
- data/lib/fog/compute/requests/aws/purchase_reserved_instances_offering.rb +63 -0
- data/lib/fog/compute/requests/aws/request_spot_instances.rb +83 -0
- data/lib/fog/compute/requests/aws/run_instances.rb +2 -3
- data/lib/fog/compute/requests/brightbox/activate_console_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/add_listeners_load_balancer.rb +1 -1
- data/lib/fog/compute/requests/brightbox/add_nodes_load_balancer.rb +1 -1
- data/lib/fog/compute/requests/brightbox/create_api_client.rb +1 -1
- data/lib/fog/compute/requests/brightbox/create_cloud_ip.rb +1 -1
- data/lib/fog/compute/requests/brightbox/create_image.rb +1 -1
- data/lib/fog/compute/requests/brightbox/create_load_balancer.rb +1 -1
- data/lib/fog/compute/requests/brightbox/create_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/destroy_api_client.rb +1 -1
- data/lib/fog/compute/requests/brightbox/destroy_cloud_ip.rb +1 -1
- data/lib/fog/compute/requests/brightbox/destroy_image.rb +1 -1
- data/lib/fog/compute/requests/brightbox/destroy_load_balancer.rb +1 -1
- data/lib/fog/compute/requests/brightbox/destroy_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_account.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_api_client.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_cloud_ip.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_image.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_interface.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_load_balancer.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_server_type.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_user.rb +1 -1
- data/lib/fog/compute/requests/brightbox/get_zone.rb +1 -1
- data/lib/fog/compute/requests/brightbox/list_api_clients.rb +1 -1
- data/lib/fog/compute/requests/brightbox/list_cloud_ips.rb +1 -1
- data/lib/fog/compute/requests/brightbox/list_images.rb +1 -1
- data/lib/fog/compute/requests/brightbox/list_load_balancers.rb +1 -1
- data/lib/fog/compute/requests/brightbox/list_server_types.rb +1 -1
- data/lib/fog/compute/requests/brightbox/list_servers.rb +1 -1
- data/lib/fog/compute/requests/brightbox/list_users.rb +1 -1
- data/lib/fog/compute/requests/brightbox/list_zones.rb +1 -1
- data/lib/fog/compute/requests/brightbox/map_cloud_ip.rb +1 -1
- data/lib/fog/compute/requests/brightbox/remove_listeners_load_balancer.rb +1 -1
- data/lib/fog/compute/requests/brightbox/remove_nodes_load_balancer.rb +1 -1
- data/lib/fog/compute/requests/brightbox/reset_ftp_password_account.rb +1 -1
- data/lib/fog/compute/requests/brightbox/resize_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/shutdown_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/snapshot_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/start_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/stop_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/unmap_cloud_ip.rb +1 -1
- data/lib/fog/compute/requests/brightbox/update_account.rb +1 -1
- data/lib/fog/compute/requests/brightbox/update_api_client.rb +1 -1
- data/lib/fog/compute/requests/brightbox/update_image.rb +1 -1
- data/lib/fog/compute/requests/brightbox/update_load_balancer.rb +1 -1
- data/lib/fog/compute/requests/brightbox/update_server.rb +1 -1
- data/lib/fog/compute/requests/brightbox/update_user.rb +1 -1
- data/lib/fog/compute/requests/linode/linode_disk_createfromstackscript.rb +1 -1
- data/lib/fog/compute/requests/rackspace/create_image.rb +1 -1
- data/lib/fog/compute/requests/rackspace/create_server.rb +1 -1
- data/lib/fog/compute/requests/rackspace/server_action.rb +2 -2
- data/lib/fog/compute/requests/rackspace/update_server.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/add_balancer_node.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/clone_server.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/create_server.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/delete_server.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/get_server.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/get_stats.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/list_balancers.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/list_configs.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/list_images.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/list_private_ips.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/list_servers.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/list_templates.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/reboot_server.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/remove_balancer_node.rb +1 -1
- data/lib/fog/compute/requests/storm_on_demand/resize_server.rb +1 -1
- data/lib/fog/compute/requests/vcloud/clone_vapp.rb +40 -0
- data/lib/fog/compute/requests/vcloud/configure_network.rb +43 -0
- data/lib/fog/compute/requests/vcloud/configure_network_ip.rb +46 -0
- data/lib/fog/compute/requests/vcloud/configure_node.rb +38 -0
- data/lib/fog/compute/requests/vcloud/configure_vapp.rb +112 -0
- data/lib/fog/compute/requests/vcloud/configure_vm.rb +247 -0
- data/lib/fog/compute/requests/vcloud/configure_vm_disks.rb +100 -0
- data/lib/fog/compute/requests/vcloud/configure_vm_memory.rb +40 -0
- data/lib/fog/compute/requests/vcloud/configure_vm_name_description.rb +30 -0
- data/lib/fog/compute/requests/vcloud/delete_node.rb +10 -0
- data/lib/fog/compute/requests/vcloud/delete_vapp.rb +10 -0
- data/lib/fog/compute/requests/vcloud/get_catalog.rb +10 -0
- data/lib/fog/compute/requests/vcloud/get_catalog_item.rb +10 -0
- data/lib/fog/compute/requests/vcloud/get_customization_options.rb +10 -0
- data/lib/fog/compute/requests/vcloud/get_network.rb +10 -0
- data/lib/fog/compute/requests/vcloud/get_network_extensions.rb +11 -0
- data/lib/fog/compute/requests/vcloud/get_network_ip.rb +15 -0
- data/lib/fog/compute/requests/vcloud/get_network_ips.rb +15 -0
- data/lib/fog/compute/requests/vcloud/get_organization.rb +11 -0
- data/lib/fog/compute/requests/vcloud/get_task.rb +11 -0
- data/lib/fog/compute/requests/vcloud/get_task_list.rb +11 -0
- data/lib/fog/compute/requests/vcloud/get_vapp.rb +10 -0
- data/lib/fog/compute/requests/vcloud/get_vapp_template.rb +11 -0
- data/lib/fog/compute/requests/vcloud/get_vdc.rb +10 -0
- data/lib/fog/compute/requests/vcloud/get_vm_disks.rb +16 -0
- data/lib/fog/compute/requests/vcloud/get_vm_memory.rb +16 -0
- data/lib/fog/compute/requests/vcloud/instantiate_vapp_template.rb +83 -0
- data/lib/fog/compute/requests/vcloud/login.rb +23 -0
- data/lib/fog/compute/requests/vcloud/power_off.rb +10 -0
- data/lib/fog/compute/requests/vcloud/power_on.rb +11 -0
- data/lib/fog/compute/requests/vcloud/power_reset.rb +11 -0
- data/lib/fog/compute/requests/vcloud/power_shutdown.rb +11 -0
- data/lib/fog/compute/requests/vcloud/undeploy.rb +23 -0
- data/lib/fog/compute/storm_on_demand.rb +2 -2
- data/lib/fog/compute/vcloud.rb +310 -0
- data/lib/fog/core.rb +2 -1
- data/lib/fog/core/attributes.rb +23 -11
- data/lib/fog/core/collection.rb +7 -7
- data/lib/fog/core/credentials.rb +4 -2
- data/lib/fog/core/model.rb +4 -4
- data/lib/fog/core/time.rb +1 -2
- data/lib/fog/core/timeout.rb +11 -0
- data/lib/fog/core/wait_for.rb +2 -2
- data/lib/fog/dns/dnsimple.rb +2 -2
- data/lib/fog/dns/dnsmadeeasy.rb +2 -2
- data/lib/fog/dns/linode.rb +2 -2
- data/lib/fog/dns/requests/dnsimple/create_domain.rb +1 -1
- data/lib/fog/dns/requests/dnsimple/create_record.rb +1 -1
- data/lib/fog/dns/requests/dnsimple/update_record.rb +1 -1
- data/lib/fog/dns/requests/dnsmadeeasy/create_record.rb +1 -1
- data/lib/fog/dns/requests/dnsmadeeasy/create_secondary.rb +1 -1
- data/lib/fog/dns/requests/dnsmadeeasy/update_record.rb +1 -1
- data/lib/fog/dns/requests/dnsmadeeasy/update_secondary.rb +1 -1
- data/lib/fog/providers.rb +1 -0
- data/lib/fog/providers/aws.rb +15 -2
- data/lib/fog/providers/ninefold.rb +1 -0
- data/lib/fog/providers/rackspace.rb +4 -3
- data/lib/fog/providers/vcloud.rb +11 -0
- data/lib/fog/storage.rb +9 -6
- data/lib/fog/storage/aws.rb +18 -1
- data/lib/fog/storage/google.rb +19 -1
- data/lib/fog/storage/models/aws/file.rb +3 -3
- data/lib/fog/storage/models/aws/files.rb +9 -2
- data/lib/fog/storage/models/google/files.rb +9 -2
- data/lib/fog/storage/models/ninefold/directories.rb +48 -0
- data/lib/fog/storage/models/ninefold/directory.rb +53 -0
- data/lib/fog/storage/models/ninefold/file.rb +99 -0
- data/lib/fog/storage/models/ninefold/files.rb +72 -0
- data/lib/fog/storage/models/rackspace/directory.rb +7 -2
- data/lib/fog/storage/ninefold.rb +149 -0
- data/lib/fog/storage/rackspace.rb +8 -2
- data/lib/fog/storage/requests/aws/get_bucket_policy.rb +1 -1
- data/lib/fog/storage/requests/aws/get_object.rb +6 -2
- data/lib/fog/storage/requests/aws/get_object_http_url.rb +51 -0
- data/lib/fog/storage/requests/aws/get_object_https_url.rb +51 -0
- data/lib/fog/storage/requests/aws/get_object_url.rb +4 -24
- data/lib/fog/storage/requests/aws/post_object_hidden_fields.rb +1 -1
- data/lib/fog/storage/requests/aws/put_bucket_policy.rb +1 -1
- data/lib/fog/storage/requests/google/get_object_http_url.rb +51 -0
- data/lib/fog/storage/requests/google/get_object_https_url.rb +51 -0
- data/lib/fog/storage/requests/google/get_object_url.rb +8 -25
- data/lib/fog/storage/requests/ninefold/delete_namespace.rb +19 -0
- data/lib/fog/storage/requests/ninefold/get_namespace.rb +20 -0
- data/lib/fog/storage/requests/ninefold/post_namespace.rb +20 -0
- data/lib/fog/storage/requests/ninefold/put_namespace.rb +20 -0
- data/lib/fog/storage/requests/rackspace/put_object.rb +3 -0
- data/lib/fog/storage/requests/rackspace/put_object_manifest.rb +25 -0
- data/tests/aws/models/auto_scaling/activities_tests.rb +6 -0
- data/tests/aws/models/auto_scaling/configuration_test.rb +13 -0
- data/tests/aws/models/auto_scaling/configurations_tests.rb +11 -0
- data/tests/aws/models/auto_scaling/helper.rb +0 -0
- data/tests/aws/models/auto_scaling/instances_tests.rb +6 -0
- data/tests/aws/models/cloud_watch/metric_statistics_tests.rb +51 -0
- data/tests/aws/models/cloud_watch/metrics_tests.rb +17 -0
- data/tests/aws/{requests → models}/elb/model_tests.rb +82 -18
- data/tests/aws/models/rds/security_group_tests.rb +1 -1
- data/tests/aws/requests/auto_scaling/auto_scaling_tests.rb +80 -0
- data/tests/aws/requests/auto_scaling/helper.rb +185 -0
- data/tests/aws/requests/auto_scaling/model_tests.rb +235 -0
- data/tests/aws/requests/cloud_formation/stack_tests.rb +1 -1
- data/tests/aws/requests/cloud_watch/get_metric_statistics_tests.rb +28 -0
- data/tests/aws/requests/cloud_watch/list_metrics_test.rb +64 -0
- data/tests/aws/requests/cloud_watch/put_metric_data_tests.rb +36 -0
- data/tests/aws/requests/elb/listener_tests.rb +50 -0
- data/tests/aws/requests/elb/load_balancer_tests.rb +23 -44
- data/tests/aws/requests/elb/policy_tests.rb +41 -0
- data/tests/aws/requests/iam/helper.rb +29 -0
- data/tests/aws/requests/iam/login_profile_tests.rb +2 -2
- data/tests/aws/requests/iam/server_certificate_tests.rb +39 -6
- data/tests/aws/requests/rds/helper.rb +1 -0
- data/tests/aws/requests/simpledb/attributes_tests.rb +10 -15
- data/tests/aws/requests/sns/helper.rb +9 -0
- data/tests/aws/requests/sns/subscription_tests.rb +86 -0
- data/tests/aws/requests/sns/topic_tests.rb +50 -0
- data/tests/aws/requests/sqs/helper.rb +15 -0
- data/tests/aws/requests/sqs/message_tests.rb +57 -0
- data/tests/aws/requests/sqs/queue_tests.rb +55 -0
- data/tests/aws/signed_params_tests.rb +3 -1
- data/tests/compute/models/aws/volume_tests.rb +13 -0
- data/tests/compute/models/vcloud/helper.rb +25 -0
- data/tests/compute/models/vcloud/servers_tests.rb +95 -0
- data/tests/compute/requests/aws/address_tests.rb +1 -1
- data/tests/compute/requests/aws/instance_tests.rb +65 -4
- data/tests/compute/requests/aws/placement_group_tests.rb +48 -0
- data/tests/compute/requests/aws/spot_datafeed_subscription_tests.rb +47 -0
- data/tests/compute/requests/aws/spot_instance_tests.rb +53 -0
- data/tests/compute/requests/aws/spot_price_history_tests.rb +24 -0
- data/tests/compute/requests/aws/volume_tests.rb +4 -0
- data/tests/compute/requests/brightbox/helper.rb +2 -1
- data/tests/compute/requests/brightbox/interface_tests.rb +4 -4
- data/tests/compute/requests/ninefold/helper.rb +1 -1
- data/tests/compute/requests/vcloud/disk_configure_tests.rb +114 -0
- data/tests/compute/requests/voxel/server_tests.rb +2 -2
- data/tests/core/attribute_tests.rb +10 -1
- data/tests/core/credential_tests.rb +6 -0
- data/tests/core/timeout_tests.rb +10 -0
- data/tests/helpers/collection_helper.rb +4 -1
- data/tests/helpers/formats_helper.rb +1 -1
- data/tests/helpers/mock_helper.rb +5 -0
- data/tests/storage/helper.rb +4 -1
- data/tests/storage/models/ninefold/file_update_tests.rb +19 -0
- data/tests/storage/models/ninefold/nested_directories_tests.rb +23 -0
- data/tests/storage/requests/aws/multipart_upload_tests.rb +2 -5
- data/tests/storage/requests/rackspace/large_object_tests.rb +47 -0
- metadata +366 -105
@@ -28,6 +28,27 @@ module Fog
|
|
28
28
|
end
|
29
29
|
|
30
30
|
end
|
31
|
+
|
32
|
+
class Mock
|
33
|
+
def create_app_cookie_stickiness_policy(lb_name, policy_name, cookie_name)
|
34
|
+
if load_balancer = self.data[:load_balancers][lb_name]
|
35
|
+
response = Excon::Response.new
|
36
|
+
response.status = 200
|
37
|
+
|
38
|
+
load_balancer['Policies']['AppCookieStickinessPolicies'] << { 'CookieName' => cookie_name, 'PolicyName' => policy_name }
|
39
|
+
|
40
|
+
response.body = {
|
41
|
+
'ResponseMetadata' => {
|
42
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
43
|
+
}
|
44
|
+
}
|
45
|
+
|
46
|
+
response
|
47
|
+
else
|
48
|
+
raise Fog::AWS::ELB::NotFound
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
31
52
|
end
|
32
53
|
end
|
33
54
|
end
|
@@ -30,6 +30,27 @@ module Fog
|
|
30
30
|
end
|
31
31
|
|
32
32
|
end
|
33
|
+
|
34
|
+
class Mock
|
35
|
+
def create_lb_cookie_stickiness_policy(lb_name, policy_name, cookie_expiration_period=nil)
|
36
|
+
if load_balancer = self.data[:load_balancers][lb_name]
|
37
|
+
response = Excon::Response.new
|
38
|
+
response.status = 200
|
39
|
+
|
40
|
+
load_balancer['Policies']['LBCookieStickinessPolicies'] << { 'PolicyName' => policy_name, 'CookieExpirationPeriod' => cookie_expiration_period }
|
41
|
+
|
42
|
+
response.body = {
|
43
|
+
'ResponseMetadata' => {
|
44
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
45
|
+
}
|
46
|
+
}
|
47
|
+
|
48
|
+
response
|
49
|
+
else
|
50
|
+
raise Fog::AWS::ELB::NotFound
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
33
54
|
end
|
34
55
|
end
|
35
56
|
end
|
@@ -47,7 +47,62 @@ module Fog
|
|
47
47
|
:parser => Fog::Parsers::AWS::ELB::CreateLoadBalancer.new
|
48
48
|
}.merge!(params))
|
49
49
|
end
|
50
|
+
end
|
51
|
+
|
52
|
+
class Mock
|
53
|
+
def create_load_balancer(availability_zones, lb_name, listeners = [])
|
54
|
+
response = Excon::Response.new
|
55
|
+
response.status = 200
|
56
|
+
|
57
|
+
raise Fog::AWS::ELB::IdentifierTaken if self.data[:load_balancers].has_key? lb_name
|
58
|
+
|
59
|
+
certificate_ids = Fog::AWS::IAM.new.list_server_certificates.body['Certificates'].collect { |c| c['Arn'] }
|
60
|
+
|
61
|
+
listeners = [*listeners].map do |listener|
|
62
|
+
if listener['SSLCertificateId'] and !certificate_ids.include? listener['SSLCertificateId']
|
63
|
+
raise Fog::AWS::IAM::NotFound.new('CertificateNotFound')
|
64
|
+
end
|
65
|
+
{'Listener' => listener, 'PolicyNames' => []}
|
66
|
+
end
|
67
|
+
|
68
|
+
dns_name = Fog::AWS::ELB::Mock.dns_name(lb_name, @region)
|
69
|
+
self.data[:load_balancers][lb_name] = {
|
70
|
+
'AvailabilityZones' => availability_zones,
|
71
|
+
'CanonicalHostedZoneName' => '',
|
72
|
+
'CanonicalHostedZoneNameID' => '',
|
73
|
+
'CreatedTime' => Time.now,
|
74
|
+
'DNSName' => dns_name,
|
75
|
+
'HealthCheck' => {
|
76
|
+
'HealthyThreshold' => 10,
|
77
|
+
'Timeout' => 5,
|
78
|
+
'UnhealthyThreshold' => 2,
|
79
|
+
'Interval' => 30,
|
80
|
+
'Target' => 'TCP:80'
|
81
|
+
},
|
82
|
+
'Instances' => [],
|
83
|
+
'ListenerDescriptions' => listeners,
|
84
|
+
'LoadBalancerName' => lb_name,
|
85
|
+
'Policies' => {
|
86
|
+
'LBCookieStickinessPolicies' => [],
|
87
|
+
'AppCookieStickinessPolicies' => []
|
88
|
+
},
|
89
|
+
'SourceSecurityGroup' => {
|
90
|
+
'GroupName' => '',
|
91
|
+
'OwnerAlias' => ''
|
92
|
+
}
|
93
|
+
}
|
50
94
|
|
95
|
+
response.body = {
|
96
|
+
'ResponseMetadata' => {
|
97
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
98
|
+
},
|
99
|
+
'CreateLoadBalancerResult' => {
|
100
|
+
'DNSName' => dns_name
|
101
|
+
}
|
102
|
+
}
|
103
|
+
|
104
|
+
response
|
105
|
+
end
|
51
106
|
end
|
52
107
|
end
|
53
108
|
end
|
@@ -46,6 +46,34 @@ module Fog
|
|
46
46
|
end
|
47
47
|
|
48
48
|
end
|
49
|
+
|
50
|
+
class Mock
|
51
|
+
def create_load_balancer_listeners(lb_name, listeners)
|
52
|
+
if load_balancer = self.data[:load_balancers][lb_name]
|
53
|
+
response = Excon::Response.new
|
54
|
+
|
55
|
+
certificate_ids = Fog::AWS::IAM.new.list_server_certificates.body['Certificates'].collect { |c| c['Arn'] }
|
56
|
+
|
57
|
+
listeners.each do |listener|
|
58
|
+
if listener['SSLCertificateId'] and !certificate_ids.include? listener['SSLCertificateId']
|
59
|
+
raise Fog::AWS::IAM::NotFound.new('CertificateNotFound')
|
60
|
+
end
|
61
|
+
load_balancer['ListenerDescriptions'] << {'Listener' => listener, 'PolicyNames' => []}
|
62
|
+
end
|
63
|
+
|
64
|
+
response.status = 200
|
65
|
+
response.body = {
|
66
|
+
'ResponseMetadata' => {
|
67
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
68
|
+
}
|
69
|
+
}
|
70
|
+
|
71
|
+
response
|
72
|
+
else
|
73
|
+
raise Fog::AWS::ELB::NotFound
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
49
77
|
end
|
50
78
|
end
|
51
79
|
end
|
@@ -28,6 +28,24 @@ module Fog
|
|
28
28
|
end
|
29
29
|
|
30
30
|
end
|
31
|
+
|
32
|
+
class Mock
|
33
|
+
def delete_load_balancer(lb_name)
|
34
|
+
response = Excon::Response.new
|
35
|
+
response.status = 200
|
36
|
+
|
37
|
+
self.data[:load_balancers].delete(lb_name)
|
38
|
+
|
39
|
+
response.body = {
|
40
|
+
'ResponseMetadata' => {
|
41
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
42
|
+
},
|
43
|
+
'DeleteLoadBalancerResult' => nil
|
44
|
+
}
|
45
|
+
|
46
|
+
response
|
47
|
+
end
|
48
|
+
end
|
31
49
|
end
|
32
50
|
end
|
33
51
|
end
|
@@ -16,7 +16,7 @@ module Fog
|
|
16
16
|
# * 'ResponseMetadata'<~Hash>:
|
17
17
|
# * 'RequestId'<~String> - Id of request
|
18
18
|
def delete_load_balancer_listeners(lb_name, load_balancer_ports)
|
19
|
-
params = Fog::AWS.indexed_param('LoadBalancerPorts.
|
19
|
+
params = Fog::AWS.indexed_param('LoadBalancerPorts.member.%d', load_balancer_ports)
|
20
20
|
|
21
21
|
request({
|
22
22
|
'Action' => 'DeleteLoadBalancerListeners',
|
@@ -26,6 +26,25 @@ module Fog
|
|
26
26
|
end
|
27
27
|
|
28
28
|
end
|
29
|
+
|
30
|
+
class Mock
|
31
|
+
def delete_load_balancer_listeners(lb_name, load_balancer_ports)
|
32
|
+
raise Fog::AWS::ELB::NotFound unless load_balancer = self.data[:load_balancers][lb_name]
|
33
|
+
|
34
|
+
response = Excon::Response.new
|
35
|
+
response.status = 200
|
36
|
+
|
37
|
+
load_balancer['ListenerDescriptions'].delete_if { |listener| load_balancer_ports.include? listener['Listener']['LoadBalancerPort'] }
|
38
|
+
|
39
|
+
response.body = {
|
40
|
+
'ResponseMetadata' => {
|
41
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
42
|
+
}
|
43
|
+
}
|
44
|
+
|
45
|
+
response
|
46
|
+
end
|
47
|
+
end
|
29
48
|
end
|
30
49
|
end
|
31
50
|
end
|
@@ -26,6 +26,29 @@ module Fog
|
|
26
26
|
end
|
27
27
|
|
28
28
|
end
|
29
|
+
|
30
|
+
class Mock
|
31
|
+
def delete_load_balancer_policy(lb_name, policy_name)
|
32
|
+
if load_balancer = self.data[:load_balancers][lb_name]
|
33
|
+
response = Excon::Response.new
|
34
|
+
response.status = 200
|
35
|
+
|
36
|
+
load_balancer['Policies'].each do |name, policies|
|
37
|
+
policies.delete_if { |p| p['PolicyName'] == policy_name }
|
38
|
+
end
|
39
|
+
|
40
|
+
response.body = {
|
41
|
+
'ResponseMetadata' => {
|
42
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
43
|
+
}
|
44
|
+
}
|
45
|
+
|
46
|
+
response
|
47
|
+
else
|
48
|
+
raise Fog::AWS::ELB::NotFound
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
29
52
|
end
|
30
53
|
end
|
31
54
|
end
|
@@ -33,15 +33,31 @@ module Fog
|
|
33
33
|
end
|
34
34
|
|
35
35
|
class Mock
|
36
|
-
|
37
36
|
def deregister_instances_from_load_balancer(instance_ids, lb_name)
|
38
|
-
Fog::
|
37
|
+
raise Fog::AWS::ELB::NotFound unless load_balancer = self.data[:load_balancers][lb_name]
|
38
|
+
instance_ids = [*instance_ids]
|
39
|
+
instance_ids.each do |instance|
|
40
|
+
raise Fog::AWS::ELB::InvalidInstance unless Compute[:aws].servers.get(instance)
|
41
|
+
end
|
42
|
+
|
43
|
+
response = Excon::Response.new
|
44
|
+
response.status = 200
|
45
|
+
|
46
|
+
load_balancer['Instances'].delete_if { |i| instance_ids.include? i['InstanceId'] }
|
47
|
+
|
48
|
+
response.body = {
|
49
|
+
'ResponseMetadata' => {
|
50
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
51
|
+
},
|
52
|
+
'DeregisterInstancesFromLoadBalancerResult' => {
|
53
|
+
'Instances' => load_balancer['Instances'].dup
|
54
|
+
}
|
55
|
+
}
|
56
|
+
|
57
|
+
response
|
39
58
|
end
|
40
|
-
|
41
59
|
alias :deregister_instances :deregister_instances_from_load_balancer
|
42
|
-
|
43
60
|
end
|
44
|
-
|
45
61
|
end
|
46
62
|
end
|
47
63
|
end
|
@@ -32,6 +32,41 @@ module Fog
|
|
32
32
|
end
|
33
33
|
|
34
34
|
end
|
35
|
+
|
36
|
+
class Mock
|
37
|
+
def describe_instance_health(lb_name, instance_ids = [])
|
38
|
+
raise Fog::AWS::ELB::NotFound unless load_balancer = self.data[:load_balancers][lb_name]
|
39
|
+
|
40
|
+
instance_ids = [*instance_ids]
|
41
|
+
instance_ids = load_balancer['Instances'].collect { |i| i['InstanceId'] } unless instance_ids.any?
|
42
|
+
data = instance_ids.map do |id|
|
43
|
+
unless instance = Compute[:aws].servers.get(id)
|
44
|
+
raise Fog::AWS::ELB::InvalidInstance
|
45
|
+
end
|
46
|
+
|
47
|
+
{
|
48
|
+
'Description' => "",
|
49
|
+
'InstanceId' => instance.id,
|
50
|
+
'ReasonCode' => "",
|
51
|
+
'State' => 'OutOfService'
|
52
|
+
}
|
53
|
+
end
|
54
|
+
|
55
|
+
response = Excon::Response.new
|
56
|
+
response.status = 200
|
57
|
+
|
58
|
+
response.body = {
|
59
|
+
'ResponseMetadata' => {
|
60
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
61
|
+
},
|
62
|
+
'DescribeInstanceHealthResult' => {
|
63
|
+
'InstanceStates' => data
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
response
|
68
|
+
end
|
69
|
+
end
|
35
70
|
end
|
36
71
|
end
|
37
72
|
end
|
@@ -51,6 +51,35 @@ module Fog
|
|
51
51
|
end
|
52
52
|
|
53
53
|
end
|
54
|
+
|
55
|
+
class Mock
|
56
|
+
def describe_load_balancers(lb_names = [])
|
57
|
+
lb_names = [*lb_names]
|
58
|
+
load_balancers = if lb_names.any?
|
59
|
+
lb_names.map do |lb_name|
|
60
|
+
lb = self.data[:load_balancers].find { |name, data| name == lb_name }
|
61
|
+
raise Fog::AWS::ELB::NotFound unless lb
|
62
|
+
lb[1]
|
63
|
+
end.compact
|
64
|
+
else
|
65
|
+
self.data[:load_balancers].values
|
66
|
+
end
|
67
|
+
|
68
|
+
response = Excon::Response.new
|
69
|
+
response.status = 200
|
70
|
+
|
71
|
+
response.body = {
|
72
|
+
'ResponseMetadata' => {
|
73
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
74
|
+
},
|
75
|
+
'DescribeLoadBalancersResult' => {
|
76
|
+
'LoadBalancerDescriptions' => load_balancers
|
77
|
+
}
|
78
|
+
}
|
79
|
+
|
80
|
+
response
|
81
|
+
end
|
82
|
+
end
|
54
83
|
end
|
55
84
|
end
|
56
85
|
end
|
@@ -17,7 +17,7 @@ module Fog
|
|
17
17
|
# * 'ResponseMetadata'<~Hash>:
|
18
18
|
# * 'RequestId'<~String> - Id of request
|
19
19
|
# * 'DisableAvailabilityZonesForLoadBalancerResult'<~Hash>:
|
20
|
-
# * 'AvailabilityZones'<~Array> -
|
20
|
+
# * 'AvailabilityZones'<~Array> - A list of updated Availability Zones for the LoadBalancer.
|
21
21
|
def disable_availability_zones_for_load_balancer(availability_zones, lb_name)
|
22
22
|
params = Fog::AWS.indexed_param('AvailabilityZones.member', [*availability_zones])
|
23
23
|
request({
|
@@ -32,15 +32,28 @@ module Fog
|
|
32
32
|
end
|
33
33
|
|
34
34
|
class Mock
|
35
|
-
|
36
35
|
def disable_availability_zones_for_load_balancer(availability_zones, lb_name)
|
37
|
-
Fog::
|
36
|
+
raise Fog::AWS::ELB::NotFound unless load_balancer = self.data[:load_balancers][lb_name]
|
37
|
+
|
38
|
+
response = Excon::Response.new
|
39
|
+
response.status = 200
|
40
|
+
|
41
|
+
load_balancer['AvailabilityZones'].delete_if { |az| availability_zones.include? az }
|
42
|
+
|
43
|
+
response.body = {
|
44
|
+
'ResponseMetadata' => {
|
45
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
46
|
+
},
|
47
|
+
'DisableAvailabilityZonesForLoadBalancerResult' => {
|
48
|
+
'AvailabilityZones' => load_balancer['AvailabilityZones']
|
49
|
+
}
|
50
|
+
}
|
51
|
+
|
52
|
+
response
|
38
53
|
end
|
39
54
|
|
40
55
|
alias :disable_zones :disable_availability_zones_for_load_balancer
|
41
|
-
|
42
56
|
end
|
43
|
-
|
44
57
|
end
|
45
58
|
end
|
46
59
|
end
|
@@ -34,13 +34,28 @@ module Fog
|
|
34
34
|
class Mock
|
35
35
|
|
36
36
|
def enable_availability_zones_for_load_balancer(availability_zones, lb_name)
|
37
|
-
Fog::
|
37
|
+
raise Fog::AWS::ELB::NotFound unless load_balancer = self.data[:load_balancers][lb_name]
|
38
|
+
|
39
|
+
response = Excon::Response.new
|
40
|
+
response.status = 200
|
41
|
+
|
42
|
+
load_balancer['AvailabilityZones'] << availability_zones
|
43
|
+
load_balancer['AvailabilityZones'].flatten!.uniq!
|
44
|
+
|
45
|
+
response.body = {
|
46
|
+
'ResponseMetadata' => {
|
47
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
48
|
+
},
|
49
|
+
'EnableAvailabilityZonesForLoadBalancerResult' => {
|
50
|
+
'AvailabilityZones' => load_balancer['AvailabilityZones']
|
51
|
+
}
|
52
|
+
}
|
53
|
+
|
54
|
+
response
|
38
55
|
end
|
39
56
|
|
40
57
|
alias :enable_zones :enable_availability_zones_for_load_balancer
|
41
|
-
|
42
58
|
end
|
43
|
-
|
44
59
|
end
|
45
60
|
end
|
46
61
|
end
|
@@ -33,15 +33,32 @@ module Fog
|
|
33
33
|
end
|
34
34
|
|
35
35
|
class Mock
|
36
|
-
|
37
36
|
def register_instances_with_load_balancer(instance_ids, lb_name)
|
38
|
-
Fog::
|
39
|
-
|
37
|
+
raise Fog::AWS::ELB::NotFound unless load_balancer = self.data[:load_balancers][lb_name]
|
38
|
+
instance_ids = [*instance_ids]
|
39
|
+
instances = instance_ids.map do |instance|
|
40
|
+
raise Fog::AWS::ELB::InvalidInstance unless Compute[:aws].servers.get(instance)
|
41
|
+
{'InstanceId' => instance}
|
42
|
+
end
|
40
43
|
|
41
|
-
|
44
|
+
response = Excon::Response.new
|
45
|
+
response.status = 200
|
42
46
|
|
43
|
-
|
47
|
+
load_balancer['Instances'] = instances.dup
|
44
48
|
|
49
|
+
response.body = {
|
50
|
+
'ResponseMetadata' => {
|
51
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
52
|
+
},
|
53
|
+
'RegisterInstancesWithLoadBalancerResult' => {
|
54
|
+
'Instances' => instances
|
55
|
+
}
|
56
|
+
}
|
57
|
+
|
58
|
+
response
|
59
|
+
end
|
60
|
+
alias :register_instances :register_instances_with_load_balancer
|
61
|
+
end
|
45
62
|
end
|
46
63
|
end
|
47
64
|
end
|