fog 1.18.0 → 1.19.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +1 -0
- data/.travis.yml +6 -0
- data/CONTRIBUTING.md +22 -0
- data/LICENSE.md +20 -0
- data/README.md +41 -60
- data/Rakefile +2 -0
- data/changelog.txt +262 -0
- data/fog.gemspec +3 -3
- data/lib/fog/aws.rb +9 -7
- data/lib/fog/aws/cloud_watch.rb +0 -1
- data/lib/fog/aws/compute.rb +2 -0
- data/lib/fog/aws/dns.rb +2 -1
- data/lib/fog/aws/elb.rb +2 -0
- data/lib/fog/aws/models/auto_scaling/configuration.rb +4 -0
- data/lib/fog/aws/models/compute/address.rb +6 -5
- data/lib/fog/aws/models/compute/flavors.rb +10 -0
- data/lib/fog/aws/models/compute/spot_request.rb +1 -1
- data/lib/fog/aws/models/compute/subnet.rb +4 -0
- data/lib/fog/aws/models/compute/vpc.rb +5 -0
- data/lib/fog/aws/models/dns/records.rb +1 -3
- data/lib/fog/aws/models/elb/load_balancer.rb +10 -0
- data/lib/fog/aws/models/glacier/vault.rb +1 -1
- data/lib/fog/aws/models/rds/server.rb +5 -2
- data/lib/fog/aws/models/rds/subnet_group.rb +15 -1
- data/lib/fog/aws/models/storage/file.rb +2 -2
- data/lib/fog/aws/parsers/auto_scaling/describe_launch_configurations.rb +6 -0
- data/lib/fog/aws/parsers/compute/assign_private_ip_addresses.rb +25 -0
- data/lib/fog/aws/parsers/compute/describe_addresses.rb +1 -1
- data/lib/fog/aws/parsers/elb/describe_load_balancer_attributes.rb +40 -0
- data/lib/fog/aws/parsers/rds/delete_db_subnet_group.rb +35 -0
- data/lib/fog/aws/rds.rb +3 -3
- data/lib/fog/aws/requests/auto_scaling/create_launch_configuration.rb +2 -0
- data/lib/fog/aws/requests/auto_scaling/describe_notification_configurations.rb +1 -1
- data/lib/fog/aws/requests/compute/assign_private_ip_addresses.rb +60 -0
- data/lib/fog/aws/requests/compute/create_route.rb +1 -1
- data/lib/fog/aws/requests/compute/describe_images.rb +1 -1
- data/lib/fog/aws/requests/compute/describe_subnets.rb +8 -0
- data/lib/fog/aws/requests/compute/describe_vpcs.rb +8 -0
- data/lib/fog/aws/requests/compute/modify_vpc_attribute.rb +59 -0
- data/lib/fog/aws/requests/dns/change_resource_record_sets.rb +26 -9
- data/lib/fog/aws/requests/dns/create_hosted_zone.rb +12 -3
- data/lib/fog/aws/requests/dns/delete_hosted_zone.rb +33 -0
- data/lib/fog/aws/requests/dns/get_change.rb +26 -0
- data/lib/fog/aws/requests/dns/get_hosted_zone.rb +1 -1
- data/lib/fog/aws/requests/dns/list_hosted_zones.rb +3 -8
- data/lib/fog/aws/requests/dns/list_resource_record_sets.rb +68 -0
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +1 -0
- data/lib/fog/aws/requests/elb/describe_load_balancer_attributes.rb +54 -0
- data/lib/fog/aws/requests/elb/modify_load_balancer_attributes.rb +59 -0
- data/lib/fog/aws/requests/rds/create_db_instance.rb +7 -1
- data/lib/fog/aws/requests/rds/create_db_subnet_group.rb +7 -1
- data/lib/fog/aws/requests/rds/delete_db_subnet_group.rb +42 -0
- data/lib/fog/aws/requests/storage/delete_multiple_objects.rb +6 -4
- data/lib/fog/aws/requests/storage/put_bucket.rb +4 -1
- data/lib/fog/aws/sqs.rb +2 -4
- data/lib/fog/aws/storage.rb +14 -1
- data/lib/fog/bluebox/compute.rb +1 -1
- data/lib/fog/brightbox/compute.rb +7 -9
- data/lib/fog/brightbox/compute/image_selector.rb +1 -1
- data/lib/fog/brightbox/compute/shared.rb +8 -10
- data/lib/fog/brightbox/models/compute/api_client.rb +1 -1
- data/lib/fog/brightbox/models/compute/application.rb +1 -4
- data/lib/fog/brightbox/models/compute/cloud_ip.rb +8 -5
- data/lib/fog/brightbox/models/compute/collaboration.rb +0 -2
- data/lib/fog/brightbox/models/compute/collaborations.rb +1 -1
- data/lib/fog/brightbox/models/compute/firewall_policy.rb +2 -4
- data/lib/fog/brightbox/models/compute/firewall_rule.rb +1 -1
- data/lib/fog/brightbox/models/compute/image.rb +1 -3
- data/lib/fog/brightbox/models/compute/load_balancer.rb +11 -8
- data/lib/fog/brightbox/models/compute/server.rb +28 -20
- data/lib/fog/brightbox/models/compute/server_group.rb +9 -11
- data/lib/fog/brightbox/models/compute/zone.rb +1 -1
- data/lib/fog/brightbox/oauth2.rb +3 -3
- data/lib/fog/brightbox/requests/compute/update_server.rb +1 -1
- data/lib/fog/cloudstack.rb +1 -1
- data/lib/fog/compute.rb +2 -2
- data/lib/fog/core.rb +1 -1
- data/lib/fog/core/connection.rb +1 -2
- data/lib/fog/core/errors.rb +3 -3
- data/lib/fog/core/hmac.rb +3 -3
- data/lib/fog/core/mock.rb +9 -2
- data/lib/fog/core/scp.rb +1 -1
- data/lib/fog/core/wait_for.rb +1 -1
- data/lib/fog/core/{timeout.rb → wait_for_defaults.rb} +10 -0
- data/lib/fog/digitalocean/models/compute/server.rb +4 -0
- data/lib/fog/digitalocean/requests/compute/create_server.rb +2 -0
- data/lib/fog/dnsimple/dns.rb +1 -1
- data/lib/fog/dreamhost/dns.rb +2 -4
- data/lib/fog/ecloud/compute.rb +1 -1
- data/lib/fog/ecloud/models/compute/environments.rb +5 -3
- data/lib/fog/google/compute.rb +105 -68
- data/lib/fog/google/examples/create.rb +1 -0
- data/lib/fog/google/models/compute/disk.rb +7 -1
- data/lib/fog/google/models/compute/operation.rb +42 -0
- data/lib/fog/google/models/compute/operations.rb +26 -0
- data/lib/fog/google/models/compute/server.rb +18 -2
- data/lib/fog/google/models/compute/servers.rb +2 -1
- data/lib/fog/google/models/compute/zones.rb +1 -1
- data/lib/fog/google/models/storage/file.rb +1 -1
- data/lib/fog/google/models/storage/files.rb +1 -1
- data/lib/fog/google/requests/compute/delete_disk.rb +22 -2
- data/lib/fog/google/requests/compute/delete_global_operation.rb +29 -0
- data/lib/fog/google/requests/compute/delete_server.rb +13 -9
- data/lib/fog/google/requests/compute/delete_zone_operation.rb +33 -0
- data/lib/fog/google/requests/compute/get_disk.rb +26 -2
- data/lib/fog/google/requests/compute/{delete_operation.rb → get_global_operation.rb} +5 -6
- data/lib/fog/google/requests/compute/get_image.rb +3 -3
- data/lib/fog/google/requests/compute/get_server.rb +1 -0
- data/lib/fog/google/requests/compute/get_zone_operation.rb +58 -0
- data/lib/fog/google/requests/compute/insert_disk.rb +43 -3
- data/lib/fog/google/requests/compute/insert_firewall.rb +2 -1
- data/lib/fog/google/requests/compute/insert_image.rb +2 -2
- data/lib/fog/google/requests/compute/insert_server.rb +64 -35
- data/lib/fog/google/requests/compute/list_disks.rb +8 -2
- data/lib/fog/google/requests/compute/list_images.rb +2 -2
- data/lib/fog/google/requests/compute/list_machine_types.rb +2 -2
- data/lib/fog/google/requests/compute/list_servers.rb +2 -2
- data/lib/fog/google/requests/compute/list_zone_operations.rb +2 -1
- data/lib/fog/google/requests/compute/list_zones.rb +1 -1
- data/lib/fog/google/requests/storage/copy_object.rb +1 -1
- data/lib/fog/hp.rb +1 -1
- data/lib/fog/hp/README.md +57 -0
- data/lib/fog/hp/articles/auth_caching.md +23 -0
- data/lib/fog/hp/docs/connect.md +152 -0
- data/lib/fog/hp/docs/install.md +133 -0
- data/lib/fog/hp/examples/block_storage.md +296 -0
- data/lib/fog/hp/examples/block_storage_v2.md +446 -0
- data/lib/fog/hp/examples/cdn.md +54 -0
- data/lib/fog/hp/examples/compute.md +794 -0
- data/lib/fog/hp/examples/compute_v2.md +848 -0
- data/lib/fog/hp/examples/getting_started_examples.md +30 -0
- data/lib/fog/hp/examples/networking.md +472 -0
- data/lib/fog/hp/examples/object_storage.md +387 -0
- data/lib/fog/json.rb +6 -3
- data/lib/fog/local/models/storage/directories.rb +8 -4
- data/lib/fog/openstack/compute.rb +3 -0
- data/lib/fog/openstack/examples/compute/basics.rb +74 -0
- data/lib/fog/openstack/identity.rb +2 -3
- data/lib/fog/openstack/image.rb +1 -4
- data/lib/fog/openstack/metering.rb +1 -4
- data/lib/fog/openstack/models/compute/host.rb +5 -1
- data/lib/fog/openstack/models/compute/security_group.rb +18 -4
- data/lib/fog/openstack/models/compute/security_group_rule.rb +32 -0
- data/lib/fog/openstack/models/compute/security_group_rules.rb +22 -0
- data/lib/fog/openstack/models/volume/volume_type.rb +20 -0
- data/lib/fog/openstack/models/volume/volume_types.rb +26 -0
- data/lib/fog/openstack/network.rb +34 -6
- data/lib/fog/openstack/requests/compute/add_flavor_access.rb +1 -1
- data/lib/fog/openstack/requests/compute/allocate_address.rb +1 -1
- data/lib/fog/openstack/requests/compute/attach_volume.rb +1 -1
- data/lib/fog/openstack/requests/compute/boot_from_snapshot.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_flavor.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_key_pair.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_security_group.rb +4 -4
- data/lib/fog/openstack/requests/compute/create_security_group_rule.rb +2 -2
- data/lib/fog/openstack/requests/compute/create_server.rb +12 -5
- data/lib/fog/openstack/requests/compute/create_volume.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_volume_snapshot.rb +1 -1
- data/lib/fog/openstack/requests/compute/delete_security_group.rb +1 -1
- data/lib/fog/openstack/requests/compute/delete_security_group_rule.rb +2 -0
- data/lib/fog/openstack/requests/compute/get_security_group.rb +14 -24
- data/lib/fog/openstack/requests/compute/get_security_group_rule.rb +38 -0
- data/lib/fog/openstack/requests/compute/list_hosts.rb +3 -3
- data/lib/fog/openstack/requests/compute/list_tenants.rb +1 -1
- data/lib/fog/openstack/requests/compute/remove_flavor_access.rb +1 -1
- data/lib/fog/openstack/requests/compute/update_quota.rb +1 -1
- data/lib/fog/openstack/requests/identity/create_ec2_credential.rb +1 -1
- data/lib/fog/openstack/requests/identity/create_role.rb +1 -1
- data/lib/fog/openstack/requests/identity/create_user.rb +1 -1
- data/lib/fog/openstack/requests/identity/update_user.rb +1 -1
- data/lib/fog/openstack/requests/image/update_image_members.rb +1 -1
- data/lib/fog/openstack/requests/orchestration/create_stack.rb +2 -2
- data/lib/fog/openstack/requests/orchestration/update_stack.rb +1 -1
- data/lib/fog/openstack/requests/storage/get_object_http_url.rb +13 -0
- data/lib/fog/openstack/requests/storage/get_object_https_url.rb +0 -14
- data/lib/fog/openstack/requests/volume/create_volume.rb +1 -1
- data/lib/fog/openstack/requests/volume/create_volume_snapshot.rb +1 -1
- data/lib/fog/openstack/requests/volume/get_volume_type_details.rb +32 -0
- data/lib/fog/openstack/requests/volume/list_volume_types.rb +41 -0
- data/lib/fog/openstack/storage.rb +2 -0
- data/lib/fog/openstack/volume.rb +9 -5
- data/lib/fog/rackspace/compute.rb +1 -4
- data/lib/fog/rackspace/compute_v2.rb +1 -0
- data/lib/fog/rackspace/docs/auto_scale.md +9 -9
- data/lib/fog/rackspace/docs/getting_started.md +1 -0
- data/lib/fog/rackspace/docs/queues.md +312 -0
- data/lib/fog/rackspace/examples/queues/claim_messages.rb +60 -0
- data/lib/fog/rackspace/examples/queues/create_queue.rb +45 -0
- data/lib/fog/rackspace/examples/queues/delete_message.rb +72 -0
- data/lib/fog/rackspace/examples/queues/delete_queue.rb +53 -0
- data/lib/fog/rackspace/examples/queues/list_messages.rb +64 -0
- data/lib/fog/rackspace/examples/queues/post_message.rb +59 -0
- data/lib/fog/rackspace/models/compute_v2/key_pairs.rb +1 -1
- data/lib/fog/rackspace/models/compute_v2/server.rb +9 -3
- data/lib/fog/rackspace/models/compute_v2/servers.rb +2 -2
- data/lib/fog/rackspace/models/identity/service_catalog.rb +44 -59
- data/lib/fog/rackspace/models/queues/claim.rb +41 -1
- data/lib/fog/rackspace/models/queues/claims.rb +25 -0
- data/lib/fog/rackspace/models/queues/message.rb +43 -5
- data/lib/fog/rackspace/models/queues/messages.rb +37 -0
- data/lib/fog/rackspace/models/queues/queue.rb +66 -3
- data/lib/fog/rackspace/models/queues/queues.rb +15 -0
- data/lib/fog/rackspace/models/storage/file.rb +8 -1
- data/lib/fog/rackspace/requests/compute_v2/delete_keypair.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/get_keypair.rb +1 -1
- data/lib/fog/rackspace/requests/queues/create_claim.rb +15 -0
- data/lib/fog/rackspace/requests/queues/create_message.rb +15 -0
- data/lib/fog/rackspace/requests/queues/create_queue.rb +11 -0
- data/lib/fog/rackspace/requests/queues/delete_claim.rb +12 -0
- data/lib/fog/rackspace/requests/queues/delete_message.rb +14 -0
- data/lib/fog/rackspace/requests/queues/delete_queue.rb +10 -0
- data/lib/fog/rackspace/requests/queues/get_claim.rb +11 -0
- data/lib/fog/rackspace/requests/queues/get_message.rb +12 -0
- data/lib/fog/rackspace/requests/queues/get_queue.rb +10 -0
- data/lib/fog/rackspace/requests/queues/get_queue_stats.rb +10 -0
- data/lib/fog/rackspace/requests/queues/list_messages.rb +26 -0
- data/lib/fog/rackspace/requests/queues/list_queues.rb +17 -2
- data/lib/fog/rackspace/requests/queues/update_claim.rb +7 -0
- data/lib/fog/rackspace/service.rb +6 -2
- data/lib/fog/rackspace/storage.rb +1 -4
- data/lib/fog/riakcs.rb +2 -2
- data/lib/fog/riakcs/provisioning.rb +1 -3
- data/lib/fog/riakcs/requests/provisioning/create_user.rb +2 -2
- data/lib/fog/riakcs/requests/provisioning/get_user.rb +1 -1
- data/lib/fog/riakcs/requests/provisioning/list_users.rb +1 -1
- data/lib/fog/riakcs/requests/usage/get_usage.rb +1 -1
- data/lib/fog/riakcs/usage.rb +0 -2
- data/lib/fog/vcloud_director/README.md +2 -0
- data/lib/fog/vcloud_director/compute.rb +79 -8
- data/lib/fog/vcloud_director/generators/compute/org_vdc_network.rb +91 -0
- data/lib/fog/vcloud_director/generators/compute/vapp.rb +30 -0
- data/lib/fog/vcloud_director/generators/compute/vm.rb +33 -0
- data/lib/fog/vcloud_director/models/compute/medias.rb +1 -1
- data/lib/fog/vcloud_director/models/compute/vm_customization.rb +2 -0
- data/lib/fog/vcloud_director/parsers/compute/vm_customization.rb +2 -0
- data/lib/fog/vcloud_director/requests/compute/delete_network.rb +64 -0
- data/lib/fog/vcloud_director/requests/compute/get_execute_query.rb +433 -333
- data/lib/fog/vcloud_director/requests/compute/get_vapp_metadata.rb +3 -1
- data/lib/fog/vcloud_director/requests/compute/post_attach_disk.rb +1 -1
- data/lib/fog/vcloud_director/requests/compute/post_configure_edge_gateway_services.rb +20 -2
- data/lib/fog/vcloud_director/requests/compute/post_create_org_vdc_network.rb +176 -0
- data/lib/fog/vcloud_director/requests/compute/post_detach_disk.rb +1 -1
- data/lib/fog/vcloud_director/requests/compute/post_eject_cd_rom.rb +1 -1
- data/lib/fog/vcloud_director/requests/compute/post_insert_cd_rom.rb +1 -1
- data/lib/fog/vcloud_director/requests/compute/put_guest_customization_section_vapp.rb +1 -0
- data/lib/fog/vcloud_director/requests/compute/put_vapp_name_and_description.rb +37 -0
- data/lib/fog/vcloud_director/requests/compute/put_vm.rb +39 -0
- data/lib/fog/version.rb +1 -1
- data/lib/fog/vsphere/compute.rb +3 -0
- data/lib/fog/vsphere/models/compute/datastore.rb +1 -0
- data/lib/fog/vsphere/models/compute/interface.rb +50 -2
- data/lib/fog/vsphere/models/compute/interfaces.rb +25 -10
- data/lib/fog/vsphere/models/compute/scsicontroller.rb +19 -0
- data/lib/fog/vsphere/models/compute/server.rb +27 -8
- data/lib/fog/vsphere/requests/compute/create_vm.rb +34 -8
- data/lib/fog/vsphere/requests/compute/get_vm_first_scsi_controller.rb +26 -0
- data/lib/fog/vsphere/requests/compute/list_datastores.rb +9 -8
- data/lib/fog/vsphere/requests/compute/modify_vm_interface.rb +9 -6
- data/lib/fog/vsphere/requests/compute/set_vm_customvalue.rb +19 -0
- data/lib/fog/xenserver.rb +2 -1
- data/lib/fog/xenserver/compute.rb +37 -1
- data/lib/fog/xenserver/models/compute/blob.rb +22 -0
- data/lib/fog/xenserver/models/compute/blobs.rb +25 -0
- data/lib/fog/xenserver/models/compute/bond.rb +23 -0
- data/lib/fog/xenserver/models/compute/bonds.rb +25 -0
- data/lib/fog/xenserver/models/compute/console.rb +3 -1
- data/lib/fog/xenserver/models/compute/crash_dump.rb +19 -0
- data/lib/fog/xenserver/models/compute/crash_dumps.rb +25 -0
- data/lib/fog/xenserver/models/compute/dr_task.rb +17 -0
- data/lib/fog/xenserver/models/compute/dr_tasks.rb +25 -0
- data/lib/fog/xenserver/models/compute/gpu_group.rb +22 -0
- data/lib/fog/xenserver/models/compute/gpu_groups.rb +25 -0
- data/lib/fog/xenserver/models/compute/guest_metrics.rb +2 -1
- data/lib/fog/xenserver/models/compute/host.rb +41 -8
- data/lib/fog/xenserver/models/compute/host_cpu.rb +2 -1
- data/lib/fog/xenserver/models/compute/host_crash_dump.rb +20 -0
- data/lib/fog/xenserver/models/compute/host_crash_dumps.rb +25 -0
- data/lib/fog/xenserver/models/compute/host_metrics.rb +1 -1
- data/lib/fog/xenserver/models/compute/host_patch.rb +25 -0
- data/lib/fog/xenserver/models/compute/host_patchs.rb +25 -0
- data/lib/fog/xenserver/models/compute/network.rb +7 -6
- data/lib/fog/xenserver/models/compute/pbd.rb +3 -1
- data/lib/fog/xenserver/models/compute/pci.rb +22 -0
- data/lib/fog/xenserver/models/compute/pcis.rb +25 -0
- data/lib/fog/xenserver/models/compute/pgpu.rb +20 -0
- data/lib/fog/xenserver/models/compute/pgpus.rb +25 -0
- data/lib/fog/xenserver/models/compute/pif.rb +19 -8
- data/lib/fog/xenserver/models/compute/pif_metrics.rb +28 -0
- data/lib/fog/xenserver/models/compute/pifs_metrics.rb +25 -0
- data/lib/fog/xenserver/models/compute/pool.rb +18 -1
- data/lib/fog/xenserver/models/compute/pool_patch.rb +24 -0
- data/lib/fog/xenserver/models/compute/pool_patchs.rb +25 -0
- data/lib/fog/xenserver/models/compute/role.rb +19 -0
- data/lib/fog/xenserver/models/compute/roles.rb +25 -0
- data/lib/fog/xenserver/models/compute/server.rb +59 -26
- data/lib/fog/xenserver/models/compute/server_appliance.rb +21 -0
- data/lib/fog/xenserver/models/compute/server_appliances.rb +25 -0
- data/lib/fog/xenserver/models/compute/storage_manager.rb +28 -0
- data/lib/fog/xenserver/models/compute/storage_managers.rb +25 -0
- data/lib/fog/xenserver/models/compute/storage_repository.rb +4 -1
- data/lib/fog/xenserver/models/compute/tunnel.rb +20 -0
- data/lib/fog/xenserver/models/compute/tunnels.rb +25 -0
- data/lib/fog/xenserver/models/compute/vbd.rb +3 -2
- data/lib/fog/xenserver/models/compute/vbd_metrics.rb +1 -1
- data/lib/fog/xenserver/models/compute/vdi.rb +4 -1
- data/lib/fog/xenserver/models/compute/vif.rb +11 -2
- data/lib/fog/xenserver/models/compute/vlan.rb +2 -1
- data/lib/fog/xenserver/models/compute/vmpp.rb +35 -0
- data/lib/fog/xenserver/models/compute/vmpps.rb +25 -0
- data/lib/fog/xenserver/models/compute/vtpm.rb +18 -0
- data/lib/fog/xenserver/models/compute/vtpms.rb +25 -0
- data/lib/fog/xenserver/requests/compute/reboot_server.rb +1 -1
- data/lib/tasks/changelog_task.rb +0 -1
- data/tests/aws/models/dns/record_tests.rb +1 -2
- data/tests/aws/models/dns/records_tests.rb +2 -7
- data/tests/aws/models/dns/zone_tests.rb +1 -1
- data/tests/aws/models/dns/zones_tests.rb +1 -1
- data/tests/aws/models/elb/model_tests.rb +10 -0
- data/tests/aws/models/storage/file_tests.rb +4 -0
- data/tests/aws/requests/compute/assign_private_ip_tests.rb +52 -0
- data/tests/aws/requests/compute/vpc_tests.rb +17 -1
- data/tests/aws/requests/dns/dns_tests.rb +1 -26
- data/tests/aws/requests/elb/load_balancer_tests.rb +6 -0
- data/tests/aws/requests/rds/{subnet_groups_test.rb → subnet_groups_tests.rb} +4 -0
- data/tests/aws/requests/storage/bucket_tests.rb +17 -0
- data/tests/aws/requests/storage/delete_multiple_objects_tests.rb +12 -0
- data/tests/brightbox/compute/schema.rb +0 -13
- data/tests/brightbox/models/compute/server_tests.rb +7 -9
- data/tests/brightbox/requests/compute/interface_tests.rb +7 -19
- data/tests/digitalocean/models/compute/server_tests.rb +4 -3
- data/tests/google/models/compute/disk_tests.rb +5 -0
- data/tests/google/models/compute/disks_tests.rb +5 -0
- data/tests/google/models/compute/server_tests.rb +5 -1
- data/tests/google/models/compute/servers_tests.rb +5 -0
- data/tests/google/requests/compute/disk_tests.rb +2 -1
- data/tests/google/requests/compute/firewall_tests.rb +1 -0
- data/tests/google/requests/compute/image_tests.rb +3 -0
- data/tests/google/requests/compute/network_tests.rb +1 -0
- data/tests/google/requests/compute/operation_tests.rb +1 -0
- data/tests/google/requests/compute/server_tests.rb +2 -3
- data/tests/google/requests/compute/zone_tests.rb +1 -6
- data/tests/helpers/collection_helper.rb +10 -2
- data/tests/helpers/mock_helper.rb +4 -5
- data/tests/local/models/directories_tests.rb +17 -0
- data/tests/openstack/models/compute/security_group_tests.rb +54 -0
- data/tests/openstack/requests/compute/security_group_tests.rb +22 -20
- data/tests/openstack/requests/network/network_tests.rb +8 -8
- data/tests/rackspace/compute_tests.rb +0 -5
- data/tests/rackspace/helper.rb +9 -4
- data/tests/rackspace/models/compute_v2/server_tests.rb +29 -1
- data/tests/rackspace/models/identity/service_catalog_tests.rb +87 -39
- data/tests/rackspace/models/queues/message_tests.rb +16 -0
- data/tests/rackspace/models/storage/file_tests.rb +29 -0
- data/tests/rackspace/requests/compute_v2/address_tests.rb +3 -1
- data/tests/rackspace/requests/compute_v2/metadata_tests.rb +4 -2
- data/tests/rackspace/requests/compute_v2/server_tests.rb +3 -6
- data/tests/vcloud_director/models/compute/media_tests.rb +18 -5
- data/tests/vcloud_director/models/compute/vapp_tests.rb +3 -1
- data/tests/vcloud_director/models/compute/vms_tests.rb +2 -1
- data/tests/vcloud_director/requests/compute/edge_gateway_tests.rb +19 -10
- data/tests/vcloud_director/requests/compute/network_tests.rb +64 -3
- data/tests/vcloud_director/requests/compute/query_tests.rb +67 -2
- data/tests/vsphere/requests/compute/set_vm_customvalue_tests.rb +21 -0
- metadata +112 -11
- data/fogkeytest1.pem +0 -27
- data/lib/fog/hp/README_HP.rdoc +0 -61
@@ -32,4 +32,20 @@ Shindo.tests('Fog::Rackspace::Queues | message', ['rackspace']) do
|
|
32
32
|
ensure
|
33
33
|
queue.destroy
|
34
34
|
end
|
35
|
+
|
36
|
+
tests('identity') do
|
37
|
+
tests('nil') do
|
38
|
+
message = Fog::Rackspace::Queues::Message.new :href => nil
|
39
|
+
returns(nil) { message.id }
|
40
|
+
end
|
41
|
+
tests('with claim id') do
|
42
|
+
message = Fog::Rackspace::Queues::Message.new :href => '/v1/queues/queue1/messages/528b7e4bb04a584f2eb805a3?claim_id=528b7e6aef913e6d2977ee6d'
|
43
|
+
returns('528b7e4bb04a584f2eb805a3') { message.id }
|
44
|
+
end
|
45
|
+
tests('without claim id') do
|
46
|
+
message = Fog::Rackspace::Queues::Message.new :href => '/v1/queues/queue1/messages/528b7e4bb04a584f2eb805a3'
|
47
|
+
returns('528b7e4bb04a584f2eb805a3') { message.id }
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
35
51
|
end
|
@@ -314,6 +314,35 @@ Shindo.tests('Fog::Rackspace::Storage | file', ['rackspace']) do
|
|
314
314
|
|
315
315
|
end
|
316
316
|
|
317
|
+
tests("#content_encoding") do
|
318
|
+
|
319
|
+
tests("#content_encoding should default to nil").returns(nil) do
|
320
|
+
@instance.save
|
321
|
+
@instance.content_encoding
|
322
|
+
end
|
323
|
+
|
324
|
+
@instance.content_encoding = 'gzip'
|
325
|
+
@instance.save
|
326
|
+
tests("#content_encoding should return the content encoding").returns('gzip') do
|
327
|
+
@instance.content_encoding
|
328
|
+
end
|
329
|
+
@instance.attributes.delete('content_encoding')
|
330
|
+
|
331
|
+
@instance.content_encoding = 'foo'
|
332
|
+
@instance.save
|
333
|
+
tests("#content_encoding= should update content_encoding").returns('bar') do
|
334
|
+
@instance.content_encoding = 'bar'
|
335
|
+
@instance.save
|
336
|
+
@instance.content_encoding
|
337
|
+
end
|
338
|
+
|
339
|
+
tests("#content_encoding= should not blow up on nil") do
|
340
|
+
@instance.content_encoding = nil
|
341
|
+
@instance.save
|
342
|
+
end
|
343
|
+
|
344
|
+
end
|
345
|
+
|
317
346
|
end
|
318
347
|
|
319
348
|
@directory.destroy
|
@@ -1,10 +1,12 @@
|
|
1
1
|
Shindo.tests('Fog::Compute::RackspaceV2 | address requests', ['rackspace']) do
|
2
2
|
|
3
3
|
@service = Fog::Compute.new(:provider => 'Rackspace', :version => 'V2')
|
4
|
+
image_id = rackspace_test_image_id(@service)
|
5
|
+
flavor_id = rackspace_test_flavor_id(@service)
|
4
6
|
|
5
7
|
tests('success') do
|
6
8
|
unless Fog.mocking?
|
7
|
-
@server = @service.servers.create(:flavor_id =>
|
9
|
+
@server = @service.servers.create(:flavor_id => flavor_id, :image_id => image_id, :name => "address-tests-#{Time.now.to_i}")
|
8
10
|
@server.wait_for { ready? }
|
9
11
|
@server_id = @server.id
|
10
12
|
else
|
@@ -1,6 +1,8 @@
|
|
1
1
|
Shindo.tests('Fog::Compute::RackspaceV2 | metadata_tests', ['rackspace']) do
|
2
2
|
|
3
3
|
@service = Fog::Compute.new(:provider => 'Rackspace', :version => 'V2')
|
4
|
+
image_id = rackspace_test_image_id(@service)
|
5
|
+
flavor_id = rackspace_test_flavor_id(@service)
|
4
6
|
|
5
7
|
tests('success') do
|
6
8
|
begin
|
@@ -9,8 +11,8 @@ Shindo.tests('Fog::Compute::RackspaceV2 | metadata_tests', ['rackspace']) do
|
|
9
11
|
unless Fog.mocking?
|
10
12
|
name = "fog-server-metadata-#{Time.now.to_i}"
|
11
13
|
@server = @service.servers.create(:name => name,
|
12
|
-
:flavor_id =>
|
13
|
-
:image_id =>
|
14
|
+
:flavor_id => flavor_id,
|
15
|
+
:image_id => image_id,
|
14
16
|
:metadata => metadata)
|
15
17
|
@server.wait_for { ready? }
|
16
18
|
|
@@ -1,8 +1,5 @@
|
|
1
1
|
Shindo.tests('Fog::Compute::RackspaceV2 | server_tests', ['rackspace']) do
|
2
2
|
service = Fog::Compute.new(:provider => 'Rackspace', :version => 'V2')
|
3
|
-
image_id = Fog.credentials[:rackspace_image_id]
|
4
|
-
image_id ||= Fog.mocking? ? service.images.first.id : service.images.find {|image| image.name =~ /Ubuntu/}.id # use the first Ubuntu image
|
5
|
-
flavor_id = Fog.credentials[:rackspace_flavor_id] || service.flavors.first.id
|
6
3
|
|
7
4
|
link_format = {
|
8
5
|
'href' => String,
|
@@ -62,8 +59,8 @@ Shindo.tests('Fog::Compute::RackspaceV2 | server_tests', ['rackspace']) do
|
|
62
59
|
|
63
60
|
server_id = nil
|
64
61
|
server_name = "fog#{Time.now.to_i.to_s}"
|
65
|
-
image_id =
|
66
|
-
flavor_id =
|
62
|
+
image_id = rackspace_test_image_id(service)
|
63
|
+
flavor_id = rackspace_test_flavor_id(service)
|
67
64
|
|
68
65
|
tests("#create_server(#{server_name}, #{image_id}, #{flavor_id}, 1, 1)").formats(create_server_format) do
|
69
66
|
body = service.create_server(server_name, image_id, flavor_id, 1, 1).body
|
@@ -117,7 +114,7 @@ Shindo.tests('Fog::Compute::RackspaceV2 | server_tests', ['rackspace']) do
|
|
117
114
|
wait_for_server_state(service, server_id, 'ACTIVE', 'ERROR')
|
118
115
|
|
119
116
|
tests('#resize_server').succeeds do
|
120
|
-
resize_flavor_id = Fog.mocking? ? flavor_id : service.flavors[
|
117
|
+
resize_flavor_id = Fog.mocking? ? flavor_id : service.flavors[2].id
|
121
118
|
service.resize_server(server_id, resize_flavor_id)
|
122
119
|
end
|
123
120
|
wait_for_server_state(service, server_id, 'VERIFY_RESIZE', 'ACTIVE')
|
@@ -4,8 +4,17 @@ Shindo.tests('Compute::VcloudDirector | media', ['vclouddirector']) do
|
|
4
4
|
pending if Fog.mocking?
|
5
5
|
|
6
6
|
medias = vdc.medias
|
7
|
-
|
8
|
-
|
7
|
+
media_name = VcloudDirector::Compute::Helper.test_name
|
8
|
+
|
9
|
+
tests('Compute::VcloudDirector | media', ['create']) do
|
10
|
+
tests('#create').returns(Fog::Compute::VcloudDirector::Media) do
|
11
|
+
File.open(VcloudDirector::Compute::Helper.fixture('test.iso'), 'rb') do |iso|
|
12
|
+
medias.create(media_name, iso).class
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
media = medias.get_by_name(media_name)
|
9
18
|
|
10
19
|
tests('Compute::VcloudDirector | media') do
|
11
20
|
tests('#href').returns(String) { media.href.class }
|
@@ -21,9 +30,9 @@ Shindo.tests('Compute::VcloudDirector | media', ['vclouddirector']) do
|
|
21
30
|
end
|
22
31
|
|
23
32
|
tests('Compute::VcloudDirector | media', ['load on demand']) do
|
24
|
-
tests(
|
25
|
-
tests(
|
26
|
-
tests(
|
33
|
+
tests('#description is not loaded yet').returns(NonLoaded) { media.attributes[:description] }
|
34
|
+
tests('#description is loaded on demand').returns(String) { media.description.class }
|
35
|
+
tests('#description is now loaded').returns(true) { media.attributes[:description] != NonLoaded }
|
27
36
|
end
|
28
37
|
|
29
38
|
tests('Compute::VcloudDirector | media', ['lazy load attrs']) do
|
@@ -42,4 +51,8 @@ Shindo.tests('Compute::VcloudDirector | media', ['vclouddirector']) do
|
|
42
51
|
tests('#get_by_name').returns(media.name) { medias.get_by_name(media.name).name }
|
43
52
|
tests('#get').returns(media.id) { medias.get(media.id).id }
|
44
53
|
end
|
54
|
+
|
55
|
+
tests('Compute::VcloudDirector | media', ['destroy']) do
|
56
|
+
tests('#destroy').returns(true) { media.destroy }
|
57
|
+
end
|
45
58
|
end
|
@@ -2,7 +2,9 @@ require File.expand_path(File.join(File.dirname(__FILE__), 'helper'))
|
|
2
2
|
|
3
3
|
Shindo.tests("Compute::VcloudDirector | vapps", ['vclouddirector', 'all']) do
|
4
4
|
pending if Fog.mocking?
|
5
|
-
|
5
|
+
|
6
|
+
# unless there is atleast one vapp we cannot run these tests
|
7
|
+
pending if vdc.vapps.empty?
|
6
8
|
|
7
9
|
vapps = vdc.vapps
|
8
10
|
vapp = vapps.first
|
@@ -4,7 +4,8 @@ Shindo.tests("Compute::VcloudDirector | vms", ['vclouddirector', 'all']) do
|
|
4
4
|
pending if Fog.mocking?
|
5
5
|
vapp = vapps.detect {|v| v.vms.size >= 1}
|
6
6
|
|
7
|
-
|
7
|
+
# we can't run these tests if there is no vapps with a vm in them
|
8
|
+
pending unless vapp
|
8
9
|
|
9
10
|
vms = vapp.vms
|
10
11
|
vm = vms.first
|
@@ -34,11 +34,17 @@ Shindo.tests('Compute::VcloudDirector | edge gateway requests', ['vclouddirector
|
|
34
34
|
@service = Fog::Compute::VcloudDirector.new
|
35
35
|
@org = VcloudDirector::Compute::Helper.current_org(@service)
|
36
36
|
|
37
|
-
tests('Get first vDC') do
|
38
|
-
|
39
|
-
l[:type] == 'application/vnd.vmware.vcloud.vdc+xml'
|
37
|
+
tests('Get first vDC with an EdgeGatewayRecord') do
|
38
|
+
@org[:Link].each do |l|
|
39
|
+
if l[:type] == 'application/vnd.vmware.vcloud.vdc+xml'
|
40
|
+
id = l[:href].split('/').last
|
41
|
+
edge_gateways = @service.get_org_vdc_gateways(id).body
|
42
|
+
if edge_gateways && edge_gateways[:EdgeGatewayRecord].size >= 1
|
43
|
+
@vdc_id = id
|
44
|
+
break
|
45
|
+
end
|
46
|
+
end
|
40
47
|
end
|
41
|
-
@vdc_id = link[:href].split('/').last
|
42
48
|
end
|
43
49
|
|
44
50
|
tests('#get_org_vdc_gateways').data_matches_schema(VcloudDirector::Compute::Schema::QUERY_RESULT_RECORDS_TYPE) do
|
@@ -52,21 +58,24 @@ Shindo.tests('Compute::VcloudDirector | edge gateway requests', ['vclouddirector
|
|
52
58
|
|
53
59
|
@edge_gateways[:EdgeGatewayRecord].each do |result|
|
54
60
|
tests("each EdgeGatewayRecord").
|
55
|
-
data_matches_schema(VcloudDirector::Compute::Schema::QUERY_RESULT_EDGE_GATEWAY_RECORD_TYPE)
|
61
|
+
data_matches_schema(VcloudDirector::Compute::Schema::QUERY_RESULT_EDGE_GATEWAY_RECORD_TYPE) do
|
62
|
+
result
|
63
|
+
end
|
56
64
|
end
|
57
65
|
|
58
66
|
tests('#get_edge_gateway').data_matches_schema(VcloudDirector::Compute::Schema::GATEWAY_TYPE) do
|
59
67
|
@edge_gateway_id = @edge_gateways[:EdgeGatewayRecord].first[:href].split('/').last
|
60
|
-
@
|
68
|
+
@original_gateway_conf = @service.get_edge_gateway(@edge_gateway_id).body
|
61
69
|
end
|
62
70
|
|
71
|
+
|
63
72
|
tests('#configure_edge_gateway_services') do
|
64
73
|
|
65
|
-
rule = @
|
74
|
+
rule = @original_gateway_conf[:Configuration][:EdgeGatewayServiceConfiguration][:FirewallService][:FirewallRule].find { |rule| rule[:Id] == FIREWALL_RULE_ID }
|
66
75
|
raise('fail fast if our test firewall rule already exists - its likely left over from a broken test run') if rule
|
67
76
|
|
68
77
|
response = @service.post_configure_edge_gateway_services(@edge_gateway_id, @new_edge_gateway_configuration)
|
69
|
-
@service.process_task(response.body)
|
78
|
+
@service.process_task(response.body)
|
70
79
|
|
71
80
|
tests('#check for new firewall rule').returns(@new_edge_gateway_configuration[:FirewallService][:FirewallRule]) do
|
72
81
|
edge_gateway = @service.get_edge_gateway(@edge_gateway_id).body
|
@@ -75,8 +84,8 @@ Shindo.tests('Compute::VcloudDirector | edge gateway requests', ['vclouddirector
|
|
75
84
|
|
76
85
|
tests('#remove the firewall rule added by test').returns(nil) do
|
77
86
|
response = @service.post_configure_edge_gateway_services(@edge_gateway_id,
|
78
|
-
@
|
79
|
-
@service.process_task(response.body)
|
87
|
+
@original_gateway_conf[:Configuration][:EdgeGatewayServiceConfiguration])
|
88
|
+
@service.process_task(response.body)
|
80
89
|
edge_gateway = @service.get_edge_gateway(@edge_gateway_id).body
|
81
90
|
edge_gateway[:Configuration][:EdgeGatewayServiceConfiguration][:FirewallService][:FirewallRule].find { |rule| rule[:Id] == FIREWALL_RULE_ID }
|
82
91
|
end
|
@@ -1,3 +1,6 @@
|
|
1
|
+
|
2
|
+
require 'pp'
|
3
|
+
|
1
4
|
Shindo.tests('Compute::VcloudDirector | network requests', ['vclouddirector']) do
|
2
5
|
|
3
6
|
GET_NETWORK_FORMAT = {
|
@@ -7,7 +10,7 @@ Shindo.tests('Compute::VcloudDirector | network requests', ['vclouddirector']) d
|
|
7
10
|
:id => String,
|
8
11
|
:description => Fog::Nullable::String,
|
9
12
|
:is_inherited => Fog::Boolean,
|
10
|
-
:gateway => String,
|
13
|
+
:gateway => Fog::Nullable::String,
|
11
14
|
:netmask => String,
|
12
15
|
:dns1 => Fog::Nullable::String,
|
13
16
|
:dns2 => Fog::Nullable::String,
|
@@ -20,6 +23,19 @@ Shindo.tests('Compute::VcloudDirector | network requests', ['vclouddirector']) d
|
|
20
23
|
|
21
24
|
@service = Fog::Compute::VcloudDirector.new
|
22
25
|
@org = VcloudDirector::Compute::Helper.current_org(@service)
|
26
|
+
@created_net_id = nil
|
27
|
+
|
28
|
+
tests('Create network in non-existent vDC').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
29
|
+
@service.post_create_org_vdc_network('00000000-0000-0000-0000-000000000000', 'bob')
|
30
|
+
end
|
31
|
+
|
32
|
+
tests('Delete non-existent OrgNetwork').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
33
|
+
@service.delete_network('00000000-0000-0000-0000-000000000000')
|
34
|
+
end
|
35
|
+
|
36
|
+
tests('Retrieve non-existent OrgNetwork').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
37
|
+
@service.get_network('00000000-0000-0000-0000-000000000000')
|
38
|
+
end
|
23
39
|
|
24
40
|
tests('#get_network').data_matches_schema(GET_NETWORK_FORMAT) do
|
25
41
|
link = @org[:Link].detect do |l|
|
@@ -36,8 +52,53 @@ Shindo.tests('Compute::VcloudDirector | network requests', ['vclouddirector']) d
|
|
36
52
|
@service.get_network_metadata(@network_id).body
|
37
53
|
end
|
38
54
|
|
39
|
-
tests('
|
40
|
-
|
55
|
+
tests('#post_create_org_vdc_network') do
|
56
|
+
pending unless Fog.mocking?
|
57
|
+
link = @org[:Link].detect do |l|
|
58
|
+
l[:rel] == 'down' && l[:type] == 'application/vnd.vmware.vcloud.vdc+xml'
|
59
|
+
end
|
60
|
+
|
61
|
+
vdc_id = link[:href].split('/').last
|
62
|
+
name = VcloudDirector::Compute::Helper.test_name
|
63
|
+
|
64
|
+
options = {
|
65
|
+
:Description => "Testing post_create_org_vdc_network #{name}",
|
66
|
+
:Configuration => {
|
67
|
+
:IpScopes => {
|
68
|
+
:IpScope => {
|
69
|
+
:IsInherited => 'false',
|
70
|
+
:Gateway => '198.51.100.1',
|
71
|
+
:Netmask => '255.255.255.0',
|
72
|
+
:Dns1 => '198.51.100.2',
|
73
|
+
:Dns2 => '198.51.100.3',
|
74
|
+
:DnsSuffix => 'example.com',
|
75
|
+
:IpRanges => [
|
76
|
+
{ :IpRange => { :StartAddress => '198.51.100.10', :EndAddress => '198.51.100.20' } },
|
77
|
+
{ :IpRange => { :StartAddress => '198.51.100.30', :EndAddress => '198.51.100.40' } },
|
78
|
+
]
|
79
|
+
},
|
80
|
+
},
|
81
|
+
:FenceMode => 'isolated',
|
82
|
+
}
|
83
|
+
}
|
84
|
+
|
85
|
+
body = @service.post_create_org_vdc_network(vdc_id, name, options).body
|
86
|
+
@created_net_id = body[:href].split('/').last if body[:href]
|
87
|
+
@service.process_task(body[:Tasks][:Task]) if body && body.key?(:Tasks)
|
88
|
+
|
89
|
+
tests('fetched name matches created name').returns(name) do
|
90
|
+
net = @service.get_network(@created_net_id).body
|
91
|
+
net[:name]
|
92
|
+
end
|
93
|
+
end
|
94
|
+
|
95
|
+
tests('#delete_network') do
|
96
|
+
pending unless Fog.mocking?
|
97
|
+
@delete_task = @service.delete_network(@created_net_id).body
|
98
|
+
@service.process_task(@delete_task)
|
99
|
+
tests('created network has been deleted').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
100
|
+
@service.get_network(@created_net_id)
|
101
|
+
end
|
41
102
|
end
|
42
103
|
|
43
104
|
end
|
@@ -11,23 +11,88 @@ Shindo.tests('Compute::VcloudDirector | query requests', ['vclouddirector']) do
|
|
11
11
|
end
|
12
12
|
end
|
13
13
|
|
14
|
-
|
15
|
-
|
14
|
+
# for each queriable type, query and check that each available format
|
15
|
+
# returns a result that matches the base schema
|
16
|
+
#
|
16
17
|
@query_list[:Link].select do |link|
|
17
18
|
link[:rel] == 'down'
|
18
19
|
end.sort_by do |link|
|
19
20
|
[link[:name], link[:href]]
|
20
21
|
end.each do |link|
|
22
|
+
|
21
23
|
href = Nokogiri::XML.fragment(link[:href])
|
22
24
|
query = CGI.parse(URI.parse(href.text).query)
|
23
25
|
type = query['type'].first
|
24
26
|
format = query['format'].first
|
25
27
|
next if %w[right role strandedUser].include?(type)
|
26
28
|
tests("type => #{type}, format => #{format}") do
|
29
|
+
|
30
|
+
pending if Fog.mocking? && (format != 'records' || type != 'orgVdcNetwork')
|
31
|
+
|
27
32
|
tests("#get_execute_query").data_matches_schema(VcloudDirector::Compute::Schema::CONTAINER_TYPE) do
|
28
33
|
@body = @service.get_execute_query(type, :format => format).body
|
29
34
|
end
|
30
35
|
tests("resource type").returns(link[:type]) { @body[:type] }
|
36
|
+
|
37
|
+
unless ( type == 'event' || type == 'edgeGateway' )
|
38
|
+
records_key = @body.keys.detect {|key| key.to_s =~ /Record|Reference$/}
|
39
|
+
if records = @body[records_key]
|
40
|
+
records.first do |record|
|
41
|
+
case format
|
42
|
+
when 'records'
|
43
|
+
tests("record is correct schema").data_matches_schema(VcloudDirector::Compute::Schema::REFERENCE_TYPE) do
|
44
|
+
record
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
end
|
52
|
+
end
|
53
|
+
|
54
|
+
if Fog.mocking?
|
55
|
+
tests('ensure Mock logic is sound') do
|
56
|
+
tests('#get_execute_query') do
|
57
|
+
tests('orgVdcNetwork') do
|
58
|
+
output = @service.get_execute_query('orgVdcNetwork').body
|
59
|
+
tests('all records').returns(@service.data[:networks].size) do
|
60
|
+
output[:OrgVdcNetworkRecords].size
|
61
|
+
end
|
62
|
+
output = @service.get_execute_query('orgVdcNetwork', :filter => 'name==vDC1 backend network').body
|
63
|
+
tests(':filter by name').returns(1) do
|
64
|
+
output[:OrgVdcNetworkRecords].size
|
65
|
+
end
|
66
|
+
tests(':page option is ok if :page == 1').returns(@service.data[:networks].size) do
|
67
|
+
output = @service.get_execute_query('orgVdcNetwork', :page => '1').body
|
68
|
+
output[:OrgVdcNetworkRecords].size
|
69
|
+
end
|
70
|
+
tests('AND expression in :filter raises MockNotImplemented').raises(Fog::Errors::MockNotImplemented) do
|
71
|
+
@service.get_execute_query('orgVdcNetwork', :filter => 'name==Default Network;thing==wibble')
|
72
|
+
end
|
73
|
+
tests('OR expression in :filter raises MockNotImplemented').raises(Fog::Errors::MockNotImplemented) do
|
74
|
+
@service.get_execute_query('orgVdcNetwork', :filter => 'name==Default Network,thing==wibble')
|
75
|
+
end
|
76
|
+
tests('sortAsc option raises MockNotImplemented').raises(Fog::Errors::MockNotImplemented) do
|
77
|
+
@service.get_execute_query('orgVdcNetwork', :sortAsc => 'name')
|
78
|
+
end
|
79
|
+
tests('sortDesc option raises MockNotImplemented').raises(Fog::Errors::MockNotImplemented) do
|
80
|
+
@service.get_execute_query('orgVdcNetwork', :sortDesc => 'name')
|
81
|
+
end
|
82
|
+
tests('page option raises MockNotImplemented').raises(Fog::Errors::MockNotImplemented) do
|
83
|
+
@service.get_execute_query('orgVdcNetwork', :page => '2')
|
84
|
+
end
|
85
|
+
tests('pageSize option raises MockNotImplemented').raises(Fog::Errors::MockNotImplemented) do
|
86
|
+
@service.get_execute_query('orgVdcNetwork', :pageSize => '50')
|
87
|
+
end
|
88
|
+
tests('offset option raises MockNotImplemented').raises(Fog::Errors::MockNotImplemented) do
|
89
|
+
@service.get_execute_query('orgVdcNetwork', :offset => '5')
|
90
|
+
end
|
91
|
+
tests('fields option raises MockNotImplemented').raises(Fog::Errors::MockNotImplemented) do
|
92
|
+
@service.get_execute_query('orgVdcNetwork', :fields => 'name,thing')
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|
31
96
|
end
|
32
97
|
end
|
33
98
|
|
@@ -0,0 +1,21 @@
|
|
1
|
+
Shindo.tests('Fog::Compute[:vsphere] | set_vm_customvalue request', ['vsphere']) do
|
2
|
+
|
3
|
+
compute = Fog::Compute[:vsphere]
|
4
|
+
|
5
|
+
instance_uuid = '50137835-88a1-436e-768e-9b2677076e67'
|
6
|
+
custom_key = nil
|
7
|
+
custom_value = nil
|
8
|
+
|
9
|
+
tests('The response should') do
|
10
|
+
response = compute.set_vm_customvalue(instance_uuid, custom_key, custom_value)
|
11
|
+
test('be nil') { response.nil? }
|
12
|
+
end
|
13
|
+
|
14
|
+
tests('The expected options') do
|
15
|
+
raises(ArgumentError, 'raises ArgumentError when instance_uuid option is missing') { compute.set_vm_customvalue }
|
16
|
+
raises(ArgumentError, 'raises ArgumentError when custom_key option is missing') { compute.set_vm_customvalue(instance_uuid) }
|
17
|
+
raises(ArgumentError, 'raises ArgumentError when custom_value option is missing') { compute.set_vm_customvalue(instance_uuid, custom_key) }
|
18
|
+
end
|
19
|
+
|
20
|
+
end
|
21
|
+
|