fog 1.15.0 → 1.16.0
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile.1.8.7 +1 -0
- data/README.md +1 -0
- data/changelog.txt +596 -0
- data/fog.gemspec +4 -3
- data/lib/fog.rb +1 -0
- data/lib/fog/atmos/models/storage/file.rb +12 -9
- data/lib/fog/atmos/models/storage/files.rb +5 -0
- data/lib/fog/atmos/storage.rb +5 -4
- data/lib/fog/aws.rb +3 -0
- data/lib/fog/aws/auto_scaling.rb +0 -1
- data/lib/fog/aws/cdn.rb +1 -2
- data/lib/fog/aws/compute.rb +11 -2
- data/lib/fog/aws/data_pipeline.rb +3 -0
- data/lib/fog/aws/dns.rb +0 -1
- data/lib/fog/aws/elasticache.rb +2 -0
- data/lib/fog/aws/iam.rb +3 -1
- data/lib/fog/aws/models/auto_scaling/group.rb +12 -12
- data/lib/fog/aws/models/compute/address.rb +1 -0
- data/lib/fog/aws/models/compute/route_table.rb +69 -0
- data/lib/fog/aws/models/compute/route_tables.rb +92 -0
- data/lib/fog/aws/models/compute/server.rb +15 -0
- data/lib/fog/aws/models/compute/subnet.rb +3 -1
- data/lib/fog/aws/models/elasticache/cluster.rb +3 -1
- data/lib/fog/aws/parsers/compute/associate_route_table.rb +20 -0
- data/lib/fog/aws/parsers/compute/create_route_table.rb +75 -0
- data/lib/fog/aws/parsers/compute/describe_route_tables.rb +85 -0
- data/lib/fog/aws/parsers/compute/run_instances.rb +2 -0
- data/lib/fog/aws/parsers/iam/get_group_policy.rb +10 -4
- data/lib/fog/aws/parsers/redshift/cluster.rb +29 -0
- data/lib/fog/aws/parsers/redshift/cluster_parser.rb +144 -0
- data/lib/fog/aws/parsers/redshift/cluster_security_group_parser.rb +50 -0
- data/lib/fog/aws/parsers/redshift/cluster_snapshot.rb +32 -0
- data/lib/fog/aws/parsers/redshift/cluster_snapshot_parser.rb +66 -0
- data/lib/fog/aws/parsers/redshift/cluster_subnet_group_parser.rb +51 -0
- data/lib/fog/aws/parsers/redshift/create_cluster_parameter_group.rb +30 -0
- data/lib/fog/aws/parsers/redshift/create_cluster_security_group.rb +31 -0
- data/lib/fog/aws/parsers/redshift/describe_cluster_parameter_groups.rb +41 -0
- data/lib/fog/aws/parsers/redshift/describe_cluster_parameters.rb +48 -0
- data/lib/fog/aws/parsers/redshift/describe_cluster_security_groups.rb +38 -0
- data/lib/fog/aws/parsers/redshift/describe_cluster_snapshots.rb +38 -0
- data/lib/fog/aws/parsers/redshift/describe_cluster_subnet_groups.rb +58 -0
- data/lib/fog/aws/parsers/redshift/describe_cluster_versions.rb +53 -0
- data/lib/fog/aws/parsers/redshift/describe_clusters.rb +30 -0
- data/lib/fog/aws/parsers/redshift/describe_default_cluster_parameters.rb +49 -0
- data/lib/fog/aws/parsers/redshift/describe_events.rb +44 -0
- data/lib/fog/aws/parsers/redshift/describe_orderable_cluster_options.rb +54 -0
- data/lib/fog/aws/parsers/redshift/describe_reserved_node_offerings.rb +64 -0
- data/lib/fog/aws/parsers/redshift/describe_reserved_nodes.rb +71 -0
- data/lib/fog/aws/parsers/redshift/describe_resize.rb +60 -0
- data/lib/fog/aws/parsers/redshift/purchase_reserved_node_offering.rb +58 -0
- data/lib/fog/aws/parsers/redshift/revoke_cluster_security_group_ingress.rb +31 -0
- data/lib/fog/aws/parsers/redshift/update_cluster_parameter_group_parser.rb +29 -0
- data/lib/fog/aws/parsers/sts/get_session_token.rb +1 -3
- data/lib/fog/aws/redshift.rb +126 -0
- data/lib/fog/aws/requests/auto_scaling/create_auto_scaling_group.rb +5 -4
- data/lib/fog/aws/requests/compute/associate_dhcp_options.rb +2 -2
- data/lib/fog/aws/requests/compute/associate_route_table.rb +75 -0
- data/lib/fog/aws/requests/compute/attach_internet_gateway.rb +2 -2
- data/lib/fog/aws/requests/compute/create_route.rb +89 -0
- data/lib/fog/aws/requests/compute/create_route_table.rb +70 -0
- data/lib/fog/aws/requests/compute/create_vpc.rb +16 -1
- data/lib/fog/aws/requests/compute/delete_dhcp_options.rb +2 -2
- data/lib/fog/aws/requests/compute/delete_internet_gateway.rb +2 -2
- data/lib/fog/aws/requests/compute/delete_network_interface.rb +2 -2
- data/lib/fog/aws/requests/compute/delete_route.rb +60 -0
- data/lib/fog/aws/requests/compute/delete_route_table.rb +51 -0
- data/lib/fog/aws/requests/compute/delete_subnet.rb +2 -2
- data/lib/fog/aws/requests/compute/delete_vpc.rb +2 -2
- data/lib/fog/aws/requests/compute/describe_route_tables.rb +87 -0
- data/lib/fog/aws/requests/compute/detach_internet_gateway.rb +2 -2
- data/lib/fog/aws/requests/compute/detach_network_interface.rb +2 -2
- data/lib/fog/aws/requests/compute/disassociate_route_table.rb +57 -0
- data/lib/fog/aws/requests/compute/reset_network_interface_attribute.rb +2 -1
- data/lib/fog/aws/requests/compute/run_instances.rb +3 -0
- data/lib/fog/aws/requests/data_pipeline/delete_pipeline.rb +2 -3
- data/lib/fog/aws/requests/data_pipeline/describe_objects.rb +41 -0
- data/lib/fog/aws/requests/data_pipeline/get_pipeline_definition.rb +37 -0
- data/lib/fog/aws/requests/data_pipeline/query_objects.rb +41 -0
- data/lib/fog/aws/requests/elasticache/authorize_cache_security_group_ingress.rb +27 -2
- data/lib/fog/aws/requests/elasticache/create_cache_security_group.rb +23 -2
- data/lib/fog/aws/requests/elasticache/delete_cache_security_group.rb +10 -1
- data/lib/fog/aws/requests/elasticache/describe_cache_security_groups.rb +36 -2
- data/lib/fog/aws/requests/iam/get_group_policy.rb +18 -1
- data/lib/fog/aws/requests/iam/get_user_policy.rb +4 -4
- data/lib/fog/aws/requests/iam/put_group_policy.rb +17 -1
- data/lib/fog/aws/requests/iam/put_user_policy.rb +1 -1
- data/lib/fog/aws/requests/redshift/authorize_cluster_security_group_ingress.rb +56 -0
- data/lib/fog/aws/requests/redshift/authorize_snapshot_access.rb +43 -0
- data/lib/fog/aws/requests/redshift/copy_cluster_snapshot.rb +48 -0
- data/lib/fog/aws/requests/redshift/create_cluster.rb +151 -0
- data/lib/fog/aws/requests/redshift/create_cluster_parameter_group.rb +54 -0
- data/lib/fog/aws/requests/redshift/create_cluster_security_group.rb +42 -0
- data/lib/fog/aws/requests/redshift/create_cluster_snapshot.rb +44 -0
- data/lib/fog/aws/requests/redshift/create_cluster_subnet_group.rb +50 -0
- data/lib/fog/aws/requests/redshift/delete_cluster.rb +51 -0
- data/lib/fog/aws/requests/redshift/delete_cluster_parameter_group.rb +34 -0
- data/lib/fog/aws/requests/redshift/delete_cluster_security_group.rb +33 -0
- data/lib/fog/aws/requests/redshift/delete_cluster_snapshot.rb +44 -0
- data/lib/fog/aws/requests/redshift/delete_cluster_subnet_group.rb +38 -0
- data/lib/fog/aws/requests/redshift/describe_cluster_parameter_groups.rb +48 -0
- data/lib/fog/aws/requests/redshift/describe_cluster_parameters.rb +55 -0
- data/lib/fog/aws/requests/redshift/describe_cluster_security_groups.rb +50 -0
- data/lib/fog/aws/requests/redshift/describe_cluster_snapshots.rb +73 -0
- data/lib/fog/aws/requests/redshift/describe_cluster_subnet_groups.rb +47 -0
- data/lib/fog/aws/requests/redshift/describe_cluster_versions.rb +54 -0
- data/lib/fog/aws/requests/redshift/describe_clusters.rb +49 -0
- data/lib/fog/aws/requests/redshift/describe_default_cluster_parameters.rb +49 -0
- data/lib/fog/aws/requests/redshift/describe_events.rb +80 -0
- data/lib/fog/aws/requests/redshift/describe_orderable_cluster_options.rb +55 -0
- data/lib/fog/aws/requests/redshift/describe_reserved_node_offerings.rb +48 -0
- data/lib/fog/aws/requests/redshift/describe_reserved_nodes.rb +48 -0
- data/lib/fog/aws/requests/redshift/describe_resize.rb +39 -0
- data/lib/fog/aws/requests/redshift/modify_cluster.rb +111 -0
- data/lib/fog/aws/requests/redshift/modify_cluster_parameter_group.rb +44 -0
- data/lib/fog/aws/requests/redshift/modify_cluster_subnet_group.rb +50 -0
- data/lib/fog/aws/requests/redshift/purchase_reserved_node_offering.rb +41 -0
- data/lib/fog/aws/requests/redshift/reboot_cluster.rb +37 -0
- data/lib/fog/aws/requests/redshift/reset_cluster_parameter_group.rb +57 -0
- data/lib/fog/aws/requests/redshift/restore_from_cluster_snapshot.rb +77 -0
- data/lib/fog/aws/requests/redshift/revoke_cluster_security_group_ingress.rb +56 -0
- data/lib/fog/aws/requests/redshift/revoke_snapshot_access.rb +44 -0
- data/lib/fog/aws/requests/storage/post_object_restore.rb +1 -1
- data/lib/fog/aws/requests/sts/get_federation_token.rb +42 -0
- data/lib/fog/aws/simpledb.rb +0 -1
- data/lib/fog/aws/sqs.rb +2 -0
- data/lib/fog/aws/storage.rb +11 -5
- data/lib/fog/bin.rb +1 -0
- data/lib/fog/bin/aws.rb +4 -0
- data/lib/fog/bin/openstack.rb +5 -0
- data/lib/fog/bin/rackspace.rb +8 -0
- data/lib/fog/bin/vcloud_director.rb +30 -0
- data/lib/fog/brightbox/requests/compute/update_server.rb +1 -0
- data/lib/fog/cloudsigma/compute.rb +5 -0
- data/lib/fog/cloudsigma/models/fwpolicies.rb +21 -0
- data/lib/fog/cloudsigma/models/fwpolicy.rb +21 -0
- data/lib/fog/cloudsigma/models/rule.rb +21 -0
- data/lib/fog/cloudsigma/requests/list_fwpolicies.rb +18 -0
- data/lib/fog/cloudstack/models/compute/server.rb +1 -0
- data/lib/fog/compute.rb +7 -4
- data/lib/fog/core.rb +3 -0
- data/lib/fog/core/class_from_string.rb +26 -0
- data/lib/fog/core/errors.rb +3 -0
- data/lib/fog/core/uuid.rb +23 -0
- data/lib/fog/dynect/dns.rb +4 -2
- data/lib/fog/dynect/models/dns/records.rb +32 -20
- data/lib/fog/dynect/requests/dns/get_all_records.rb +56 -0
- data/lib/fog/dynect/requests/dns/get_node_list.rb +1 -1
- data/lib/fog/dynect/requests/dns/put_record.rb +76 -0
- data/lib/fog/google/compute.rb +693 -32
- data/lib/fog/google/models/compute/disk.rb +2 -1
- data/lib/fog/google/models/compute/flavors.rb +2 -2
- data/lib/fog/google/models/compute/server.rb +27 -7
- data/lib/fog/google/models/compute/servers.rb +2 -2
- data/lib/fog/google/models/compute/zone.rb +25 -0
- data/lib/fog/google/models/compute/zones.rb +27 -0
- data/lib/fog/google/requests/compute/delete_server.rb +40 -13
- data/lib/fog/google/requests/compute/get_image.rb +15 -2
- data/lib/fog/google/requests/compute/get_machine_type.rb +23 -3
- data/lib/fog/google/requests/compute/get_server.rb +46 -2
- data/lib/fog/google/requests/compute/get_zone.rb +14 -1
- data/lib/fog/google/requests/compute/insert_server.rb +74 -2
- data/lib/fog/google/requests/compute/list_images.rb +8 -2
- data/lib/fog/google/requests/compute/list_machine_types.rb +9 -2
- data/lib/fog/google/requests/compute/list_servers.rb +10 -2
- data/lib/fog/google/requests/compute/list_zones.rb +7 -1
- data/lib/fog/google/storage.rb +1 -3
- data/lib/fog/hp/block_storage.rb +3 -0
- data/lib/fog/hp/cdn.rb +3 -0
- data/lib/fog/hp/compute.rb +3 -0
- data/lib/fog/hp/models/storage/file.rb +12 -0
- data/lib/fog/hp/models/storage/files.rb +23 -1
- data/lib/fog/hp/storage.rb +74 -20
- data/lib/fog/internet_archive/storage.rb +0 -2
- data/lib/fog/joyent/compute.rb +1 -1
- data/lib/fog/linode/models/compute/server.rb +1 -1
- data/lib/fog/local/models/storage/directories.rb +1 -1
- data/lib/fog/local/storage.rb +0 -2
- data/lib/fog/ninefold/storage.rb +0 -1
- data/lib/fog/openstack.rb +1 -4
- data/lib/fog/openstack/compute.rb +1 -2
- data/lib/fog/openstack/identity.rb +1 -2
- data/lib/fog/openstack/image.rb +1 -2
- data/lib/fog/openstack/metering.rb +0 -1
- data/lib/fog/openstack/models/compute/images.rb +10 -2
- data/lib/fog/openstack/models/compute/server.rb +3 -1
- data/lib/fog/openstack/models/network/floating_ip.rb +1 -1
- data/lib/fog/openstack/models/orchestration/stack.rb +52 -0
- data/lib/fog/openstack/models/orchestration/stacks.rb +21 -0
- data/lib/fog/openstack/models/storage/file.rb +16 -0
- data/lib/fog/openstack/models/storage/files.rb +10 -0
- data/lib/fog/openstack/models/volume/volumes.rb +5 -2
- data/lib/fog/openstack/network.rb +0 -1
- data/lib/fog/openstack/orchestration.rb +228 -0
- data/lib/fog/openstack/requests/compute/create_server.rb +41 -31
- data/lib/fog/openstack/requests/compute/list_images_detail.rb +4 -3
- data/lib/fog/openstack/requests/network/create_floating_ip.rb +1 -4
- data/lib/fog/openstack/requests/orchestration/create_stack.rb +58 -0
- data/lib/fog/openstack/requests/orchestration/delete_stack.rb +37 -0
- data/lib/fog/openstack/requests/orchestration/list_stacks.rb +49 -0
- data/lib/fog/openstack/requests/orchestration/update_stack.rb +41 -0
- data/lib/fog/openstack/requests/storage/delete_multiple_objects.rb +67 -0
- data/lib/fog/openstack/requests/storage/delete_static_large_object.rb +43 -0
- data/lib/fog/openstack/requests/storage/get_object.rb +7 -7
- data/lib/fog/openstack/requests/storage/get_object_https_url.rb +44 -6
- data/lib/fog/openstack/requests/storage/put_dynamic_obj_manifest.rb +43 -0
- data/lib/fog/openstack/requests/storage/put_object.rb +13 -4
- data/lib/fog/openstack/requests/storage/put_object_manifest.rb +3 -25
- data/lib/fog/openstack/requests/storage/put_static_obj_manifest.rb +57 -0
- data/lib/fog/openstack/requests/volume/list_volumes.rb +4 -4
- data/lib/fog/openstack/storage.rb +7 -5
- data/lib/fog/openstack/volume.rb +1 -2
- data/lib/fog/orchestration.rb +25 -0
- data/lib/fog/rackspace.rb +7 -3
- data/lib/fog/rackspace/auto_scale.rb +136 -0
- data/lib/fog/rackspace/block_storage.rb +2 -2
- data/lib/fog/rackspace/cdn.rb +23 -23
- data/lib/fog/rackspace/compute.rb +6 -2
- data/lib/fog/rackspace/compute_v2.rb +4 -2
- data/lib/fog/rackspace/databases.rb +2 -2
- data/lib/fog/rackspace/dns.rb +14 -16
- data/lib/fog/rackspace/docs/auto_scale.md +501 -0
- data/lib/fog/rackspace/docs/getting_started.md +1 -0
- data/lib/fog/rackspace/examples/auto_scale/add_policy.rb +68 -0
- data/lib/fog/rackspace/examples/auto_scale/add_webhook.rb +74 -0
- data/lib/fog/rackspace/examples/auto_scale/create_scaling_group.rb +115 -0
- data/lib/fog/rackspace/examples/auto_scale/delete_policy.rb +71 -0
- data/lib/fog/rackspace/examples/auto_scale/delete_scaling_group.rb +61 -0
- data/lib/fog/rackspace/examples/auto_scale/delete_webhook.rb +91 -0
- data/lib/fog/rackspace/examples/compute_v2/bootstrap_server.rb +98 -0
- data/lib/fog/rackspace/examples/compute_v2/create_network.rb +81 -0
- data/lib/fog/rackspace/examples/compute_v2/delete_network.rb +78 -0
- data/lib/fog/rackspace/load_balancers.rb +3 -2
- data/lib/fog/rackspace/mock_data.rb +69 -4
- data/lib/fog/rackspace/models/auto_scale/group.rb +207 -0
- data/lib/fog/rackspace/models/auto_scale/group_builder.rb +85 -0
- data/lib/fog/rackspace/models/auto_scale/group_config.rb +79 -0
- data/lib/fog/rackspace/models/auto_scale/groups.rb +46 -0
- data/lib/fog/rackspace/models/auto_scale/launch_config.rb +64 -0
- data/lib/fog/rackspace/models/auto_scale/policies.rb +67 -0
- data/lib/fog/rackspace/models/auto_scale/policy.rb +222 -0
- data/lib/fog/rackspace/models/auto_scale/webhook.rb +118 -0
- data/lib/fog/rackspace/models/auto_scale/webhooks.rb +63 -0
- data/lib/fog/rackspace/models/block_storage/volume.rb +2 -1
- data/lib/fog/rackspace/models/compute_v2/flavors.rb +1 -2
- data/lib/fog/rackspace/models/compute_v2/images.rb +35 -3
- data/lib/fog/rackspace/models/compute_v2/metadata.rb +0 -1
- data/lib/fog/rackspace/models/compute_v2/metadatum.rb +2 -2
- data/lib/fog/rackspace/models/compute_v2/server.rb +9 -8
- data/lib/fog/rackspace/models/load_balancers/load_balancer.rb +8 -3
- data/lib/fog/rackspace/models/monitoring/notification.rb +42 -0
- data/lib/fog/rackspace/models/monitoring/notifications.rb +30 -0
- data/lib/fog/rackspace/models/queues/claim.rb +92 -0
- data/lib/fog/rackspace/models/queues/claims.rb +40 -0
- data/lib/fog/rackspace/models/queues/message.rb +51 -0
- data/lib/fog/rackspace/models/queues/messages.rb +54 -0
- data/lib/fog/rackspace/models/queues/queue.rb +73 -0
- data/lib/fog/rackspace/models/queues/queues.rb +32 -0
- data/lib/fog/rackspace/monitoring.rb +21 -14
- data/lib/fog/rackspace/queues.rb +117 -0
- data/lib/fog/rackspace/requests/auto_scale/create_group.rb +61 -0
- data/lib/fog/rackspace/requests/auto_scale/create_policy.rb +45 -0
- data/lib/fog/rackspace/requests/auto_scale/create_webhook.rb +57 -0
- data/lib/fog/rackspace/requests/auto_scale/delete_group.rb +23 -0
- data/lib/fog/rackspace/requests/auto_scale/delete_policy.rb +31 -0
- data/lib/fog/rackspace/requests/auto_scale/delete_webhook.rb +34 -0
- data/lib/fog/rackspace/requests/auto_scale/execute_anonymous_webhook.rb +22 -0
- data/lib/fog/rackspace/requests/auto_scale/execute_policy.rb +22 -0
- data/lib/fog/rackspace/requests/auto_scale/get_group.rb +29 -0
- data/lib/fog/rackspace/requests/auto_scale/get_group_config.rb +30 -0
- data/lib/fog/rackspace/requests/auto_scale/get_group_state.rb +62 -0
- data/lib/fog/rackspace/requests/auto_scale/get_launch_config.rb +30 -0
- data/lib/fog/rackspace/requests/auto_scale/get_policy.rb +35 -0
- data/lib/fog/rackspace/requests/auto_scale/get_webhook.rb +39 -0
- data/lib/fog/rackspace/requests/auto_scale/list_groups.rb +35 -0
- data/lib/fog/rackspace/requests/auto_scale/list_policies.rb +23 -0
- data/lib/fog/rackspace/requests/auto_scale/list_webhooks.rb +33 -0
- data/lib/fog/rackspace/requests/auto_scale/pause_group_state.rb +23 -0
- data/lib/fog/rackspace/requests/auto_scale/resume_group_state.rb +22 -0
- data/lib/fog/rackspace/requests/auto_scale/update_group_config.rb +39 -0
- data/lib/fog/rackspace/requests/auto_scale/update_launch_config.rb +36 -0
- data/lib/fog/rackspace/requests/auto_scale/update_policy.rb +33 -0
- data/lib/fog/rackspace/requests/auto_scale/update_webhook.rb +44 -0
- data/lib/fog/rackspace/requests/block_storage/create_volume.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/delete_server.rb +2 -2
- data/lib/fog/rackspace/requests/compute_v2/list_flavors_detail.rb +39 -0
- data/lib/fog/rackspace/requests/compute_v2/list_images.rb +15 -5
- data/lib/fog/rackspace/requests/compute_v2/list_images_detail.rb +53 -0
- data/lib/fog/rackspace/requests/databases/create_database.rb +2 -2
- data/lib/fog/rackspace/requests/databases/create_instance.rb +3 -1
- data/lib/fog/rackspace/requests/databases/create_user.rb +1 -1
- data/lib/fog/rackspace/requests/identity/create_token.rb +1 -1
- data/lib/fog/rackspace/requests/load_balancers/create_load_balancer.rb +11 -0
- data/lib/fog/rackspace/requests/load_balancers/delete_load_balancer.rb +10 -0
- data/lib/fog/rackspace/requests/load_balancers/get_load_balancer.rb +30 -0
- data/lib/fog/rackspace/requests/load_balancers/get_stats.rb +31 -0
- data/lib/fog/rackspace/requests/monitoring/create_agent_token.rb +31 -0
- data/lib/fog/rackspace/requests/monitoring/create_alarm.rb +32 -0
- data/lib/fog/rackspace/requests/monitoring/create_check.rb +31 -0
- data/lib/fog/rackspace/requests/monitoring/create_entity.rb +32 -0
- data/lib/fog/rackspace/requests/monitoring/create_notification.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/delete_agent_token.rb +32 -0
- data/lib/fog/rackspace/requests/monitoring/delete_alarm.rb +27 -0
- data/lib/fog/rackspace/requests/monitoring/delete_check.rb +26 -0
- data/lib/fog/rackspace/requests/monitoring/delete_entity.rb +27 -0
- data/lib/fog/rackspace/requests/monitoring/delete_notification.rb +16 -0
- data/lib/fog/rackspace/requests/monitoring/get_agent_token.rb +33 -0
- data/lib/fog/rackspace/requests/monitoring/get_alarm.rb +38 -0
- data/lib/fog/rackspace/requests/monitoring/get_check.rb +41 -0
- data/lib/fog/rackspace/requests/monitoring/get_entity.rb +42 -0
- data/lib/fog/rackspace/requests/monitoring/get_notification.rb +50 -0
- data/lib/fog/rackspace/requests/monitoring/list_agent_tokens.rb +39 -0
- data/lib/fog/rackspace/requests/monitoring/list_alarms.rb +50 -0
- data/lib/fog/rackspace/requests/monitoring/list_check_types.rb +72 -0
- data/lib/fog/rackspace/requests/monitoring/list_checks.rb +54 -0
- data/lib/fog/rackspace/requests/monitoring/list_data_points.rb +37 -0
- data/lib/fog/rackspace/requests/monitoring/list_entities.rb +53 -0
- data/lib/fog/rackspace/requests/monitoring/list_metrics.rb +65 -0
- data/lib/fog/rackspace/requests/monitoring/list_notification_plans.rb +55 -0
- data/lib/fog/rackspace/requests/monitoring/list_notifications.rb +67 -0
- data/lib/fog/rackspace/requests/monitoring/list_overview.rb +97 -1
- data/lib/fog/rackspace/requests/monitoring/update_alarm.rb +33 -2
- data/lib/fog/rackspace/requests/monitoring/update_check.rb +32 -2
- data/lib/fog/rackspace/requests/monitoring/update_entity.rb +33 -2
- data/lib/fog/rackspace/requests/monitoring/update_notification.rb +17 -0
- data/lib/fog/rackspace/requests/queues/create_claim.rb +24 -0
- data/lib/fog/rackspace/requests/queues/create_message.rb +21 -0
- data/lib/fog/rackspace/requests/queues/create_queue.rb +16 -0
- data/lib/fog/rackspace/requests/queues/delete_claim.rb +15 -0
- data/lib/fog/rackspace/requests/queues/delete_message.rb +18 -0
- data/lib/fog/rackspace/requests/queues/delete_queue.rb +15 -0
- data/lib/fog/rackspace/requests/queues/get_claim.rb +15 -0
- data/lib/fog/rackspace/requests/queues/get_message.rb +16 -0
- data/lib/fog/rackspace/requests/queues/get_queue.rb +15 -0
- data/lib/fog/rackspace/requests/queues/get_queue_stats.rb +15 -0
- data/lib/fog/rackspace/requests/queues/list_messages.rb +17 -0
- data/lib/fog/rackspace/requests/queues/list_queues.rb +15 -0
- data/lib/fog/rackspace/requests/queues/update_claim.rb +19 -0
- data/lib/fog/rackspace/requests/storage/get_object.rb +7 -9
- data/lib/fog/rackspace/requests/storage/put_object.rb +6 -1
- data/lib/fog/rackspace/service.rb +26 -7
- data/lib/fog/rackspace/storage.rb +8 -5
- data/lib/fog/riakcs/provisioning.rb +0 -1
- data/lib/fog/riakcs/usage.rb +2 -3
- data/lib/fog/storage.rb +2 -0
- data/lib/fog/vcloud_director.rb +67 -0
- data/lib/fog/vcloud_director/README.md +953 -0
- data/lib/fog/vcloud_director/compute.rb +640 -0
- data/lib/fog/vcloud_director/generators/compute/customization.rb +105 -0
- data/lib/fog/vcloud_director/generators/compute/disks.rb +186 -0
- data/lib/fog/vcloud_director/generators/compute/edge_gateway.rb +156 -0
- data/lib/fog/vcloud_director/generators/compute/metadata.rb +104 -0
- data/lib/fog/vcloud_director/generators/compute/vm_network.rb +119 -0
- data/lib/fog/vcloud_director/models/compute/catalog.rb +25 -0
- data/lib/fog/vcloud_director/models/compute/catalog_item.rb +26 -0
- data/lib/fog/vcloud_director/models/compute/catalog_items.rb +34 -0
- data/lib/fog/vcloud_director/models/compute/catalogs.rb +32 -0
- data/lib/fog/vcloud_director/models/compute/disk.rb +51 -0
- data/lib/fog/vcloud_director/models/compute/disks.rb +40 -0
- data/lib/fog/vcloud_director/models/compute/media.rb +29 -0
- data/lib/fog/vcloud_director/models/compute/medias.rb +77 -0
- data/lib/fog/vcloud_director/models/compute/network.rb +26 -0
- data/lib/fog/vcloud_director/models/compute/networks.rb +31 -0
- data/lib/fog/vcloud_director/models/compute/organization.rb +41 -0
- data/lib/fog/vcloud_director/models/compute/organizations.rb +30 -0
- data/lib/fog/vcloud_director/models/compute/tag.rb +34 -0
- data/lib/fog/vcloud_director/models/compute/tags.rb +43 -0
- data/lib/fog/vcloud_director/models/compute/task.rb +59 -0
- data/lib/fog/vcloud_director/models/compute/tasks.rb +30 -0
- data/lib/fog/vcloud_director/models/compute/vapp.rb +142 -0
- data/lib/fog/vcloud_director/models/compute/vapps.rb +34 -0
- data/lib/fog/vcloud_director/models/compute/vdc.rb +38 -0
- data/lib/fog/vcloud_director/models/compute/vdcs.rb +32 -0
- data/lib/fog/vcloud_director/models/compute/vm.rb +173 -0
- data/lib/fog/vcloud_director/models/compute/vm_customization.rb +41 -0
- data/lib/fog/vcloud_director/models/compute/vm_customizations.rb +16 -0
- data/lib/fog/vcloud_director/models/compute/vm_network.rb +30 -0
- data/lib/fog/vcloud_director/models/compute/vm_networks.rb +21 -0
- data/lib/fog/vcloud_director/models/compute/vms.rb +41 -0
- data/lib/fog/vcloud_director/parsers/compute/disks.rb +57 -0
- data/lib/fog/vcloud_director/parsers/compute/metadata.rb +63 -0
- data/lib/fog/vcloud_director/parsers/compute/network.rb +106 -0
- data/lib/fog/vcloud_director/parsers/compute/vm.rb +82 -0
- data/lib/fog/vcloud_director/parsers/compute/vm_customization.rb +56 -0
- data/lib/fog/vcloud_director/parsers/compute/vm_network.rb +109 -0
- data/lib/fog/vcloud_director/parsers/compute/vms.rb +96 -0
- data/lib/fog/vcloud_director/parsers/compute/vms_by_metadata.rb +41 -0
- data/lib/fog/vcloud_director/requests/compute/delete_catalog_item.rb +22 -0
- data/lib/fog/vcloud_director/requests/compute/delete_catalog_item_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/delete_disk.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/delete_disk_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/delete_logout.rb +18 -0
- data/lib/fog/vcloud_director/requests/compute/delete_media.rb +42 -0
- data/lib/fog/vcloud_director/requests/compute/delete_media_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/delete_shadow_vm.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp.rb +29 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp_metadata_item_metadata.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp_template.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp_template_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_allocated_ip_addresses.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog.rb +42 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalogs_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_control_access_params_catalog.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_control_access_params_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_cpu_rasd_item.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_current_session.rb +83 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk_owner.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_disks_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_disks_rasd_items_list.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_edge_gateway.rb +93 -0
- data/lib/fog/vcloud_director/requests/compute/get_entity.rb +38 -0
- data/lib/fog/vcloud_director/requests/compute/get_execute_query.rb +462 -0
- data/lib/fog/vcloud_director/requests/compute/get_groups_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_guest_customization_system_section_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_guest_customization_system_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_href.rb +21 -0
- data/lib/fog/vcloud_director/requests/compute/get_lease_settings_section_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_lease_settings_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_media.rb +40 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_drives_rasd_items_list.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_owner.rb +40 -0
- data/lib/fog/vcloud_director/requests/compute/get_medias_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_memory_rasd_item.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_metadata.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/get_network.rb +63 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_cards_items_list.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_config_section_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_config_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_connection_system_section_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_connection_system_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_section_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_operating_system_section.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_org_settings.rb +38 -0
- data/lib/fog/vcloud_director/requests/compute/get_org_vdc_gateways.rb +83 -0
- data/lib/fog/vcloud_director/requests/compute/get_organization.rb +100 -0
- data/lib/fog/vcloud_director/requests/compute/get_organization_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_organization_metadata_item_metadata.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_organizations.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/get_organizations_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_product_sections_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_product_sections_vapp_template.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_request.rb +19 -0
- data/lib/fog/vcloud_director/requests/compute/get_runtime_info_section_type.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_serial_ports_items_list.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_shadow_vm.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_snapshot_section.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_startup_section.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_supported_systems_info.rb +239 -0
- data/lib/fog/vcloud_director/requests/compute/get_supported_versions.rb +1159 -0
- data/lib/fog/vcloud_director/requests/compute/get_task.rb +40 -0
- data/lib/fog/vcloud_director/requests/compute/get_task_list.rb +87 -0
- data/lib/fog/vcloud_director/requests/compute/get_thumbnail.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_users_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_ovf_descriptor.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_owner.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_customization_system_section.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_metadata_item_metadata.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_ovf_descriptor.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_owner.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_templates_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapps_in_lease_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_vcloud.rb +76 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc.rb +158 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_metadata_item_metadata.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_storage_class.rb +83 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_storage_class_metadata.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_storage_class_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdcs_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_virtual_hardware_section.rb +29 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_capabilities.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_compliance_results.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_customization.rb +31 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_disks.rb +31 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_network.rb +31 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_pending_question.rb +34 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms_by_metadata.rb +21 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms_disks_attached_to.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms_in_lease_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/instantiate_vapp_template.rb +97 -0
- data/lib/fog/vcloud_director/requests/compute/post_acquire_ticket.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_answer_vm_pending_question.rb +36 -0
- data/lib/fog/vcloud_director/requests/compute/post_attach_disk.rb +51 -0
- data/lib/fog/vcloud_director/requests/compute/post_cancel_task.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/post_capture_vapp.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/post_check_vm_compliance.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/post_clone_media.rb +51 -0
- data/lib/fog/vcloud_director/requests/compute/post_clone_vapp.rb +62 -0
- data/lib/fog/vcloud_director/requests/compute/post_clone_vapp_template.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_configure_edge_gateway_services.rb +40 -0
- data/lib/fog/vcloud_director/requests/compute/post_consolidate_vm_vapp.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_consolidate_vm_vapp_template.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_deploy_vapp.rb +51 -0
- data/lib/fog/vcloud_director/requests/compute/post_detach_disk.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_disable_nested_hv.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_disable_vapp_template_download.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/post_discard_vapp_state.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/post_eject_cd_rom.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_enable_nested_hv.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_enable_vapp_template_download.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/post_enter_maintenance_mode.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/post_exit_maintenance_mode.rb +22 -0
- data/lib/fog/vcloud_director/requests/compute/post_insert_cd_rom.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_install_vmware_tools.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_instantiate_vapp_template.rb +133 -0
- data/lib/fog/vcloud_director/requests/compute/post_login_session.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_power_off_vapp.rb +36 -0
- data/lib/fog/vcloud_director/requests/compute/post_power_on_vapp.rb +36 -0
- data/lib/fog/vcloud_director/requests/compute/post_reboot_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_remove_all_snapshots.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_reset_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_revert_snapshot.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_shutdown_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_suspend_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_undeploy_vapp.rb +66 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_catalog_item_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_disk_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_media_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_vapp_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_vapp_template_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_upgrade_hw_version.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/post_upload_media.rb +76 -0
- data/lib/fog/vcloud_director/requests/compute/post_upload_vapp_template.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/put_catalog_item_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_cpu.rb +47 -0
- data/lib/fog/vcloud_director/requests/compute/put_disk_metadata_item_metadata.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/put_disks.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/put_guest_customization_section_vapp.rb +62 -0
- data/lib/fog/vcloud_director/requests/compute/put_media_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_memory.rb +47 -0
- data/lib/fog/vcloud_director/requests/compute/put_metadata_value.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/put_network_connection_system_section_vapp.rb +63 -0
- data/lib/fog/vcloud_director/requests/compute/put_vapp_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_vapp_template_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_vm_capabilities.rb +44 -0
- data/lib/fog/version.rb +1 -1
- data/lib/fog/vsphere/compute.rb +9 -1
- data/lib/fog/vsphere/models/compute/datacenter.rb +11 -6
- data/lib/fog/vsphere/models/compute/interface.rb +6 -2
- data/lib/fog/vsphere/models/compute/interfacetype.rb +26 -0
- data/lib/fog/vsphere/models/compute/interfacetypes.rb +40 -0
- data/lib/fog/vsphere/models/compute/server.rb +1 -1
- data/lib/fog/vsphere/models/compute/servertype.rb +39 -0
- data/lib/fog/vsphere/models/compute/servertypes.rb +29 -0
- data/lib/fog/vsphere/requests/compute/create_vm.rb +2 -2
- data/lib/fog/vsphere/requests/compute/get_datacenter.rb +1 -1
- data/lib/fog/vsphere/requests/compute/get_interface_type.rb +15 -0
- data/lib/fog/vsphere/requests/compute/get_network.rb +2 -2
- data/lib/fog/vsphere/requests/compute/get_server_type.rb +32 -0
- data/lib/fog/vsphere/requests/compute/list_datacenters.rb +22 -3
- data/lib/fog/vsphere/requests/compute/list_interface_types.rb +25 -0
- data/lib/fog/vsphere/requests/compute/list_server_types.rb +55 -0
- data/lib/tasks/changelog_task.rb +1 -0
- data/tests/aws/models/auto_scaling/groups_test.rb +5 -0
- data/tests/aws/models/compute/server_tests.rb +21 -1
- data/tests/aws/models/compute/subnet_tests.rb +1 -1
- data/tests/aws/models/compute/subnets_tests.rb +1 -1
- data/tests/aws/requests/compute/instance_tests.rb +1 -0
- data/tests/aws/requests/compute/network_interface_tests.rb +17 -0
- data/tests/aws/requests/compute/route_tests.rb +277 -0
- data/tests/aws/requests/data_pipeline/helper.rb +38 -8
- data/tests/aws/requests/data_pipeline/pipeline_tests.rb +25 -1
- data/tests/aws/requests/elasticache/security_group_tests.rb +3 -2
- data/tests/aws/requests/iam/group_policy_tests.rb +12 -6
- data/tests/aws/requests/redshift/cluster_parameter_group_tests.rb +77 -0
- data/tests/aws/requests/redshift/cluster_security_group_tests.rb +44 -0
- data/tests/aws/requests/redshift/cluster_snapshot_tests.rb +75 -0
- data/tests/aws/requests/redshift/cluster_tests.rb +82 -0
- data/tests/aws/requests/storage/object_tests.rb +1 -0
- data/tests/aws/requests/sts/get_federation_token_tests.rb +0 -1
- data/tests/aws/signed_params_tests.rb +9 -1
- data/tests/aws/storage_tests.rb +7 -0
- data/tests/brightbox/compute/helper.rb +1 -0
- data/tests/brightbox/compute/schema.rb +696 -0
- data/tests/brightbox/requests/compute/account_tests.rb +7 -7
- data/tests/brightbox/requests/compute/api_client_tests.rb +6 -6
- data/tests/brightbox/requests/compute/application_test.rb +6 -6
- data/tests/brightbox/requests/compute/cloud_ip_tests.rb +7 -7
- data/tests/brightbox/requests/compute/firewall_policy_tests.rb +5 -5
- data/tests/brightbox/requests/compute/firewall_rule_tests.rb +4 -4
- data/tests/brightbox/requests/compute/helper.rb +0 -688
- data/tests/brightbox/requests/compute/image_tests.rb +2 -2
- data/tests/brightbox/requests/compute/interface_tests.rb +1 -1
- data/tests/brightbox/requests/compute/load_balancer_tests.rb +9 -9
- data/tests/brightbox/requests/compute/server_group_tests.rb +8 -8
- data/tests/brightbox/requests/compute/server_tests.rb +13 -10
- data/tests/brightbox/requests/compute/server_type_tests.rb +2 -2
- data/tests/brightbox/requests/compute/user_tests.rb +3 -3
- data/tests/brightbox/requests/compute/zone_tests.rb +2 -2
- data/tests/compute/helper.rb +3 -2
- data/tests/core/uuid_tests.rb +10 -0
- data/tests/dynect/requests/dns/dns_tests.rb +29 -0
- data/tests/helpers/mock_helper.rb +4 -0
- data/tests/hp/requests/storage/object_tests.rb +19 -1
- data/tests/openstack/models/storage/file_tests.rb +20 -1
- data/tests/openstack/requests/compute/server_tests.rb +30 -0
- data/tests/openstack/requests/orchestration/stack_tests.rb +35 -0
- data/tests/openstack/requests/storage/large_object_tests.rb +320 -59
- data/tests/openstack/requests/storage/object_tests.rb +77 -4
- data/tests/rackspace/auto_scale_tests.rb +84 -0
- data/tests/rackspace/block_storage_tests.rb +9 -4
- data/tests/rackspace/cdn_tests.rb +9 -4
- data/tests/rackspace/compute_tests.rb +10 -4
- data/tests/rackspace/compute_v2_tests.rb +9 -4
- data/tests/rackspace/databases_tests.rb +9 -4
- data/tests/rackspace/dns_tests.rb +9 -4
- data/tests/rackspace/helper.rb +26 -2
- data/tests/rackspace/identity_tests.rb +9 -4
- data/tests/rackspace/load_balancer_tests.rb +8 -4
- data/tests/rackspace/models/auto_scale/group_builder_tests.rb +145 -0
- data/tests/rackspace/models/auto_scale/group_tests.rb +36 -0
- data/tests/rackspace/models/auto_scale/groups_tests.rb +17 -0
- data/tests/rackspace/models/auto_scale/policies_tests.rb +25 -0
- data/tests/rackspace/models/auto_scale/policy_tests.rb +35 -0
- data/tests/rackspace/models/auto_scale/webhook_tests.rb +42 -0
- data/tests/rackspace/models/auto_scale/webhooks_tests.rb +28 -0
- data/tests/rackspace/models/compute_v2/server_tests.rb +26 -22
- data/tests/rackspace/models/load_balancers/load_balancer_tests.rb +5 -0
- data/tests/rackspace/models/monitoring/notification_tests.rb +19 -0
- data/tests/rackspace/models/monitoring/notifications_tests.rb +10 -0
- data/tests/rackspace/models/queues/claim_tests.rb +43 -0
- data/tests/rackspace/models/queues/claims_tests.rb +55 -0
- data/tests/rackspace/models/queues/message_tests.rb +35 -0
- data/tests/rackspace/models/queues/messages_tests.rb +18 -0
- data/tests/rackspace/models/queues/queue_tests.rb +30 -0
- data/tests/rackspace/models/queues/queues_tests.rb +10 -0
- data/tests/rackspace/monitoring_tests.rb +9 -4
- data/tests/rackspace/queues_tests.rb +118 -0
- data/tests/rackspace/requests/auto_scale/config_tests.rb +97 -0
- data/tests/rackspace/requests/auto_scale/group_tests.rb +50 -0
- data/tests/rackspace/requests/auto_scale/helper.rb +224 -0
- data/tests/rackspace/requests/auto_scale/policy_tests.rb +71 -0
- data/tests/rackspace/requests/auto_scale/webhook_tests.rb +58 -0
- data/tests/rackspace/requests/compute_v2/address_tests.rb +1 -1
- data/tests/rackspace/requests/compute_v2/flavor_tests.rb +6 -0
- data/tests/rackspace/requests/compute_v2/image_tests.rb +4 -0
- data/tests/rackspace/requests/compute_v2/server_tests.rb +2 -2
- data/tests/rackspace/requests/databases/helper.rb +0 -5
- data/tests/rackspace/requests/load_balancers/get_stats_tests.rb +13 -0
- data/tests/rackspace/requests/load_balancers/helper.rb +9 -0
- data/tests/rackspace/requests/monitoring/agent_tests.rb +0 -1
- data/tests/rackspace/requests/monitoring/alarm_tests.rb +3 -3
- data/tests/rackspace/requests/monitoring/check_tests.rb +0 -1
- data/tests/rackspace/requests/monitoring/entity_tests.rb +6 -7
- data/tests/rackspace/requests/monitoring/list_tests.rb +18 -6
- data/tests/rackspace/requests/monitoring/notification_tests.rb +46 -0
- data/tests/rackspace/requests/queues/claim_tests.rb +62 -0
- data/tests/rackspace/requests/queues/helper.rb +50 -0
- data/tests/rackspace/requests/queues/messages_tests.rb +60 -0
- data/tests/rackspace/requests/queues/queues_tests.rb +43 -0
- data/tests/rackspace/requests/storage/large_object_tests.rb +12 -4
- data/tests/rackspace/requests/storage/object_tests.rb +1 -1
- data/tests/rackspace/service_tests.rb +0 -1
- data/tests/rackspace/storage_tests.rb +23 -4
- data/tests/rackspace/url_encoding_tests.rb +3 -1
- data/tests/vcloud_director/ensure_list_tests.rb +56 -0
- data/tests/vcloud_director/fixtures/test.iso +1 -0
- data/tests/vcloud_director/models/compute/catalog_items_tests.rb +41 -0
- data/tests/vcloud_director/models/compute/catalogs_tests.rb +40 -0
- data/tests/vcloud_director/models/compute/helper.rb +60 -0
- data/tests/vcloud_director/models/compute/media_tests.rb +45 -0
- data/tests/vcloud_director/models/compute/organizations_tests.rb +18 -0
- data/tests/vcloud_director/models/compute/tasks_tests.rb +26 -0
- data/tests/vcloud_director/models/compute/vapp_life_cycle_tests.rb +93 -0
- data/tests/vcloud_director/models/compute/vapp_tests.rb +39 -0
- data/tests/vcloud_director/models/compute/vdcs_tests.rb +41 -0
- data/tests/vcloud_director/models/compute/vms_tests.rb +85 -0
- data/tests/vcloud_director/requests/compute/admin_tests.rb +16 -0
- data/tests/vcloud_director/requests/compute/catalog_tests.rb +42 -0
- data/tests/vcloud_director/requests/compute/disk_tests.rb +23 -0
- data/tests/vcloud_director/requests/compute/edge_gateway_tests.rb +39 -0
- data/tests/vcloud_director/requests/compute/groups_tests.rb +18 -0
- data/tests/vcloud_director/requests/compute/helper.rb +30 -0
- data/tests/vcloud_director/requests/compute/media_tests.rb +185 -0
- data/tests/vcloud_director/requests/compute/network_tests.rb +41 -0
- data/tests/vcloud_director/requests/compute/organization_tests.rb +37 -0
- data/tests/vcloud_director/requests/compute/ovf_descriptor_tests.rb +36 -0
- data/tests/vcloud_director/requests/compute/query_tests.rb +34 -0
- data/tests/vcloud_director/requests/compute/schema_helper.rb +625 -0
- data/tests/vcloud_director/requests/compute/session_tests.rb +14 -0
- data/tests/vcloud_director/requests/compute/supported_systems_tests.rb +11 -0
- data/tests/vcloud_director/requests/compute/task_tests.rb +20 -0
- data/tests/vcloud_director/requests/compute/users_tests.rb +18 -0
- data/tests/vcloud_director/requests/compute/vapp_tests.rb +91 -0
- data/tests/vcloud_director/requests/compute/vdc_storage_profile_tests.rb +27 -0
- data/tests/vcloud_director/requests/compute/vdc_tests.rb +36 -0
- data/tests/vcloud_director/requests/compute/versions_tests.rb +13 -0
- data/tests/vcloud_director/requests/compute/vm_tests.rb +125 -0
- metadata +552 -14
- data/lib/fog/aws/parsers/compute/associate_dhcp_options.rb +0 -24
- data/lib/fog/aws/parsers/compute/attach_internet_gateway.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_dhcp_options.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_internet_gateway.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_network_interface.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_subnet.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_vpc.rb +0 -24
- data/lib/fog/aws/parsers/compute/detach_internet_gateway.rb +0 -24
- data/lib/fog/aws/parsers/compute/detach_network_interface.rb +0 -24
@@ -16,6 +16,7 @@ Shindo.tests('Fog::Compute[:openstack] | server requests', ['openstack']) do
|
|
16
16
|
'created' => String,
|
17
17
|
'updated' => String,
|
18
18
|
'user_id' => String,
|
19
|
+
'config_drive' => String,
|
19
20
|
}
|
20
21
|
|
21
22
|
@create_format = {
|
@@ -24,6 +25,10 @@ Shindo.tests('Fog::Compute[:openstack] | server requests', ['openstack']) do
|
|
24
25
|
'links' => Array,
|
25
26
|
'security_groups' => Fog::Nullable::Array,
|
26
27
|
}
|
28
|
+
|
29
|
+
@reservation_format = {
|
30
|
+
'reservation_id' => String,
|
31
|
+
}
|
27
32
|
|
28
33
|
@image_format = {
|
29
34
|
'created' => Fog::Nullable::String,
|
@@ -58,6 +63,31 @@ Shindo.tests('Fog::Compute[:openstack] | server requests', ['openstack']) do
|
|
58
63
|
Fog::Compute[:openstack].get_server_details(@server_id).body['server']
|
59
64
|
end
|
60
65
|
|
66
|
+
#MULTI_CREATE
|
67
|
+
tests('#create_server("test", #{@image_id} , 19, {"min_count" => 2, "return_reservation_id" => "True"})').formats(@reservation_format, false) do
|
68
|
+
data = Fog::Compute[:openstack].create_server("test", @image_id, @flavor_id, {"min_count" => 2, "return_reservation_id" => "True"}).body
|
69
|
+
@reservation_id = data['reservation_id']
|
70
|
+
data
|
71
|
+
end
|
72
|
+
|
73
|
+
tests('#validate_multi_create') do
|
74
|
+
passed = false
|
75
|
+
@multi_create_servers = []
|
76
|
+
if Fog.mocking?
|
77
|
+
@multi_create_servers = [Fog::Mock.random_numbers(6).to_s, Fog::Mock.random_numbers(6).to_s]
|
78
|
+
else
|
79
|
+
@multi_create_servers = Fog::Compute[:openstack].list_servers_detail({'reservation_id' => @reservation_id}).body['servers'].map{|server| server['id']}
|
80
|
+
end
|
81
|
+
if (@multi_create_servers.size == 2)
|
82
|
+
passed = true
|
83
|
+
end
|
84
|
+
end
|
85
|
+
unless Fog.mocking?
|
86
|
+
@multi_create_servers.each {|server|
|
87
|
+
Fog::Compute[:openstack].servers.get(server).destroy
|
88
|
+
}
|
89
|
+
end
|
90
|
+
|
61
91
|
#LIST
|
62
92
|
#NOTE: we can remove strict=false if we remove uuid from GET /servers
|
63
93
|
tests('#list_servers').formats({'servers' => [OpenStack::Compute::Formats::SUMMARY]}, false) do
|
@@ -0,0 +1,35 @@
|
|
1
|
+
Shindo.tests('Fog::Orchestration[:openstack] | stack requests', ['openstack']) do
|
2
|
+
@stack_format = {
|
3
|
+
'links' => Array,
|
4
|
+
'id' => String,
|
5
|
+
'stack_name' => String,
|
6
|
+
'description' => Fog::Nullable::String,
|
7
|
+
'stack_status' => String,
|
8
|
+
'stack_status_reason' => String,
|
9
|
+
'creation_time' => Time,
|
10
|
+
'updated_time' => Time
|
11
|
+
}
|
12
|
+
|
13
|
+
@create_format = {
|
14
|
+
'id' => String,
|
15
|
+
'links' => Array,
|
16
|
+
}
|
17
|
+
|
18
|
+
tests('success') do
|
19
|
+
tests('#create_stack("teststack")').formats(@create_format) do
|
20
|
+
Fog::Orchestration[:openstack].create_stack("teststack").body
|
21
|
+
end
|
22
|
+
|
23
|
+
tests('#list_stacks').formats({'stacks' => [@stack_format]}) do
|
24
|
+
Fog::Orchestration[:openstack].list_stacks.body
|
25
|
+
end
|
26
|
+
|
27
|
+
tests('#update_stack("teststack")').formats({}) do
|
28
|
+
Fog::Orchestration[:openstack].update_stack("teststack").body
|
29
|
+
end
|
30
|
+
|
31
|
+
tests('#delete_stack("teststack", "id")').formats({}) do
|
32
|
+
Fog::Orchestration[:openstack].delete_stack("teststack", "id").body
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -1,106 +1,367 @@
|
|
1
|
-
Shindo.tests('Fog::Storage[:openstack] | large object requests', [
|
1
|
+
Shindo.tests('Fog::Storage[:openstack] | large object requests', ['openstack']) do
|
2
2
|
|
3
3
|
unless Fog.mocking?
|
4
|
-
@directory
|
4
|
+
@directory = Fog::Storage[:openstack].directories.create(:key => 'foglargeobjecttests')
|
5
5
|
@directory2 = Fog::Storage[:openstack].directories.create(:key => 'foglargeobjecttests2')
|
6
|
+
@segments = {
|
7
|
+
:a => {
|
8
|
+
:container => @directory.identity,
|
9
|
+
:name => 'fog_large_object/a',
|
10
|
+
:data => 'a' * (1024**2 + 10),
|
11
|
+
:size => 1024**2 + 10,
|
12
|
+
:etag => 'c2e97007d59f0c19b850debdcb80cca5'
|
13
|
+
},
|
14
|
+
:b => {
|
15
|
+
:container => @directory.identity,
|
16
|
+
:name => 'fog_large_object/b',
|
17
|
+
:data => 'b' * (1024**2 + 20),
|
18
|
+
:size => 1024**2 + 20,
|
19
|
+
:etag => 'd35f50622a1259daad75ff7d5512c7ef'
|
20
|
+
},
|
21
|
+
:c => {
|
22
|
+
:container => @directory.identity,
|
23
|
+
:name => 'fog_large_object2/a',
|
24
|
+
:data => 'c' * (1024**2 + 30),
|
25
|
+
:size => 1024**2 + 30,
|
26
|
+
:etag => '901d3531a87d188041d4d5b43cb464c1'
|
27
|
+
},
|
28
|
+
:d => {
|
29
|
+
:container => @directory2.identity,
|
30
|
+
:name => 'fog_large_object2/b',
|
31
|
+
:data => 'd' * (1024**2 + 40),
|
32
|
+
:size => 1024**2 + 40,
|
33
|
+
:etag => '350c0e00525198813920a157df185c8d'
|
34
|
+
}
|
35
|
+
}
|
6
36
|
end
|
7
37
|
|
8
38
|
tests('success') do
|
9
39
|
|
10
|
-
tests(
|
40
|
+
tests('upload test segments').succeeds do
|
11
41
|
pending if Fog.mocking?
|
12
|
-
|
42
|
+
|
43
|
+
@segments.each_value do |segment|
|
44
|
+
Fog::Storage[:openstack].put_object(segment[:container], segment[:name], segment[:data])
|
45
|
+
end
|
13
46
|
end
|
14
47
|
|
15
|
-
tests(
|
48
|
+
tests('dynamic large object requests') do
|
16
49
|
pending if Fog.mocking?
|
17
|
-
|
50
|
+
|
51
|
+
tests('#put_object_manifest alias').succeeds do
|
52
|
+
Fog::Storage[:openstack].put_object_manifest(@directory.identity, 'fog_large_object')
|
53
|
+
end
|
54
|
+
|
55
|
+
tests('using default X-Object-Manifest header') do
|
56
|
+
|
57
|
+
tests('#put_dynamic_obj_manifest').succeeds do
|
58
|
+
Fog::Storage[:openstack].put_dynamic_obj_manifest(@directory.identity, 'fog_large_object')
|
59
|
+
end
|
60
|
+
|
61
|
+
tests('#get_object streams all segments matching the default prefix').succeeds do
|
62
|
+
expected = @segments[:a][:data] + @segments[:b][:data] + @segments[:c][:data]
|
63
|
+
Fog::Storage[:openstack].get_object(@directory.identity, 'fog_large_object').body == expected
|
64
|
+
end
|
65
|
+
|
66
|
+
# When the manifest object name is equal to the segment prefix, OpenStack treats it as if it's the first segment.
|
67
|
+
# So you must prepend the manifest object's Etag - Digest::MD5.hexdigest('')
|
68
|
+
tests('#head_object returns Etag that includes manifest object in calculation').succeeds do
|
69
|
+
etags = ['d41d8cd98f00b204e9800998ecf8427e', @segments[:a][:etag], @segments[:b][:etag], @segments[:c][:etag]]
|
70
|
+
expected = "\"#{ Digest::MD5.hexdigest(etags.join) }\"" # returned in quotes "\"2577f38428e895c50de6ea78ccc7da2a"\"
|
71
|
+
Fog::Storage[:openstack].head_object(@directory.identity, 'fog_large_object').headers['Etag'] == expected
|
72
|
+
end
|
73
|
+
|
74
|
+
end
|
75
|
+
|
76
|
+
tests('specifying X-Object-Manifest segment prefix') do
|
77
|
+
|
78
|
+
tests('#put_dynamic_obj_manifest').succeeds do
|
79
|
+
options = { 'X-Object-Manifest' => "#{ @directory.identity }/fog_large_object/" }
|
80
|
+
Fog::Storage[:openstack].put_dynamic_obj_manifest(@directory.identity, 'fog_large_object', options)
|
81
|
+
end
|
82
|
+
|
83
|
+
tests('#get_object streams segments only matching the specified prefix').succeeds do
|
84
|
+
expected = @segments[:a][:data] + @segments[:b][:data]
|
85
|
+
Fog::Storage[:openstack].get_object(@directory.identity, 'fog_large_object').body == expected
|
86
|
+
end
|
87
|
+
|
88
|
+
tests('#head_object returns Etag that does not include manifest object in calculation').succeeds do
|
89
|
+
etags = [@segments[:a][:etag], @segments[:b][:etag]]
|
90
|
+
expected = "\"#{ Digest::MD5.hexdigest(etags.join) }\"" # returned in quotes "\"0f035ed3cc38aa0ef46dda3478fad44d"\"
|
91
|
+
Fog::Storage[:openstack].head_object(@directory.identity, 'fog_large_object').headers['Etag'] == expected
|
92
|
+
end
|
93
|
+
|
94
|
+
end
|
95
|
+
|
96
|
+
tests('storing manifest in a different container than the segments') do
|
97
|
+
|
98
|
+
tests('#put_dynamic_obj_manifest').succeeds do
|
99
|
+
options = { 'X-Object-Manifest' => "#{ @directory.identity }/fog_large_object/" }
|
100
|
+
Fog::Storage[:openstack].put_dynamic_obj_manifest(@directory2.identity, 'fog_large_object', options)
|
101
|
+
end
|
102
|
+
|
103
|
+
tests('#get_object').succeeds do
|
104
|
+
expected = @segments[:a][:data] + @segments[:b][:data]
|
105
|
+
Fog::Storage[:openstack].get_object(@directory2.identity, 'fog_large_object').body == expected
|
106
|
+
end
|
107
|
+
|
108
|
+
end
|
109
|
+
|
18
110
|
end
|
19
111
|
|
20
|
-
tests(
|
112
|
+
tests('static large object requests') do
|
21
113
|
pending if Fog.mocking?
|
22
|
-
Fog::Storage[:openstack].put_object(@directory.identity, 'fog_large_object2/1', ('x' * 1 * 1024 * 1024))
|
23
|
-
end
|
24
114
|
|
25
|
-
|
115
|
+
tests('single container') do
|
116
|
+
|
117
|
+
tests('#put_static_obj_manifest').succeeds do
|
118
|
+
segments = [
|
119
|
+
{ :path => "#{ @segments[:a][:container] }/#{ @segments[:a][:name] }",
|
120
|
+
:etag => @segments[:a][:etag],
|
121
|
+
:size_bytes => @segments[:a][:size] },
|
122
|
+
{ :path => "#{ @segments[:c][:container] }/#{ @segments[:c][:name] }",
|
123
|
+
:etag => @segments[:c][:etag],
|
124
|
+
:size_bytes => @segments[:c][:size] }
|
125
|
+
]
|
126
|
+
Fog::Storage[:openstack].put_static_obj_manifest(@directory.identity, 'fog_large_object', segments)
|
127
|
+
end
|
128
|
+
|
129
|
+
tests('#head_object') do
|
130
|
+
etags = [@segments[:a][:etag], @segments[:c][:etag]]
|
131
|
+
etag = "\"#{ Digest::MD5.hexdigest(etags.join) }\"" # "\"ad7e633a12e8a4915b45e6dd1d4b0b4b\""
|
132
|
+
content_length = (@segments[:a][:size] + @segments[:c][:size]).to_s
|
133
|
+
response = Fog::Storage[:openstack].head_object(@directory.identity, 'fog_large_object')
|
134
|
+
|
135
|
+
returns(etag, 'returns ETag computed from segments') { response.headers['Etag'] }
|
136
|
+
returns(content_length , 'returns Content-Length for all segments') { response.headers['Content-Length'] }
|
137
|
+
returns('True', 'returns X-Static-Large-Object header') { response.headers['X-Static-Large-Object'] }
|
138
|
+
end
|
139
|
+
|
140
|
+
tests('#get_object').succeeds do
|
141
|
+
expected = @segments[:a][:data] + @segments[:c][:data]
|
142
|
+
Fog::Storage[:openstack].get_object(@directory.identity, 'fog_large_object').body == expected
|
143
|
+
end
|
144
|
+
|
145
|
+
tests('#delete_static_large_object') do
|
146
|
+
expected = {
|
147
|
+
'Number Not Found' => 0,
|
148
|
+
'Response Status' => '200 OK',
|
149
|
+
'Errors' => [],
|
150
|
+
'Number Deleted' => 3,
|
151
|
+
'Response Body' => ''
|
152
|
+
}
|
153
|
+
returns(expected, 'deletes manifest and segments') do
|
154
|
+
Fog::Storage[:openstack].delete_static_large_object(@directory.identity, 'fog_large_object').body
|
155
|
+
end
|
156
|
+
end
|
26
157
|
|
27
|
-
tests("#put_object_manifest('foglargeobjecttests', 'fog_large_object')").succeeds do
|
28
|
-
pending if Fog.mocking?
|
29
|
-
Fog::Storage[:openstack].put_object_manifest(@directory.identity, 'fog_large_object')
|
30
158
|
end
|
31
159
|
|
32
|
-
tests(
|
33
|
-
|
34
|
-
|
160
|
+
tests('multiple containers') do
|
161
|
+
|
162
|
+
tests('#put_static_obj_manifest').succeeds do
|
163
|
+
segments = [
|
164
|
+
{ :path => "#{ @segments[:b][:container] }/#{ @segments[:b][:name] }",
|
165
|
+
:etag => @segments[:b][:etag],
|
166
|
+
:size_bytes => @segments[:b][:size] },
|
167
|
+
{ :path => "#{ @segments[:d][:container] }/#{ @segments[:d][:name] }",
|
168
|
+
:etag => @segments[:d][:etag],
|
169
|
+
:size_bytes => @segments[:d][:size] }
|
170
|
+
]
|
171
|
+
Fog::Storage[:openstack].put_static_obj_manifest(@directory2.identity, 'fog_large_object', segments)
|
172
|
+
end
|
173
|
+
|
174
|
+
tests('#head_object') do
|
175
|
+
etags = [@segments[:b][:etag], @segments[:d][:etag]]
|
176
|
+
etag = "\"#{ Digest::MD5.hexdigest(etags.join) }\"" # "\"9801a4cc4472896a1e975d03f0d2c3f8\""
|
177
|
+
content_length = (@segments[:b][:size] + @segments[:d][:size]).to_s
|
178
|
+
response = Fog::Storage[:openstack].head_object(@directory2.identity, 'fog_large_object')
|
179
|
+
|
180
|
+
returns(etag, 'returns ETag computed from segments') { response.headers['Etag'] }
|
181
|
+
returns(content_length , 'returns Content-Length for all segments') { response.headers['Content-Length'] }
|
182
|
+
returns('True', 'returns X-Static-Large-Object header') { response.headers['X-Static-Large-Object'] }
|
183
|
+
end
|
184
|
+
|
185
|
+
tests('#get_object').succeeds do
|
186
|
+
expected = @segments[:b][:data] + @segments[:d][:data]
|
187
|
+
Fog::Storage[:openstack].get_object(@directory2.identity, 'fog_large_object').body == expected
|
188
|
+
end
|
189
|
+
|
190
|
+
tests('#delete_static_large_object') do
|
191
|
+
expected = {
|
192
|
+
'Number Not Found' => 0,
|
193
|
+
'Response Status' => '200 OK',
|
194
|
+
'Errors' => [],
|
195
|
+
'Number Deleted' => 3,
|
196
|
+
'Response Body' => ''
|
197
|
+
}
|
198
|
+
returns(expected, 'deletes manifest and segments') do
|
199
|
+
Fog::Storage[:openstack].delete_static_large_object(@directory2.identity, 'fog_large_object').body
|
200
|
+
end
|
201
|
+
end
|
202
|
+
|
35
203
|
end
|
36
204
|
|
37
|
-
|
38
|
-
|
205
|
+
end
|
206
|
+
|
207
|
+
end
|
208
|
+
|
209
|
+
tests('failure') do
|
210
|
+
|
211
|
+
tests('dynamic large object requests') do
|
212
|
+
pending if Fog.mocking?
|
39
213
|
|
40
|
-
|
41
|
-
|
42
|
-
etags << Digest::MD5.hexdigest('') # Etag for manifest object => "d41d8cd98f00b204e9800998ecf8427e"
|
43
|
-
etags << Digest::MD5.hexdigest('x' * 4 * 1024 * 1024) # => "44981362d3ba9b5bacaf017c2f29d355"
|
44
|
-
etags << Digest::MD5.hexdigest('x' * 2 * 1024 * 1024) # => "67b2f816a30e8956149b2d7beb479e51"
|
45
|
-
etags << Digest::MD5.hexdigest('x' * 1 * 1024 * 1024) # => "b561f87202d04959e37588ee05cf5b10"
|
46
|
-
expected = Digest::MD5.hexdigest(etags.join) # => "42e92048bd2c8085e7072b0b55fd76ab"
|
47
|
-
actual = Fog::Storage[:openstack].head_object(@directory.identity, 'fog_large_object').headers['Etag']
|
48
|
-
actual.gsub('"', '') == expected # actual is returned in quotes "\"42e92048bd2c8085e7072b0b55fd76abu"\"
|
214
|
+
tests('#put_dynamic_obj_manifest with missing container').raises(Fog::Storage::OpenStack::NotFound) do
|
215
|
+
Fog::Storage[:openstack].put_dynamic_obj_manifest('fognoncontainer', 'fog_large_object')
|
49
216
|
end
|
50
217
|
|
51
218
|
end
|
52
219
|
|
53
|
-
tests(
|
220
|
+
tests('static large object requests') do
|
221
|
+
pending if Fog.mocking?
|
54
222
|
|
55
|
-
tests(
|
56
|
-
|
57
|
-
Fog::Storage[:openstack].
|
223
|
+
tests('upload test segments').succeeds do
|
224
|
+
Fog::Storage[:openstack].put_object(@segments[:a][:container], @segments[:a][:name], @segments[:a][:data])
|
225
|
+
Fog::Storage[:openstack].put_object(@segments[:b][:container], @segments[:b][:name], @segments[:b][:data])
|
58
226
|
end
|
59
227
|
|
60
|
-
tests(
|
61
|
-
|
62
|
-
Fog::Storage[:openstack].get_object(@directory.identity, 'fog_large_object').body == ('x' * 6 * 1024 * 1024)
|
228
|
+
tests('#put_static_obj_manifest with missing container').raises(Fog::Storage::OpenStack::NotFound) do
|
229
|
+
Fog::Storage[:openstack].put_static_obj_manifest('fognoncontainer', 'fog_large_object', [])
|
63
230
|
end
|
64
231
|
|
65
|
-
tests(
|
66
|
-
|
232
|
+
tests('#put_static_obj_manifest with missing object') do
|
233
|
+
segments = [
|
234
|
+
{ :path => "#{ @segments[:c][:container] }/#{ @segments[:c][:name] }",
|
235
|
+
:etag => @segments[:c][:etag],
|
236
|
+
:size_bytes => @segments[:c][:size] }
|
237
|
+
]
|
238
|
+
expected = { 'Errors' => [[segments[0][:path], '404 Not Found']] }
|
239
|
+
|
240
|
+
error = nil
|
241
|
+
begin
|
242
|
+
Fog::Storage[:openstack].put_static_obj_manifest(@directory.identity, 'fog_large_object', segments)
|
243
|
+
rescue => err
|
244
|
+
error = err
|
245
|
+
end
|
67
246
|
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
247
|
+
raises(Excon::Errors::BadRequest) do
|
248
|
+
raise error if error
|
249
|
+
end
|
250
|
+
|
251
|
+
returns(expected, 'returns error information') do
|
252
|
+
Fog::JSON.decode(error.response.body)
|
253
|
+
end
|
74
254
|
end
|
75
255
|
|
76
|
-
|
256
|
+
tests('#put_static_obj_manifest with invalid etag') do
|
257
|
+
segments = [
|
258
|
+
{ :path => "#{ @segments[:a][:container] }/#{ @segments[:a][:name] }",
|
259
|
+
:etag => @segments[:b][:etag],
|
260
|
+
:size_bytes => @segments[:a][:size] }
|
261
|
+
]
|
262
|
+
expected = { 'Errors' => [[segments[0][:path], 'Etag Mismatch']] }
|
77
263
|
|
78
|
-
|
264
|
+
error = nil
|
265
|
+
begin
|
266
|
+
Fog::Storage[:openstack].put_static_obj_manifest(@directory.identity, 'fog_large_object', segments)
|
267
|
+
rescue => err
|
268
|
+
error = err
|
269
|
+
end
|
79
270
|
|
80
|
-
|
81
|
-
|
82
|
-
|
271
|
+
raises(Excon::Errors::BadRequest) do
|
272
|
+
raise error if error
|
273
|
+
end
|
274
|
+
|
275
|
+
returns(expected, 'returns error information') do
|
276
|
+
Fog::JSON.decode(error.response.body)
|
277
|
+
end
|
83
278
|
end
|
84
279
|
|
85
|
-
tests(
|
86
|
-
|
87
|
-
|
280
|
+
tests('#put_static_obj_manifest with invalid byte_size') do
|
281
|
+
segments = [
|
282
|
+
{ :path => "#{ @segments[:a][:container] }/#{ @segments[:a][:name] }",
|
283
|
+
:etag => @segments[:a][:etag],
|
284
|
+
:size_bytes => @segments[:b][:size] }
|
285
|
+
]
|
286
|
+
expected = { 'Errors' => [[segments[0][:path], 'Size Mismatch']] }
|
287
|
+
|
288
|
+
error = nil
|
289
|
+
begin
|
290
|
+
Fog::Storage[:openstack].put_static_obj_manifest(@directory.identity, 'fog_large_object', segments)
|
291
|
+
rescue => err
|
292
|
+
error = err
|
293
|
+
end
|
294
|
+
|
295
|
+
raises(Excon::Errors::BadRequest) do
|
296
|
+
raise error if error
|
297
|
+
end
|
298
|
+
|
299
|
+
returns(expected, 'returns error information') do
|
300
|
+
Fog::JSON.decode(error.response.body)
|
301
|
+
end
|
88
302
|
end
|
89
303
|
|
90
|
-
|
304
|
+
tests('#delete_static_large_object with missing container') do
|
305
|
+
expected = {
|
306
|
+
'Number Not Found' => 1,
|
307
|
+
'Response Status' => '200 OK',
|
308
|
+
'Errors' => [],
|
309
|
+
'Number Deleted' => 0,
|
310
|
+
'Response Body' => ''
|
311
|
+
}
|
91
312
|
|
92
|
-
|
93
|
-
|
94
|
-
|
313
|
+
returns(expected, 'reports missing object') do
|
314
|
+
Fog::Storage[:openstack].delete_static_large_object('fognoncontainer', 'fog_large_object').body
|
315
|
+
end
|
95
316
|
end
|
96
|
-
@directory2.files.new(:key => 'fog_large_object').destroy
|
97
|
-
end
|
98
317
|
|
99
|
-
|
318
|
+
tests('#delete_static_large_object with missing manifest') do
|
319
|
+
expected = {
|
320
|
+
'Number Not Found' => 1,
|
321
|
+
'Response Status' => '200 OK',
|
322
|
+
'Errors' => [],
|
323
|
+
'Number Deleted' => 0,
|
324
|
+
'Response Body' => ''
|
325
|
+
}
|
100
326
|
|
101
|
-
|
327
|
+
returns(expected, 'reports missing manifest') do
|
328
|
+
Fog::Storage[:openstack].delete_static_large_object(@directory.identity, 'fog_non_object').body
|
329
|
+
end
|
330
|
+
end
|
331
|
+
|
332
|
+
tests('#delete_static_large_object with missing segment') do
|
333
|
+
|
334
|
+
tests('#put_static_obj_manifest for segments :a and :b').succeeds do
|
335
|
+
segments = [
|
336
|
+
{ :path => "#{ @segments[:a][:container] }/#{ @segments[:a][:name] }",
|
337
|
+
:etag => @segments[:a][:etag],
|
338
|
+
:size_bytes => @segments[:a][:size] },
|
339
|
+
{ :path => "#{ @segments[:b][:container] }/#{ @segments[:b][:name] }",
|
340
|
+
:etag => @segments[:b][:etag],
|
341
|
+
:size_bytes => @segments[:b][:size] }
|
342
|
+
]
|
343
|
+
Fog::Storage[:openstack].put_static_obj_manifest(@directory.identity, 'fog_large_object', segments)
|
344
|
+
end
|
345
|
+
|
346
|
+
tests('#delete_object segment :b').succeeds do
|
347
|
+
Fog::Storage[:openstack].delete_object(@segments[:b][:container], @segments[:b][:name])
|
348
|
+
end
|
102
349
|
|
103
|
-
|
350
|
+
tests('#delete_static_large_object') do
|
351
|
+
expected = {
|
352
|
+
'Number Not Found' => 1,
|
353
|
+
'Response Status' => '200 OK',
|
354
|
+
'Errors' => [],
|
355
|
+
'Number Deleted' => 2,
|
356
|
+
'Response Body' => ''
|
357
|
+
}
|
358
|
+
returns(expected, 'deletes manifest and segment :a, and reports missing segment :b') do
|
359
|
+
Fog::Storage[:openstack].delete_static_large_object(@directory.identity, 'fog_large_object').body
|
360
|
+
end
|
361
|
+
end
|
362
|
+
|
363
|
+
end
|
364
|
+
end
|
104
365
|
|
105
366
|
end
|
106
367
|
|