fog 1.9.0 → 1.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/Gemfile +1 -1
 - data/README.md +1 -1
 - data/changelog.txt +743 -0
 - data/fog.gemspec +3 -5
 - data/lib/fog/aws.rb +1 -0
 - data/lib/fog/aws/credential_fetcher.rb +1 -1
 - data/lib/fog/aws/data_pipeline.rb +114 -0
 - data/lib/fog/aws/dynamodb.rb +1 -1
 - data/lib/fog/aws/models/compute/flavors.rb +1 -1
 - data/lib/fog/aws/models/compute/spot_request.rb +2 -0
 - data/lib/fog/aws/models/data_pipeline/pipeline.rb +67 -0
 - data/lib/fog/aws/models/data_pipeline/pipelines.rb +36 -0
 - data/lib/fog/aws/parsers/cloud_watch/list_metrics.rb +1 -1
 - data/lib/fog/aws/parsers/compute/describe_instances.rb +1 -1
 - data/lib/fog/aws/parsers/compute/spot_instance_requests.rb +2 -0
 - data/lib/fog/aws/requests/compute/request_spot_instances.rb +1 -0
 - data/lib/fog/aws/requests/data_pipeline/activate_pipeline.rb +35 -0
 - data/lib/fog/aws/requests/data_pipeline/create_pipeline.rb +41 -0
 - data/lib/fog/aws/requests/data_pipeline/delete_pipeline.rb +35 -0
 - data/lib/fog/aws/requests/data_pipeline/describe_pipelines.rb +36 -0
 - data/lib/fog/aws/requests/data_pipeline/list_pipelines.rb +36 -0
 - data/lib/fog/aws/requests/data_pipeline/put_pipeline_definition.rb +72 -0
 - data/lib/fog/aws/requests/rds/describe_db_instances.rb +8 -9
 - data/lib/fog/aws/requests/storage/get_service.rb +1 -2
 - data/lib/fog/aws/requests/storage/list_multipart_uploads.rb +3 -3
 - data/lib/fog/aws/requests/storage/put_bucket_policy.rb +2 -2
 - data/lib/fog/aws/storage.rb +1 -1
 - data/lib/fog/bin.rb +2 -1
 - data/lib/fog/bin/aws.rb +4 -0
 - data/lib/fog/bin/bluebox.rb +2 -0
 - data/lib/fog/bin/dreamhost.rb +31 -0
 - data/lib/fog/bin/hp.rb +7 -0
 - data/lib/fog/bin/internet_archive.rb +34 -0
 - data/lib/fog/bin/openstack.rb +17 -2
 - data/lib/fog/bluebox.rb +1 -0
 - data/lib/fog/bluebox/blb.rb +85 -0
 - data/lib/fog/bluebox/models/blb/lb_application.rb +32 -0
 - data/lib/fog/bluebox/models/blb/lb_applications.rb +26 -0
 - data/lib/fog/bluebox/models/blb/lb_backend.rb +22 -0
 - data/lib/fog/bluebox/models/blb/lb_backends.rb +30 -0
 - data/lib/fog/bluebox/models/blb/lb_service.rb +35 -0
 - data/lib/fog/bluebox/models/blb/lb_services.rb +29 -0
 - data/lib/fog/bluebox/requests/blb/add_machine_to_lb_application.rb +33 -0
 - data/lib/fog/bluebox/requests/blb/add_machine_to_lb_backend.rb +31 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_application.rb +33 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_applications.rb +31 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_backend.rb +36 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_backends.rb +36 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_machine.rb +35 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_machines.rb +35 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_service.rb +36 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_services.rb +36 -0
 - data/lib/fog/bluebox/requests/blb/remove_machine_from_lb_backend.rb +28 -0
 - data/lib/fog/bluebox/requests/blb/update_lb_backend_machine.rb +29 -0
 - data/lib/fog/brightbox/compute.rb +1 -0
 - data/lib/fog/brightbox/requests/compute/create_firewall_policy.rb +1 -0
 - data/lib/fog/brightbox/requests/compute/update_firewall_policy.rb +25 -0
 - data/lib/fog/brightbox/requests/compute/update_server.rb +1 -0
 - data/lib/fog/cdn.rb +5 -12
 - data/lib/fog/compute.rb +7 -68
 - data/lib/fog/core/errors.rb +5 -1
 - data/lib/fog/core/scp.rb +1 -0
 - data/lib/fog/core/ssh.rb +1 -0
 - data/lib/fog/dns.rb +7 -27
 - data/lib/fog/dreamhost.rb +11 -0
 - data/lib/fog/dreamhost/dns.rb +86 -0
 - data/lib/fog/dreamhost/examples/dns/getting_started.md +105 -0
 - data/lib/fog/dreamhost/models/dns/record.rb +35 -0
 - data/lib/fog/dreamhost/models/dns/records.rb +38 -0
 - data/lib/fog/dreamhost/models/dns/zone.rb +59 -0
 - data/lib/fog/dreamhost/models/dns/zones.rb +41 -0
 - data/lib/fog/dreamhost/requests/dns/create_record.rb +32 -0
 - data/lib/fog/dreamhost/requests/dns/delete_record.rb +31 -0
 - data/lib/fog/dreamhost/requests/dns/list_records.rb +25 -0
 - data/lib/fog/ecloud/models/compute/detached_disks.rb +1 -5
 - data/lib/fog/ecloud/models/compute/internet_services.rb +1 -5
 - data/lib/fog/ecloud/models/compute/nodes.rb +1 -5
 - data/lib/fog/ecloud/models/compute/public_ips.rb +1 -5
 - data/lib/fog/ecloud/models/compute/servers.rb +2 -6
 - data/lib/fog/ecloud/requests/compute/get_detached_disk.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/get_internet_service.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/get_node.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/get_public_ip.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/get_server.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/virtual_machine_create_from_template.rb +1 -1
 - data/lib/fog/glesys/compute.rb +5 -1
 - data/lib/fog/glesys/models/compute/ip.rb +47 -46
 - data/lib/fog/glesys/models/compute/ips.rb +95 -12
 - data/lib/fog/glesys/models/compute/server.rb +66 -5
 - data/lib/fog/glesys/models/compute/servers.rb +7 -1
 - data/lib/fog/glesys/models/compute/template.rb +8 -16
 - data/lib/fog/glesys/models/compute/templates.rb +23 -5
 - data/lib/fog/glesys/requests/compute/ip_details.rb +2 -2
 - data/lib/fog/glesys/requests/compute/server_details.rb +2 -2
 - data/lib/fog/glesys/requests/compute/template_list.rb +2 -2
 - data/lib/fog/hp.rb +56 -26
 - data/lib/fog/hp/CHANGELOG.hp +113 -0
 - data/lib/fog/hp/README_HP.rdoc +7 -6
 - data/lib/fog/hp/block_storage.rb +169 -0
 - data/lib/fog/hp/cdn.rb +29 -7
 - data/lib/fog/hp/compute.rb +88 -17
 - data/lib/fog/hp/models/block_storage/bootable_volumes.rb +28 -0
 - data/lib/fog/hp/models/block_storage/snapshot.rb +56 -0
 - data/lib/fog/hp/models/block_storage/snapshots.rb +29 -0
 - data/lib/fog/hp/models/block_storage/volume.rb +102 -0
 - data/lib/fog/hp/models/block_storage/volumes.rb +28 -0
 - data/lib/fog/hp/models/compute/address.rb +0 -1
 - data/lib/fog/hp/models/compute/image.rb +43 -4
 - data/lib/fog/hp/models/compute/images.rb +0 -5
 - data/lib/fog/hp/models/compute/key_pair.rb +0 -5
 - data/lib/fog/hp/models/compute/meta.rb +29 -0
 - data/lib/fog/hp/models/compute/metadata.rb +79 -0
 - data/lib/fog/hp/models/compute/server.rb +84 -20
 - data/lib/fog/hp/models/meta_parent.rb +33 -0
 - data/lib/fog/hp/models/storage/directories.rb +34 -9
 - data/lib/fog/hp/models/storage/directory.rb +111 -26
 - data/lib/fog/hp/models/storage/file.rb +10 -0
 - data/lib/fog/hp/models/storage/files.rb +8 -0
 - data/lib/fog/hp/models/storage/shared_directories.rb +55 -0
 - data/lib/fog/hp/models/storage/shared_directory.rb +39 -0
 - data/lib/fog/hp/models/storage/shared_file.rb +67 -0
 - data/lib/fog/hp/models/storage/shared_files.rb +64 -0
 - data/lib/fog/hp/requests/block_storage/create_snapshot.rb +76 -0
 - data/lib/fog/hp/requests/block_storage/create_volume.rb +87 -0
 - data/lib/fog/hp/requests/block_storage/delete_snapshot.rb +38 -0
 - data/lib/fog/hp/requests/block_storage/delete_volume.rb +38 -0
 - data/lib/fog/hp/requests/block_storage/get_bootable_volume_details.rb +59 -0
 - data/lib/fog/hp/requests/block_storage/get_snapshot_details.rb +54 -0
 - data/lib/fog/hp/requests/block_storage/get_volume_details.rb +58 -0
 - data/lib/fog/hp/requests/block_storage/list_bootable_volumes.rb +53 -0
 - data/lib/fog/hp/requests/block_storage/list_snapshots.rb +48 -0
 - data/lib/fog/hp/requests/block_storage/list_volumes.rb +52 -0
 - data/lib/fog/hp/requests/compute/attach_volume.rb +78 -0
 - data/lib/fog/hp/requests/compute/create_image.rb +5 -8
 - data/lib/fog/hp/requests/compute/create_persistent_server.rb +168 -0
 - data/lib/fog/hp/requests/compute/create_server.rb +36 -20
 - data/lib/fog/hp/requests/compute/delete_meta.rb +55 -0
 - data/lib/fog/hp/requests/compute/delete_security_group_rule.rb +4 -4
 - data/lib/fog/hp/requests/compute/detach_volume.rb +47 -0
 - data/lib/fog/hp/requests/compute/get_console_output.rb +43 -0
 - data/lib/fog/hp/requests/compute/get_meta.rb +57 -0
 - data/lib/fog/hp/requests/compute/get_windows_password.rb +43 -0
 - data/lib/fog/hp/requests/compute/list_metadata.rb +56 -0
 - data/lib/fog/hp/requests/compute/list_server_volumes.rb +49 -0
 - data/lib/fog/hp/requests/compute/set_metadata.rb +60 -0
 - data/lib/fog/hp/requests/compute/update_meta.rb +61 -0
 - data/lib/fog/hp/requests/compute/update_metadata.rb +60 -0
 - data/lib/fog/hp/requests/storage/delete_shared_object.rb +38 -0
 - data/lib/fog/hp/requests/storage/get_object.rb +12 -10
 - data/lib/fog/hp/requests/storage/get_object_temp_url.rb +31 -0
 - data/lib/fog/hp/requests/storage/get_shared_container.rb +75 -0
 - data/lib/fog/hp/requests/storage/get_shared_object.rb +66 -0
 - data/lib/fog/hp/requests/storage/head_container.rb +1 -0
 - data/lib/fog/hp/requests/storage/head_object.rb +1 -0
 - data/lib/fog/hp/requests/storage/head_shared_container.rb +45 -0
 - data/lib/fog/hp/requests/storage/head_shared_object.rb +39 -0
 - data/lib/fog/hp/requests/storage/put_container.rb +6 -6
 - data/lib/fog/hp/requests/storage/put_object.rb +12 -1
 - data/lib/fog/hp/requests/storage/put_shared_object.rb +85 -0
 - data/lib/fog/hp/storage.rb +175 -33
 - data/lib/fog/identity.rb +5 -4
 - data/lib/fog/image.rb +5 -6
 - data/lib/fog/internet_archive.rb +290 -0
 - data/lib/fog/internet_archive/models/storage/directories.rb +43 -0
 - data/lib/fog/internet_archive/models/storage/directory.rb +126 -0
 - data/lib/fog/internet_archive/models/storage/file.rb +286 -0
 - data/lib/fog/internet_archive/models/storage/files.rb +122 -0
 - data/lib/fog/internet_archive/models/storage/version.rb +36 -0
 - data/lib/fog/internet_archive/models/storage/versions.rb +38 -0
 - data/lib/fog/internet_archive/parsers/storage/access_control_list.rb +46 -0
 - data/lib/fog/internet_archive/parsers/storage/complete_multipart_upload.rb +24 -0
 - data/lib/fog/internet_archive/parsers/storage/copy_object.rb +22 -0
 - data/lib/fog/internet_archive/parsers/storage/cors_configuration.rb +41 -0
 - data/lib/fog/internet_archive/parsers/storage/delete_multiple_objects.rb +50 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket.rb +62 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_lifecycle.rb +66 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_location.rb +20 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_logging.rb +40 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_object_versions.rb +88 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_versioning.rb +24 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_website.rb +26 -0
 - data/lib/fog/internet_archive/parsers/storage/get_request_payment.rb +20 -0
 - data/lib/fog/internet_archive/parsers/storage/get_service.rb +32 -0
 - data/lib/fog/internet_archive/parsers/storage/initiate_multipart_upload.rb +24 -0
 - data/lib/fog/internet_archive/parsers/storage/list_multipart_uploads.rb +56 -0
 - data/lib/fog/internet_archive/parsers/storage/list_parts.rb +40 -0
 - data/lib/fog/internet_archive/requests/storage/abort_multipart_upload.rb +28 -0
 - data/lib/fog/internet_archive/requests/storage/acl_utils.rb +62 -0
 - data/lib/fog/internet_archive/requests/storage/complete_multipart_upload.rb +48 -0
 - data/lib/fog/internet_archive/requests/storage/copy_object.rb +81 -0
 - data/lib/fog/internet_archive/requests/storage/cors_utils.rb +41 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket.rb +47 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket_cors.rb +29 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket_lifecycle.rb +27 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket_policy.rb +29 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket_website.rb +29 -0
 - data/lib/fog/internet_archive/requests/storage/delete_multiple_objects.rb +167 -0
 - data/lib/fog/internet_archive/requests/storage/delete_object.rb +118 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket.rb +112 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_acl.rb +69 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_cors.rb +65 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_lifecycle.rb +38 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_location.rb +58 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_logging.rb +47 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_object_versions.rb +162 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_policy.rb +34 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_versioning.rb +69 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_website.rb +40 -0
 - data/lib/fog/internet_archive/requests/storage/get_object.rb +188 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_acl.rb +80 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_http_url.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_https_url.rb +37 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_torrent.rb +47 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_url.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/get_request_payment.rb +49 -0
 - data/lib/fog/internet_archive/requests/storage/get_service.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/head_object.rb +66 -0
 - data/lib/fog/internet_archive/requests/storage/initiate_multipart_upload.rb +44 -0
 - data/lib/fog/internet_archive/requests/storage/list_multipart_uploads.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/list_parts.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/post_object_hidden_fields.rb +38 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket.rb +74 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_acl.rb +71 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_cors.rb +49 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_lifecycle.rb +77 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_logging.rb +81 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_policy.rb +28 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_versioning.rb +75 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_website.rb +64 -0
 - data/lib/fog/internet_archive/requests/storage/put_object.rb +113 -0
 - data/lib/fog/internet_archive/requests/storage/put_object_acl.rb +80 -0
 - data/lib/fog/internet_archive/requests/storage/put_object_url.rb +48 -0
 - data/lib/fog/internet_archive/requests/storage/put_request_payment.rb +49 -0
 - data/lib/fog/internet_archive/requests/storage/sync_clock.rb +28 -0
 - data/lib/fog/internet_archive/requests/storage/upload_part.rb +41 -0
 - data/lib/fog/internet_archive/signaturev4.rb +73 -0
 - data/lib/fog/internet_archive/storage.rb +402 -0
 - data/lib/fog/joyent/models/compute/server.rb +1 -1
 - data/lib/fog/joyent/requests/compute/resize_machine.rb +2 -0
 - data/lib/fog/libvirt/models/compute/volume.rb +1 -1
 - data/lib/fog/network.rb +5 -6
 - data/lib/fog/openstack.rb +10 -0
 - data/lib/fog/openstack/compute.rb +11 -4
 - data/lib/fog/openstack/identity.rb +5 -2
 - data/lib/fog/openstack/models/compute/images.rb +2 -1
 - data/lib/fog/openstack/models/compute/metadata.rb +4 -5
 - data/lib/fog/openstack/models/compute/server.rb +36 -21
 - data/lib/fog/openstack/models/identity/role.rb +1 -1
 - data/lib/fog/openstack/models/network/floating_ip.rb +1 -1
 - data/lib/fog/openstack/models/network/floating_ips.rb +2 -2
 - data/lib/fog/openstack/models/network/network.rb +8 -0
 - data/lib/fog/openstack/models/storage/directories.rb +39 -0
 - data/lib/fog/openstack/models/storage/directory.rb +50 -0
 - data/lib/fog/openstack/models/storage/file.rb +150 -0
 - data/lib/fog/openstack/models/storage/files.rb +94 -0
 - data/lib/fog/openstack/requests/compute/allocate_address.rb +1 -1
 - data/lib/fog/openstack/requests/compute/delete_meta.rb +43 -0
 - data/lib/fog/openstack/requests/compute/get_limits.rb +1 -1
 - data/lib/fog/openstack/requests/compute/get_snapshot_details.rb +1 -1
 - data/lib/fog/openstack/requests/compute/get_volume_details.rb +1 -1
 - data/lib/fog/openstack/requests/compute/list_servers.rb +1 -1
 - data/lib/fog/openstack/requests/compute/list_tenants.rb +1 -0
 - data/lib/fog/openstack/requests/compute/remove_fixed_ip.rb +1 -1
 - data/lib/fog/openstack/requests/compute/update_meta.rb +46 -0
 - data/lib/fog/openstack/requests/compute/update_server.rb +1 -1
 - data/lib/fog/openstack/requests/identity/delete_user_role.rb +2 -2
 - data/lib/fog/openstack/requests/identity/get_user_by_name.rb +2 -2
 - data/lib/fog/openstack/requests/image/create_image.rb +1 -1
 - data/lib/fog/openstack/requests/network/associate_floating_ip.rb +3 -3
 - data/lib/fog/openstack/requests/network/create_floating_ip.rb +3 -3
 - data/lib/fog/openstack/requests/network/delete_floating_ip.rb +1 -1
 - data/lib/fog/openstack/requests/network/disassociate_floating_ip.rb +3 -3
 - data/lib/fog/openstack/requests/network/get_floating_ip.rb +1 -1
 - data/lib/fog/openstack/requests/network/list_floating_ips.rb +1 -1
 - data/lib/fog/openstack/requests/storage/copy_object.rb +27 -0
 - data/lib/fog/openstack/requests/storage/delete_container.rb +22 -0
 - data/lib/fog/openstack/requests/storage/delete_object.rb +23 -0
 - data/lib/fog/openstack/requests/storage/get_container.rb +44 -0
 - data/lib/fog/openstack/requests/storage/get_containers.rb +33 -0
 - data/lib/fog/openstack/requests/storage/get_object.rb +29 -0
 - data/lib/fog/openstack/requests/storage/get_object_https_url.rb +51 -0
 - data/lib/fog/openstack/requests/storage/head_container.rb +28 -0
 - data/lib/fog/openstack/requests/storage/head_containers.rb +25 -0
 - data/lib/fog/openstack/requests/storage/head_object.rb +23 -0
 - data/lib/fog/openstack/requests/storage/post_set_meta_temp_url_key.rb +37 -0
 - data/lib/fog/openstack/requests/storage/put_container.rb +22 -0
 - data/lib/fog/openstack/requests/storage/put_object.rb +30 -0
 - data/lib/fog/openstack/requests/storage/put_object_manifest.rb +25 -0
 - data/lib/fog/openstack/storage.rb +159 -0
 - data/lib/fog/openstack/volume.rb +4 -2
 - data/lib/fog/ovirt/compute.rb +1 -0
 - data/lib/fog/ovirt/models/compute/server.rb +2 -2
 - data/lib/fog/ovirt/models/compute/volume.rb +1 -0
 - data/lib/fog/ovirt/requests/compute/get_api_version.rb +16 -0
 - data/lib/fog/providers.rb +2 -1
 - data/lib/fog/rackspace/block_storage.rb +1 -0
 - data/lib/fog/rackspace/cdn.rb +61 -7
 - data/lib/fog/rackspace/compute_v2.rb +16 -3
 - data/lib/fog/rackspace/databases.rb +4 -3
 - data/lib/fog/rackspace/docs/compute_v2.md +663 -0
 - data/lib/fog/rackspace/docs/getting_started.md +9 -9
 - data/lib/fog/rackspace/examples/README.md +47 -0
 - data/lib/fog/rackspace/examples/compute_v2/README.md +47 -0
 - data/lib/fog/rackspace/examples/compute_v2/create_image.rb +61 -0
 - data/lib/fog/rackspace/examples/compute_v2/create_server.rb +89 -0
 - data/lib/fog/rackspace/examples/compute_v2/delete_image.rb +61 -0
 - data/lib/fog/rackspace/examples/compute_v2/delete_server.rb +56 -0
 - data/lib/fog/rackspace/examples/compute_v2/detach_volume.rb +93 -0
 - data/lib/fog/rackspace/examples/compute_v2/resize_server.rb +106 -0
 - data/lib/fog/rackspace/examples/compute_v2/server_attachments.rb +69 -0
 - data/lib/fog/rackspace/examples/compute_v2/server_metadata.rb +85 -0
 - data/lib/fog/rackspace/identity.rb +1 -1
 - data/lib/fog/rackspace/load_balancers.rb +2 -2
 - data/lib/fog/rackspace/mock_data.rb +114 -96
 - data/lib/fog/rackspace/models/compute_v2/attachment.rb +16 -0
 - data/lib/fog/rackspace/models/compute_v2/attachments.rb +6 -0
 - data/lib/fog/rackspace/models/compute_v2/flavor.rb +18 -0
 - data/lib/fog/rackspace/models/compute_v2/flavors.rb +9 -1
 - data/lib/fog/rackspace/models/compute_v2/image.rb +52 -7
 - data/lib/fog/rackspace/models/compute_v2/images.rb +9 -0
 - data/lib/fog/rackspace/models/compute_v2/meta_parent.rb +9 -0
 - data/lib/fog/rackspace/models/compute_v2/metadata.rb +30 -7
 - data/lib/fog/rackspace/models/compute_v2/metadatum.rb +4 -0
 - data/lib/fog/rackspace/models/compute_v2/network.rb +27 -0
 - data/lib/fog/rackspace/models/compute_v2/networks.rb +23 -0
 - data/lib/fog/rackspace/models/compute_v2/server.rb +235 -24
 - data/lib/fog/rackspace/models/compute_v2/servers.rb +19 -1
 - data/lib/fog/rackspace/models/dns/zones.rb +35 -2
 - data/lib/fog/rackspace/models/identity/credentials.rb +3 -2
 - data/lib/fog/rackspace/models/storage/account.rb +24 -0
 - data/lib/fog/rackspace/models/storage/directories.rb +3 -0
 - data/lib/fog/rackspace/models/storage/directory.rb +68 -39
 - data/lib/fog/rackspace/models/storage/file.rb +38 -67
 - data/lib/fog/rackspace/models/storage/files.rb +11 -4
 - data/lib/fog/rackspace/models/storage/metadata.rb +129 -0
 - data/lib/fog/rackspace/requests/cdn/delete_object.rb +37 -0
 - data/lib/fog/rackspace/requests/cdn/get_containers.rb +34 -0
 - data/lib/fog/rackspace/requests/cdn/head_container.rb +24 -0
 - data/lib/fog/rackspace/requests/cdn/post_container.rb +21 -0
 - data/lib/fog/rackspace/requests/cdn/put_container.rb +21 -0
 - data/lib/fog/rackspace/requests/compute_v2/attach_volume.rb +13 -0
 - data/lib/fog/rackspace/requests/compute_v2/change_server_password.rb +7 -0
 - data/lib/fog/rackspace/requests/compute_v2/confirm_resize_server.rb +9 -0
 - data/lib/fog/rackspace/requests/compute_v2/create_image.rb +9 -5
 - data/lib/fog/rackspace/requests/compute_v2/create_network.rb +36 -0
 - data/lib/fog/rackspace/requests/compute_v2/create_server.rb +38 -0
 - data/lib/fog/rackspace/requests/compute_v2/delete_attachment.rb +5 -0
 - data/lib/fog/rackspace/requests/compute_v2/delete_image.rb +2 -4
 - data/lib/fog/rackspace/requests/compute_v2/delete_metadata_item.rb +6 -0
 - data/lib/fog/rackspace/requests/compute_v2/delete_network.rb +21 -0
 - data/lib/fog/rackspace/requests/compute_v2/delete_server.rb +4 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_attachment.rb +12 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_flavor.rb +14 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_image.rb +18 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_metadata_item.rb +9 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_network.rb +21 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_server.rb +32 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_addresses.rb +5 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_addresses_by_network.rb +12 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_attachments.rb +12 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_flavors.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_images.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_metadata.rb +8 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_networks.rb +18 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +31 -0
 - data/lib/fog/rackspace/requests/compute_v2/reboot_server.rb +5 -0
 - data/lib/fog/rackspace/requests/compute_v2/rebuild_server.rb +37 -0
 - data/lib/fog/rackspace/requests/compute_v2/resize_server.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/revert_resize_server.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/set_metadata.rb +9 -0
 - data/lib/fog/rackspace/requests/compute_v2/set_metadata_item.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/update_metadata.rb +9 -0
 - data/lib/fog/rackspace/requests/compute_v2/update_server.rb +9 -0
 - data/lib/fog/rackspace/requests/storage/get_object.rb +0 -1
 - data/lib/fog/rackspace/requests/storage/put_container.rb +2 -1
 - data/lib/fog/rackspace/storage.rb +14 -2
 - data/lib/fog/schema/data_validator.rb +154 -0
 - data/lib/fog/storage.rb +8 -24
 - data/lib/fog/terremark/models/shared/server.rb +5 -3
 - data/lib/fog/terremark/parser.rb +14 -13
 - data/lib/fog/terremark/parsers/shared/get_catalog.rb +5 -19
 - data/lib/fog/terremark/parsers/shared/get_catalog_item.rb +4 -14
 - data/lib/fog/terremark/parsers/shared/get_internet_services.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/get_keys_list.rb +4 -18
 - data/lib/fog/terremark/parsers/shared/get_network_ips.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/get_node_services.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/get_organization.rb +4 -3
 - data/lib/fog/terremark/parsers/shared/get_organizations.rb +3 -2
 - data/lib/fog/terremark/parsers/shared/get_public_ips.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/get_tasks_list.rb +4 -17
 - data/lib/fog/terremark/parsers/shared/get_vapp_template.rb +3 -14
 - data/lib/fog/terremark/parsers/shared/get_vdc.rb +6 -38
 - data/lib/fog/terremark/parsers/shared/instantiate_vapp_template.rb +3 -14
 - data/lib/fog/terremark/parsers/shared/internet_service.rb +2 -5
 - data/lib/fog/terremark/parsers/shared/network.rb +3 -11
 - data/lib/fog/terremark/parsers/shared/node_service.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/public_ip.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/task.rb +3 -14
 - data/lib/fog/terremark/parsers/shared/vapp.rb +3 -14
 - data/lib/fog/vcloud/compute.rb +1 -0
 - data/lib/fog/vcloud/models/compute/server.rb +15 -2
 - data/lib/fog/vcloud/models/compute/vapp.rb +11 -0
 - data/lib/fog/vcloud/requests/compute/configure_vm_network.rb +37 -0
 - data/lib/fog/vcloud/requests/compute/instantiate_vapp_template.rb +8 -4
 - data/lib/fog/version.rb +1 -1
 - data/lib/fog/volume.rb +6 -6
 - data/lib/fog/vsphere/requests/compute/create_vm.rb +18 -3
 - data/lib/fog/vsphere/requests/compute/list_vm_interfaces.rb +1 -1
 - data/lib/fog/vsphere/requests/compute/vm_reconfig_hardware.rb +1 -1
 - data/tests/aws/models/data_pipeline/pipeline_tests.rb +8 -0
 - data/tests/aws/models/data_pipeline/pipelines_tests.rb +8 -0
 - data/tests/aws/models/rds/server_tests.rb +10 -9
 - data/tests/aws/requests/compute/image_tests.rb +2 -2
 - data/tests/aws/requests/compute/security_group_tests.rb +1 -1
 - data/tests/aws/requests/compute/spot_instance_tests.rb +3 -2
 - data/tests/aws/requests/data_pipeline/helper.rb +44 -0
 - data/tests/aws/requests/data_pipeline/pipeline_tests.rb +54 -0
 - data/tests/aws/requests/rds/instance_tests.rb +8 -5
 - data/tests/bluebox/requests/blb/helper.rb +64 -0
 - data/tests/bluebox/requests/blb/lb_tests.rb +75 -0
 - data/tests/brightbox/requests/compute/firewall_policy_tests.rb +7 -0
 - data/tests/brightbox/requests/compute/helper.rb +4 -2
 - data/tests/compute/helper.rb +8 -0
 - data/tests/core/user_agent_tests.rb +6 -0
 - data/tests/dreamhost/README.md +56 -0
 - data/tests/dreamhost/dns_tests.rb +20 -0
 - data/tests/dreamhost/helper.rb +19 -0
 - data/tests/dreamhost/models/dns/record_tests.rb +73 -0
 - data/tests/dreamhost/models/dns/records_tests.rb +29 -0
 - data/tests/dreamhost/models/dns/zone_tests.rb +62 -0
 - data/tests/dreamhost/models/dns/zones_tests.rb +29 -0
 - data/tests/dreamhost/requests/dns/create_record_tests.rb +39 -0
 - data/tests/dreamhost/requests/dns/delete_record_tests.rb +26 -0
 - data/tests/dreamhost/requests/dns/list_records_tests.rb +31 -0
 - data/tests/glesys/requests/compute/helper.rb +5 -5
 - data/tests/helper.rb +1 -1
 - data/tests/helpers/formats_helper.rb +63 -50
 - data/tests/helpers/formats_helper_tests.rb +87 -36
 - data/tests/helpers/mock_helper.rb +4 -1
 - data/tests/helpers/schema_validator_tests.rb +107 -0
 - data/tests/hp/models/block_storage/bootable_volume_tests.rb +23 -0
 - data/tests/hp/models/block_storage/snapshot_tests.rb +23 -0
 - data/tests/hp/models/block_storage/volume_tests.rb +21 -0
 - data/tests/hp/models/compute/address_tests.rb +1 -1
 - data/tests/hp/models/compute/addresses_tests.rb +1 -1
 - data/tests/hp/models/compute/key_pair_tests.rb +1 -1
 - data/tests/hp/models/compute/key_pairs_tests.rb +1 -1
 - data/tests/hp/models/compute/metadata_image_tests.rb +60 -0
 - data/tests/hp/models/compute/metadata_server_tests.rb +54 -0
 - data/tests/hp/models/compute/security_group_tests.rb +3 -1
 - data/tests/hp/models/compute/security_groups_tests.rb +1 -1
 - data/tests/hp/models/storage/directories_tests.rb +23 -0
 - data/tests/hp/models/storage/directory_tests.rb +62 -0
 - data/tests/hp/models/storage/file_tests.rb +44 -0
 - data/tests/hp/models/storage/files_tests.rb +38 -0
 - data/tests/hp/requests/block_storage/bootable_volume_tests.rb +78 -0
 - data/tests/hp/requests/block_storage/snapshot_tests.rb +56 -0
 - data/tests/hp/requests/block_storage/volume_tests.rb +94 -0
 - data/tests/hp/requests/cdn/container_tests.rb +1 -1
 - data/tests/hp/requests/compute/address_tests.rb +5 -6
 - data/tests/hp/requests/compute/flavor_tests.rb +1 -1
 - data/tests/hp/requests/compute/image_tests.rb +1 -1
 - data/tests/hp/requests/compute/key_pair_tests.rb +1 -1
 - data/tests/hp/requests/compute/metadata_tests.rb +70 -0
 - data/tests/hp/requests/compute/persistent_server_tests.rb +66 -0
 - data/tests/hp/requests/compute/security_group_rule_tests.rb +1 -1
 - data/tests/hp/requests/compute/security_group_tests.rb +1 -1
 - data/tests/hp/requests/compute/server_address_tests.rb +1 -1
 - data/tests/hp/requests/compute/server_tests.rb +5 -6
 - data/tests/hp/requests/compute/server_volume_tests.rb +76 -0
 - data/tests/hp/requests/storage/container_tests.rb +1 -1
 - data/tests/hp/requests/storage/object_tests.rb +9 -1
 - data/tests/hp/user_agent_tests.rb +13 -0
 - data/tests/internet_archive/models/storage/directory_tests.rb +51 -0
 - data/tests/internet_archive/models/storage/file_tests.rb +80 -0
 - data/tests/internet_archive/models/storage/files_tests.rb +56 -0
 - data/tests/internet_archive/models/storage/url_tests.rb +28 -0
 - data/tests/internet_archive/models/storage/version_tests.rb +52 -0
 - data/tests/internet_archive/models/storage/versions_tests.rb +56 -0
 - data/tests/internet_archive/requests/storage/acl_utils_tests.rb +209 -0
 - data/tests/internet_archive/requests/storage/bucket_tests.rb +328 -0
 - data/tests/internet_archive/requests/storage/cors_utils_tests.rb +108 -0
 - data/tests/internet_archive/requests/storage/multipart_upload_tests.rb +132 -0
 - data/tests/internet_archive/requests/storage/object_tests.rb +166 -0
 - data/tests/internet_archive/requests/storage/versioning_tests.rb +258 -0
 - data/tests/internet_archive/signaturev4_tests.rb +41 -0
 - data/tests/internet_archive/signed_params_tests.rb +5 -0
 - data/tests/openstack/models/compute/images_tests.rb +14 -0
 - data/tests/openstack/models/compute/server_tests.rb +42 -1
 - data/tests/openstack/models/identity/roles_tests.rb +1 -0
 - data/tests/openstack/models/identity/user_tests.rb +2 -2
 - data/tests/openstack/models/network/network_tests.rb +21 -1
 - data/tests/openstack/models/storage/file_tests.rb +178 -0
 - data/tests/openstack/requests/compute/limit_tests.rb +1 -1
 - data/tests/openstack/requests/compute/tenant_tests.rb +2 -2
 - data/tests/openstack/requests/identity/ec2_credentials_tests.rb +7 -4
 - data/tests/openstack/requests/identity/helper.rb +17 -0
 - data/tests/openstack/requests/identity/role_tests.rb +6 -0
 - data/tests/openstack/requests/identity/tenant_tests.rb +14 -12
 - data/tests/openstack/requests/identity/user_tests.rb +9 -5
 - data/tests/openstack/requests/storage/container_tests.rb +64 -0
 - data/tests/openstack/requests/storage/large_object_tests.rb +47 -0
 - data/tests/openstack/requests/storage/object_tests.rb +84 -0
 - data/tests/openstack/volume_tests.rb +15 -0
 - data/tests/rackspace/cdn_tests.rb +78 -0
 - data/tests/rackspace/helper.rb +9 -0
 - data/tests/rackspace/models/compute_v2/flavors_tests.rb +1 -1
 - data/tests/rackspace/models/compute_v2/image_tests.rb +2 -4
 - data/tests/rackspace/models/compute_v2/images_tests.rb +1 -1
 - data/tests/rackspace/models/compute_v2/metadata_tests.rb +5 -3
 - data/tests/rackspace/models/compute_v2/network_tests.rb +10 -0
 - data/tests/rackspace/models/compute_v2/networks_tests.rb +10 -0
 - data/tests/rackspace/models/compute_v2/server_tests.rb +8 -7
 - data/tests/rackspace/models/compute_v2/servers_tests.rb +5 -7
 - data/tests/rackspace/models/dns/zones_tests.rb +22 -0
 - data/tests/rackspace/models/identity/credentials_tests.rb +14 -5
 - data/tests/rackspace/models/storage/account_tests.rb +28 -0
 - data/tests/rackspace/models/storage/directories_tests.rb +29 -0
 - data/tests/rackspace/models/storage/directory_tests.rb +141 -0
 - data/tests/rackspace/models/storage/file_tests.rb +86 -11
 - data/tests/rackspace/models/storage/metadata_tests.rb +174 -0
 - data/tests/rackspace/requests/cdn/cdn_tests.rb +76 -0
 - data/tests/rackspace/requests/compute/image_tests.rb +2 -2
 - data/tests/rackspace/requests/compute_v2/image_tests.rb +6 -6
 - data/tests/rackspace/requests/compute_v2/network_tests.rb +49 -0
 - data/tests/rackspace/requests/identity/user_tests.rb +0 -4
 - data/tests/rackspace/requests/storage/container_tests.rb +8 -1
 - data/tests/rackspace/storage_tests.rb +8 -0
 - data/tests/storage/helper.rb +3 -0
 - metadata +341 -40
 - data/docs/storage/aws.markdown +0 -21
 - data/lib/fog/bin/virtual_box.rb +0 -57
 - data/lib/fog/rackspace/docs/cloud_servers.md +0 -65
 - data/lib/fog/rackspace/requests/identity/get_credentials.rb +0 -15
 - data/lib/fog/virtual_box.rb +0 -11
 - data/lib/fog/virtual_box/compute.rb +0 -59
 - data/lib/fog/virtual_box/models/compute/medium.rb +0 -87
 - data/lib/fog/virtual_box/models/compute/medium_format.rb +0 -34
 - data/lib/fog/virtual_box/models/compute/mediums.rb +0 -32
 - data/lib/fog/virtual_box/models/compute/nat_engine.rb +0 -65
 - data/lib/fog/virtual_box/models/compute/nat_redirect.rb +0 -91
 - data/lib/fog/virtual_box/models/compute/nat_redirects.rb +0 -41
 - data/lib/fog/virtual_box/models/compute/network_adapter.rb +0 -82
 - data/lib/fog/virtual_box/models/compute/network_adapters.rb +0 -42
 - data/lib/fog/virtual_box/models/compute/server.rb +0 -199
 - data/lib/fog/virtual_box/models/compute/servers.rb +0 -41
 - data/lib/fog/virtual_box/models/compute/storage_controller.rb +0 -83
 - data/lib/fog/virtual_box/models/compute/storage_controllers.rb +0 -38
 
| 
         @@ -0,0 +1,29 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            Shindo.tests("Fog::DNS[:dreamhost] | Zones Collection", ['dreamhost', 'dns']) do
         
     | 
| 
      
 2 
     | 
    
         
            +
             
     | 
| 
      
 3 
     | 
    
         
            +
              service = Fog::DNS[:dreamhost]
         
     | 
| 
      
 4 
     | 
    
         
            +
              
         
     | 
| 
      
 5 
     | 
    
         
            +
              tests('#all') do
         
     | 
| 
      
 6 
     | 
    
         
            +
                zones = service.zones
         
     | 
| 
      
 7 
     | 
    
         
            +
             
     | 
| 
      
 8 
     | 
    
         
            +
                test('should be an array') { zones.is_a? Array }
         
     | 
| 
      
 9 
     | 
    
         
            +
             
     | 
| 
      
 10 
     | 
    
         
            +
                test('should not be empty') { !zones.empty? }
         
     | 
| 
      
 11 
     | 
    
         
            +
                
         
     | 
| 
      
 12 
     | 
    
         
            +
                tests('should list Fog::DNS::Dreamhost::Zone') do
         
     | 
| 
      
 13 
     | 
    
         
            +
                  zones.each do |r|
         
     | 
| 
      
 14 
     | 
    
         
            +
                    test("as zone") { r.is_a?(Fog::DNS::Dreamhost::Zone) }
         
     | 
| 
      
 15 
     | 
    
         
            +
                  end
         
     | 
| 
      
 16 
     | 
    
         
            +
                end
         
     | 
| 
      
 17 
     | 
    
         
            +
              end
         
     | 
| 
      
 18 
     | 
    
         
            +
             
     | 
| 
      
 19 
     | 
    
         
            +
              tests('#get') do
         
     | 
| 
      
 20 
     | 
    
         
            +
                tests('should fetch a zone') do
         
     | 
| 
      
 21 
     | 
    
         
            +
                  zone = service.zones.get test_domain 
         
     | 
| 
      
 22 
     | 
    
         
            +
                  test('should be a Fog::DNS::Dreamhost::Zone') do
         
     | 
| 
      
 23 
     | 
    
         
            +
                    zone.is_a? Fog::DNS::Dreamhost::Zone
         
     | 
| 
      
 24 
     | 
    
         
            +
                  end
         
     | 
| 
      
 25 
     | 
    
         
            +
                end
         
     | 
| 
      
 26 
     | 
    
         
            +
              end
         
     | 
| 
      
 27 
     | 
    
         
            +
             
     | 
| 
      
 28 
     | 
    
         
            +
            end
         
     | 
| 
      
 29 
     | 
    
         
            +
             
     | 
| 
         @@ -0,0 +1,39 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            Shindo.tests('Fog::DNS[:dreamhost] | create_record request', ['dreamhost', 'dns']) do
         
     | 
| 
      
 2 
     | 
    
         
            +
             
     | 
| 
      
 3 
     | 
    
         
            +
              tests("success") do
         
     | 
| 
      
 4 
     | 
    
         
            +
                
         
     | 
| 
      
 5 
     | 
    
         
            +
                test("create an A resource record without comment") do
         
     | 
| 
      
 6 
     | 
    
         
            +
                  name = "foo.testing.#{test_domain}"
         
     | 
| 
      
 7 
     | 
    
         
            +
                  type = "A"
         
     | 
| 
      
 8 
     | 
    
         
            +
                  value = "1.2.3.4"
         
     | 
| 
      
 9 
     | 
    
         
            +
                  response = Fog::DNS[:dreamhost].create_record(name, type, value)
         
     | 
| 
      
 10 
     | 
    
         
            +
             
     | 
| 
      
 11 
     | 
    
         
            +
                  response.body['result'] == 'success'
         
     | 
| 
      
 12 
     | 
    
         
            +
                end
         
     | 
| 
      
 13 
     | 
    
         
            +
                
         
     | 
| 
      
 14 
     | 
    
         
            +
                test("create an A resource record with comment") do
         
     | 
| 
      
 15 
     | 
    
         
            +
                  name = "foo2.testing.#{test_domain}"
         
     | 
| 
      
 16 
     | 
    
         
            +
                  type = "A"
         
     | 
| 
      
 17 
     | 
    
         
            +
                  value = "1.2.3.4"
         
     | 
| 
      
 18 
     | 
    
         
            +
                  comment = "test"
         
     | 
| 
      
 19 
     | 
    
         
            +
                  response = Fog::DNS[:dreamhost].create_record(name, type, value, comment)
         
     | 
| 
      
 20 
     | 
    
         
            +
                  
         
     | 
| 
      
 21 
     | 
    
         
            +
                  response.body['result'] == 'success'
         
     | 
| 
      
 22 
     | 
    
         
            +
                end
         
     | 
| 
      
 23 
     | 
    
         
            +
             
     | 
| 
      
 24 
     | 
    
         
            +
                test("create TXT record") do
         
     | 
| 
      
 25 
     | 
    
         
            +
                  name = "txt.testing.#{test_domain}"
         
     | 
| 
      
 26 
     | 
    
         
            +
                  type = "txt"
         
     | 
| 
      
 27 
     | 
    
         
            +
                  value = "foobar"
         
     | 
| 
      
 28 
     | 
    
         
            +
                  comment = "test"
         
     | 
| 
      
 29 
     | 
    
         
            +
                  response = Fog::DNS[:dreamhost].create_record(name, type, value, comment)
         
     | 
| 
      
 30 
     | 
    
         
            +
                  
         
     | 
| 
      
 31 
     | 
    
         
            +
                  response.body['result'] == 'success'
         
     | 
| 
      
 32 
     | 
    
         
            +
                end
         
     | 
| 
      
 33 
     | 
    
         
            +
             
     | 
| 
      
 34 
     | 
    
         
            +
              end
         
     | 
| 
      
 35 
     | 
    
         
            +
             
     | 
| 
      
 36 
     | 
    
         
            +
              # helper
         
     | 
| 
      
 37 
     | 
    
         
            +
              cleanup_records
         
     | 
| 
      
 38 
     | 
    
         
            +
             
     | 
| 
      
 39 
     | 
    
         
            +
            end
         
     | 
| 
         @@ -0,0 +1,26 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            Shindo.tests('Fog::DNS[:dreamhost] | delete_record request', ['dreamhost', 'dns']) do
         
     | 
| 
      
 2 
     | 
    
         
            +
             
     | 
| 
      
 3 
     | 
    
         
            +
              tests("success") do
         
     | 
| 
      
 4 
     | 
    
         
            +
                
         
     | 
| 
      
 5 
     | 
    
         
            +
                test("delete testing records") do
         
     | 
| 
      
 6 
     | 
    
         
            +
                  name = "delete-test.#{test_domain}"
         
     | 
| 
      
 7 
     | 
    
         
            +
                  type = "A"
         
     | 
| 
      
 8 
     | 
    
         
            +
                  value = "1.2.3.4"
         
     | 
| 
      
 9 
     | 
    
         
            +
                  comment = "test"
         
     | 
| 
      
 10 
     | 
    
         
            +
                  Fog::DNS[:dreamhost].create_record(name, type, value, comment)
         
     | 
| 
      
 11 
     | 
    
         
            +
                  response = Fog::DNS[:dreamhost].delete_record(name, type, value)
         
     | 
| 
      
 12 
     | 
    
         
            +
                  response.body['result'] == 'success'
         
     | 
| 
      
 13 
     | 
    
         
            +
                end
         
     | 
| 
      
 14 
     | 
    
         
            +
             
     | 
| 
      
 15 
     | 
    
         
            +
              end
         
     | 
| 
      
 16 
     | 
    
         
            +
             
     | 
| 
      
 17 
     | 
    
         
            +
              tests( 'failure') do
         
     | 
| 
      
 18 
     | 
    
         
            +
                raises(RuntimeError, 'deleting non-existent record') do
         
     | 
| 
      
 19 
     | 
    
         
            +
                  Fog::DNS[:dreamhost].delete_record('foo.bar.bar', 'A', '1.2.3.4')
         
     | 
| 
      
 20 
     | 
    
         
            +
                end
         
     | 
| 
      
 21 
     | 
    
         
            +
              end
         
     | 
| 
      
 22 
     | 
    
         
            +
             
     | 
| 
      
 23 
     | 
    
         
            +
              # helper
         
     | 
| 
      
 24 
     | 
    
         
            +
              cleanup_records
         
     | 
| 
      
 25 
     | 
    
         
            +
             
     | 
| 
      
 26 
     | 
    
         
            +
            end
         
     | 
| 
         @@ -0,0 +1,31 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            Shindo.tests('Fog::DNS[:dreamhost] | list_records request', ['dreamhost', 'dns']) do
         
     | 
| 
      
 2 
     | 
    
         
            +
             
     | 
| 
      
 3 
     | 
    
         
            +
              tests("success") do
         
     | 
| 
      
 4 
     | 
    
         
            +
                
         
     | 
| 
      
 5 
     | 
    
         
            +
                response = Fog::DNS[:dreamhost].list_records
         
     | 
| 
      
 6 
     | 
    
         
            +
             
     | 
| 
      
 7 
     | 
    
         
            +
                test("should return 200") do
         
     | 
| 
      
 8 
     | 
    
         
            +
                  if response.status == 200
         
     | 
| 
      
 9 
     | 
    
         
            +
                    @records = response.body["data"]
         
     | 
| 
      
 10 
     | 
    
         
            +
                  end
         
     | 
| 
      
 11 
     | 
    
         
            +
                  (response.status == 200) and (response.body.size == 2)
         
     | 
| 
      
 12 
     | 
    
         
            +
                end
         
     | 
| 
      
 13 
     | 
    
         
            +
             
     | 
| 
      
 14 
     | 
    
         
            +
                test("data should be an Array") do
         
     | 
| 
      
 15 
     | 
    
         
            +
                  @records.is_a? Array
         
     | 
| 
      
 16 
     | 
    
         
            +
                end
         
     | 
| 
      
 17 
     | 
    
         
            +
             
     | 
| 
      
 18 
     | 
    
         
            +
                tests("should return records") do
         
     | 
| 
      
 19 
     | 
    
         
            +
                  %w{type zone value comment record}.each do |elem|
         
     | 
| 
      
 20 
     | 
    
         
            +
                    test("with #{elem}") do
         
     | 
| 
      
 21 
     | 
    
         
            +
                      @records.first[elem].is_a? String
         
     | 
| 
      
 22 
     | 
    
         
            +
                    end
         
     | 
| 
      
 23 
     | 
    
         
            +
                  end
         
     | 
| 
      
 24 
     | 
    
         
            +
                end
         
     | 
| 
      
 25 
     | 
    
         
            +
                
         
     | 
| 
      
 26 
     | 
    
         
            +
              end
         
     | 
| 
      
 27 
     | 
    
         
            +
             
     | 
| 
      
 28 
     | 
    
         
            +
              # helper
         
     | 
| 
      
 29 
     | 
    
         
            +
              cleanup_records
         
     | 
| 
      
 30 
     | 
    
         
            +
             
     | 
| 
      
 31 
     | 
    
         
            +
            end
         
     | 
| 
         @@ -5,7 +5,7 @@ class Glesys 
     | 
|
| 
       5 
5 
     | 
    
         | 
| 
       6 
6 
     | 
    
         
             
                    LIST = {
         
     | 
| 
       7 
7 
     | 
    
         
             
                      'debug' => {
         
     | 
| 
       8 
     | 
    
         
            -
                        'input' =>  
     | 
| 
      
 8 
     | 
    
         
            +
                        'input' => Array
         
     | 
| 
       9 
9 
     | 
    
         
             
                      },
         
     | 
| 
       10 
10 
     | 
    
         
             
                      'servers' => [{
         
     | 
| 
       11 
11 
     | 
    
         
             
                        'serverid' => String,
         
     | 
| 
         @@ -122,7 +122,7 @@ class Glesys 
     | 
|
| 
       122 
122 
     | 
    
         
             
                          'current' => Fog::Nullable::Integer,
         
     | 
| 
       123 
123 
     | 
    
         
             
                          'unit'    => String
         
     | 
| 
       124 
124 
     | 
    
         
             
                        },
         
     | 
| 
       125 
     | 
    
         
            -
                        'warnings'  =>  
     | 
| 
      
 125 
     | 
    
         
            +
                        'warnings'  => Array
         
     | 
| 
       126 
126 
     | 
    
         
             
                      },
         
     | 
| 
       127 
127 
     | 
    
         
             
                      'status' => {
         
     | 
| 
       128 
128 
     | 
    
         
             
                        'timestamp' => String,
         
     | 
| 
         @@ -161,7 +161,7 @@ class Glesys 
     | 
|
| 
       161 
161 
     | 
    
         
             
                        'netmask'     => Fog::Nullable::String,
         
     | 
| 
       162 
162 
     | 
    
         
             
                        'broadcast'   => Fog::Nullable::String,
         
     | 
| 
       163 
163 
     | 
    
         
             
                        'gateway'     => Fog::Nullable::String,
         
     | 
| 
       164 
     | 
    
         
            -
                        'nameservers' =>  
     | 
| 
      
 164 
     | 
    
         
            +
                        'nameservers' => Array,
         
     | 
| 
       165 
165 
     | 
    
         
             
                        'datacenter'  => String,
         
     | 
| 
       166 
166 
     | 
    
         
             
                        'serverid'    => Fog::Nullable::String,
         
     | 
| 
       167 
167 
     | 
    
         
             
                        'platform'    => String,
         
     | 
| 
         @@ -189,7 +189,7 @@ class Glesys 
     | 
|
| 
       189 
189 
     | 
    
         
             
                        'ipversion'   => Integer,
         
     | 
| 
       190 
190 
     | 
    
         
             
                        'datacenter'  => String,
         
     | 
| 
       191 
191 
     | 
    
         
             
                        'platform'    => String,
         
     | 
| 
       192 
     | 
    
         
            -
                        "ipaddresses" =>  
     | 
| 
      
 192 
     | 
    
         
            +
                        "ipaddresses" => Array
         
     | 
| 
       193 
193 
     | 
    
         
             
                      },
         
     | 
| 
       194 
194 
     | 
    
         
             
                      'status' => {
         
     | 
| 
       195 
195 
     | 
    
         
             
                        'timestamp' => String,
         
     | 
| 
         @@ -214,7 +214,7 @@ class Glesys 
     | 
|
| 
       214 
214 
     | 
    
         
             
                        'netmask'     => String,
         
     | 
| 
       215 
215 
     | 
    
         
             
                        'broadcast'   => String,
         
     | 
| 
       216 
216 
     | 
    
         
             
                        'gateway'     => String,
         
     | 
| 
       217 
     | 
    
         
            -
                        'nameservers' =>  
     | 
| 
      
 217 
     | 
    
         
            +
                        'nameservers' => Array,
         
     | 
| 
       218 
218 
     | 
    
         
             
                        'datacenter'  => String,
         
     | 
| 
       219 
219 
     | 
    
         
             
                        'serverid'    => Fog::Nullable::String,
         
     | 
| 
       220 
220 
     | 
    
         
             
                        'platform'    => String,
         
     | 
    
        data/tests/helper.rb
    CHANGED
    
    | 
         @@ -18,7 +18,7 @@ end 
     | 
|
| 
       18 
18 
     | 
    
         
             
            all_providers = Fog.registered_providers.map {|provider| provider.downcase}
         
     | 
| 
       19 
19 
     | 
    
         | 
| 
       20 
20 
     | 
    
         
             
            # Manually remove these providers since they are local applications, not lacking credentials
         
     | 
| 
       21 
     | 
    
         
            -
            all_providers = all_providers - ["libvirt", " 
     | 
| 
      
 21 
     | 
    
         
            +
            all_providers = all_providers - ["libvirt", "vmfusion"]
         
     | 
| 
       22 
22 
     | 
    
         | 
| 
       23 
23 
     | 
    
         
             
            available_providers = Fog.available_providers.map {|provider| provider.downcase}
         
     | 
| 
       24 
24 
     | 
    
         | 
| 
         @@ -1,3 +1,5 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            require "fog/schema/data_validator"
         
     | 
| 
      
 2 
     | 
    
         
            +
             
     | 
| 
       1 
3 
     | 
    
         
             
            # format related hackery
         
     | 
| 
       2 
4 
     | 
    
         
             
            # allows both true.is_a?(Fog::Boolean) and false.is_a?(Fog::Boolean)
         
     | 
| 
       3 
5 
     | 
    
         
             
            # allows both nil.is_a?(Fog::Nullable::String) and ''.is_a?(Fog::Nullable::String)
         
     | 
| 
         @@ -25,62 +27,73 @@ end 
     | 
|
| 
       25 
27 
     | 
    
         
             
            module Shindo
         
     | 
| 
       26 
28 
     | 
    
         
             
              class Tests
         
     | 
| 
       27 
29 
     | 
    
         | 
| 
       28 
     | 
    
         
            -
                 
     | 
| 
       29 
     | 
    
         
            -
             
     | 
| 
       30 
     | 
    
         
            -
             
     | 
| 
       31 
     | 
    
         
            -
             
     | 
| 
       32 
     | 
    
         
            -
             
     | 
| 
      
 30 
     | 
    
         
            +
                # Generates a Shindo test that compares a hash schema to the result
         
     | 
| 
      
 31 
     | 
    
         
            +
                # of the passed in block returning true if they match.
         
     | 
| 
      
 32 
     | 
    
         
            +
                #
         
     | 
| 
      
 33 
     | 
    
         
            +
                # The schema that is passed in is a Hash or Array of hashes that
         
     | 
| 
      
 34 
     | 
    
         
            +
                # have Classes in place of values. When checking the schema the
         
     | 
| 
      
 35 
     | 
    
         
            +
                # value should match the Class.
         
     | 
| 
      
 36 
     | 
    
         
            +
                #
         
     | 
| 
      
 37 
     | 
    
         
            +
                # Strict mode will fail if the data has additional keys. Setting
         
     | 
| 
      
 38 
     | 
    
         
            +
                # +strict+ to +false+ will allow additional keys to appear.
         
     | 
| 
      
 39 
     | 
    
         
            +
                #
         
     | 
| 
      
 40 
     | 
    
         
            +
                # @param [Hash] schema A Hash schema
         
     | 
| 
      
 41 
     | 
    
         
            +
                # @param [Hash] options Options to change validation rules
         
     | 
| 
      
 42 
     | 
    
         
            +
                # @option options [Boolean] :allow_extra_keys
         
     | 
| 
      
 43 
     | 
    
         
            +
                #     If +true+ does not fail when keys are in the data that are
         
     | 
| 
      
 44 
     | 
    
         
            +
                #     not specified in the schema. This allows new values to
         
     | 
| 
      
 45 
     | 
    
         
            +
                #     appear in API output without breaking the check.
         
     | 
| 
      
 46 
     | 
    
         
            +
                # @option options [Boolean] :allow_optional_rules
         
     | 
| 
      
 47 
     | 
    
         
            +
                #     If +true+ does not fail if extra keys are in the schema
         
     | 
| 
      
 48 
     | 
    
         
            +
                #     that do not match the data. Not recommended!
         
     | 
| 
      
 49 
     | 
    
         
            +
                # @yield Data to check with schema
         
     | 
| 
      
 50 
     | 
    
         
            +
                #
         
     | 
| 
      
 51 
     | 
    
         
            +
                # @example Using in a test
         
     | 
| 
      
 52 
     | 
    
         
            +
                #     Shindo.tests("comparing welcome data against schema") do
         
     | 
| 
      
 53 
     | 
    
         
            +
                #       data = {:welcome => "Hello" }
         
     | 
| 
      
 54 
     | 
    
         
            +
                #       data_matches_schema(:welcome => String) { data }
         
     | 
| 
      
 55 
     | 
    
         
            +
                #     end
         
     | 
| 
      
 56 
     | 
    
         
            +
                #
         
     | 
| 
      
 57 
     | 
    
         
            +
                #     comparing welcome data against schema
         
     | 
| 
      
 58 
     | 
    
         
            +
                #     + data matches schema
         
     | 
| 
      
 59 
     | 
    
         
            +
                #
         
     | 
| 
      
 60 
     | 
    
         
            +
                # @example Example schema
         
     | 
| 
      
 61 
     | 
    
         
            +
                #     {
         
     | 
| 
      
 62 
     | 
    
         
            +
                #       "id" => String,
         
     | 
| 
      
 63 
     | 
    
         
            +
                #       "ram" => Integer,
         
     | 
| 
      
 64 
     | 
    
         
            +
                #       "disks" => [
         
     | 
| 
      
 65 
     | 
    
         
            +
                #         {
         
     | 
| 
      
 66 
     | 
    
         
            +
                #           "size" => Float
         
     | 
| 
      
 67 
     | 
    
         
            +
                #         }
         
     | 
| 
      
 68 
     | 
    
         
            +
                #       ],
         
     | 
| 
      
 69 
     | 
    
         
            +
                #       "dns_name" => Fog::Nullable::String,
         
     | 
| 
      
 70 
     | 
    
         
            +
                #       "active" => Fog::Boolean,
         
     | 
| 
      
 71 
     | 
    
         
            +
                #       "created" => DateTime
         
     | 
| 
      
 72 
     | 
    
         
            +
                #     }
         
     | 
| 
      
 73 
     | 
    
         
            +
                #
         
     | 
| 
      
 74 
     | 
    
         
            +
                # @return [Boolean]
         
     | 
| 
      
 75 
     | 
    
         
            +
                def data_matches_schema(schema, options = {})
         
     | 
| 
      
 76 
     | 
    
         
            +
                  test('data matches schema') do
         
     | 
| 
      
 77 
     | 
    
         
            +
                    validator = Fog::Schema::DataValidator.new
         
     | 
| 
      
 78 
     | 
    
         
            +
                    valid = validator.validate(yield, schema, options)
         
     | 
| 
      
 79 
     | 
    
         
            +
                    @message = validator.message unless valid
         
     | 
| 
      
 80 
     | 
    
         
            +
                    valid
         
     | 
| 
       33 
81 
     | 
    
         
             
                  end
         
     | 
| 
       34 
82 
     | 
    
         
             
                end
         
     | 
| 
       35 
83 
     | 
    
         | 
| 
       36 
     | 
    
         
            -
                 
     | 
| 
       37 
     | 
    
         
            -
             
     | 
| 
       38 
     | 
    
         
            -
             
     | 
| 
       39 
     | 
    
         
            -
             
     | 
| 
       40 
     | 
    
         
            -
             
     | 
| 
       41 
     | 
    
         
            -
                  format = original_format.dup
         
     | 
| 
       42 
     | 
    
         
            -
                  if format.is_a?(Array)
         
     | 
| 
       43 
     | 
    
         
            -
                    data   = {:element => data}
         
     | 
| 
       44 
     | 
    
         
            -
                    format = {:element => format}
         
     | 
| 
       45 
     | 
    
         
            -
                  end
         
     | 
| 
       46 
     | 
    
         
            -
                  for key, value in format
         
     | 
| 
       47 
     | 
    
         
            -
                    datum = data.delete(key)
         
     | 
| 
       48 
     | 
    
         
            -
                    format.delete(key)
         
     | 
| 
       49 
     | 
    
         
            -
                    case value
         
     | 
| 
       50 
     | 
    
         
            -
                    when Array
         
     | 
| 
       51 
     | 
    
         
            -
                      p("#{key.inspect} not Array: #{datum.inspect}") unless datum.is_a?(Array)
         
     | 
| 
       52 
     | 
    
         
            -
                      valid &&= datum.is_a?(Array)
         
     | 
| 
       53 
     | 
    
         
            -
                      if datum.is_a?(Array) && !value.empty?
         
     | 
| 
       54 
     | 
    
         
            -
                        for element in datum
         
     | 
| 
       55 
     | 
    
         
            -
                          type = value.first
         
     | 
| 
       56 
     | 
    
         
            -
                          if type.is_a?(Hash)
         
     | 
| 
       57 
     | 
    
         
            -
                            valid &&= formats_kernel({:element => element}, {:element => type}, false, strict)
         
     | 
| 
       58 
     | 
    
         
            -
                          else
         
     | 
| 
       59 
     | 
    
         
            -
                            valid &&= element.is_a?(type)
         
     | 
| 
       60 
     | 
    
         
            -
                          end
         
     | 
| 
       61 
     | 
    
         
            -
                        end
         
     | 
| 
       62 
     | 
    
         
            -
                      end
         
     | 
| 
       63 
     | 
    
         
            -
                    when Hash
         
     | 
| 
       64 
     | 
    
         
            -
                      p("#{key.inspect} not Hash: #{datum.inspect}") unless datum.is_a?(Hash)
         
     | 
| 
       65 
     | 
    
         
            -
                      valid &&= datum.is_a?(Hash)
         
     | 
| 
       66 
     | 
    
         
            -
                      valid &&= formats_kernel(datum, value, false, strict)
         
     | 
| 
      
 84 
     | 
    
         
            +
                # @deprecated #formats is deprecated. Use #data_matches_schema instead
         
     | 
| 
      
 85 
     | 
    
         
            +
                def formats(format, strict = true)
         
     | 
| 
      
 86 
     | 
    
         
            +
                  test('has proper format') do
         
     | 
| 
      
 87 
     | 
    
         
            +
                    if strict
         
     | 
| 
      
 88 
     | 
    
         
            +
                      options = {:allow_extra_keys => false, :allow_optional_rules => true}
         
     | 
| 
       67 
89 
     | 
    
         
             
                    else
         
     | 
| 
       68 
     | 
    
         
            -
                       
     | 
| 
       69 
     | 
    
         
            -
                      valid &&= datum.is_a?(value)
         
     | 
| 
      
 90 
     | 
    
         
            +
                      options = {:allow_extra_keys => true, :allow_optional_rules => true}
         
     | 
| 
       70 
91 
     | 
    
         
             
                    end
         
     | 
| 
      
 92 
     | 
    
         
            +
                    validator = Fog::Schema::DataValidator.new
         
     | 
| 
      
 93 
     | 
    
         
            +
                    valid = validator.validate(yield, format, options)
         
     | 
| 
      
 94 
     | 
    
         
            +
                    @message = validator.message unless valid
         
     | 
| 
      
 95 
     | 
    
         
            +
                    valid
         
     | 
| 
       71 
96 
     | 
    
         
             
                  end
         
     | 
| 
       72 
     | 
    
         
            -
                  p data unless data.empty?
         
     | 
| 
       73 
     | 
    
         
            -
                  p format unless format.empty?
         
     | 
| 
       74 
     | 
    
         
            -
                  if strict
         
     | 
| 
       75 
     | 
    
         
            -
                    valid &&= data.empty? && format.empty?
         
     | 
| 
       76 
     | 
    
         
            -
                  else
         
     | 
| 
       77 
     | 
    
         
            -
                    valid &&= format.empty?
         
     | 
| 
       78 
     | 
    
         
            -
                  end
         
     | 
| 
       79 
     | 
    
         
            -
                  if !valid && original
         
     | 
| 
       80 
     | 
    
         
            -
                    @message = "#{original_data.inspect} does not match #{original_format.inspect}"
         
     | 
| 
       81 
     | 
    
         
            -
                  end
         
     | 
| 
       82 
     | 
    
         
            -
                  valid
         
     | 
| 
       83 
97 
     | 
    
         
             
                end
         
     | 
| 
       84 
     | 
    
         
            -
             
     | 
| 
       85 
98 
     | 
    
         
             
              end
         
     | 
| 
       86 
99 
     | 
    
         
             
            end
         
     | 
| 
         @@ -1,60 +1,111 @@ 
     | 
|
| 
       1 
1 
     | 
    
         
             
            Shindo.tests('test_helper', 'meta') do
         
     | 
| 
       2 
2 
     | 
    
         | 
| 
       3 
     | 
    
         
            -
              tests(' 
     | 
| 
      
 3 
     | 
    
         
            +
              tests('comparing welcome data against schema') do
         
     | 
| 
      
 4 
     | 
    
         
            +
                data = {:welcome => "Hello" }
         
     | 
| 
      
 5 
     | 
    
         
            +
                data_matches_schema(:welcome => String) { data }
         
     | 
| 
      
 6 
     | 
    
         
            +
              end
         
     | 
| 
      
 7 
     | 
    
         
            +
             
     | 
| 
      
 8 
     | 
    
         
            +
              tests('#data_matches_schema') do
         
     | 
| 
      
 9 
     | 
    
         
            +
                tests('when value matches schema expectation') do
         
     | 
| 
      
 10 
     | 
    
         
            +
                  data_matches_schema({"key" => String}) { {"key" => "Value"} }
         
     | 
| 
      
 11 
     | 
    
         
            +
                end
         
     | 
| 
      
 12 
     | 
    
         
            +
             
     | 
| 
      
 13 
     | 
    
         
            +
                tests('when values within an array all match schema expectation') do
         
     | 
| 
      
 14 
     | 
    
         
            +
                  data_matches_schema({"key" => [Integer]}) { {"key" => [1, 2]} }
         
     | 
| 
      
 15 
     | 
    
         
            +
                end
         
     | 
| 
      
 16 
     | 
    
         
            +
             
     | 
| 
      
 17 
     | 
    
         
            +
                tests('when nested values match schema expectation') do
         
     | 
| 
      
 18 
     | 
    
         
            +
                  data_matches_schema({"key" => {:nested_key => String}}) { {"key" => {:nested_key => "Value"}} }
         
     | 
| 
      
 19 
     | 
    
         
            +
                end
         
     | 
| 
      
 20 
     | 
    
         
            +
             
     | 
| 
      
 21 
     | 
    
         
            +
                tests('when collection of values all match schema expectation') do
         
     | 
| 
      
 22 
     | 
    
         
            +
                  data_matches_schema([{"key" => String}]) { [{"key" => "Value"}, {"key" => "Value"}] }
         
     | 
| 
      
 23 
     | 
    
         
            +
                end
         
     | 
| 
      
 24 
     | 
    
         
            +
             
     | 
| 
      
 25 
     | 
    
         
            +
                tests('when collection is empty although schema covers optional members') do
         
     | 
| 
      
 26 
     | 
    
         
            +
                  data_matches_schema([{"key" => String}], {:allow_optional_rules => true}) { [] }
         
     | 
| 
      
 27 
     | 
    
         
            +
                end
         
     | 
| 
      
 28 
     | 
    
         
            +
             
     | 
| 
      
 29 
     | 
    
         
            +
                tests('when additional keys are passed and not strict') do
         
     | 
| 
      
 30 
     | 
    
         
            +
                  data_matches_schema({"key" => String}, {:allow_extra_keys => true}) { {"key" => "Value", :extra => "Bonus"} }
         
     | 
| 
      
 31 
     | 
    
         
            +
                end
         
     | 
| 
      
 32 
     | 
    
         
            +
             
     | 
| 
      
 33 
     | 
    
         
            +
                tests('when value is nil and schema expects NilClass') do
         
     | 
| 
      
 34 
     | 
    
         
            +
                  data_matches_schema({"key" => NilClass}) { {"key" => nil} }
         
     | 
| 
      
 35 
     | 
    
         
            +
                end
         
     | 
| 
      
 36 
     | 
    
         
            +
             
     | 
| 
      
 37 
     | 
    
         
            +
                tests('when value and schema match as hashes') do
         
     | 
| 
      
 38 
     | 
    
         
            +
                  data_matches_schema({}) { {} }
         
     | 
| 
      
 39 
     | 
    
         
            +
                end
         
     | 
| 
       4 
40 
     | 
    
         | 
| 
       5 
     | 
    
         
            -
                tests(' 
     | 
| 
      
 41 
     | 
    
         
            +
                tests('when value and schema match as arrays') do
         
     | 
| 
      
 42 
     | 
    
         
            +
                  data_matches_schema([]) { [] }
         
     | 
| 
      
 43 
     | 
    
         
            +
                end
         
     | 
| 
       6 
44 
     | 
    
         | 
| 
       7 
     | 
    
         
            -
             
     | 
| 
       8 
     | 
    
         
            -
             
     | 
| 
       9 
     | 
    
         
            -
             
     | 
| 
      
 45 
     | 
    
         
            +
                tests('when value is a Time') do
         
     | 
| 
      
 46 
     | 
    
         
            +
                  data_matches_schema({"time" => Time}) { {"time" => Time.now} }
         
     | 
| 
      
 47 
     | 
    
         
            +
                end
         
     | 
| 
       10 
48 
     | 
    
         | 
| 
       11 
     | 
    
         
            -
             
     | 
| 
       12 
     | 
    
         
            -
             
     | 
| 
       13 
     | 
    
         
            -
             
     | 
| 
      
 49 
     | 
    
         
            +
                tests('when key is missing but value should be NilClass (#1477)') do
         
     | 
| 
      
 50 
     | 
    
         
            +
                  data_matches_schema({"key" => NilClass}, {:allow_optional_rules => true}) { {} }
         
     | 
| 
      
 51 
     | 
    
         
            +
                end
         
     | 
| 
       14 
52 
     | 
    
         | 
| 
       15 
     | 
    
         
            -
             
     | 
| 
       16 
     | 
    
         
            -
             
     | 
| 
       17 
     | 
    
         
            -
             
     | 
| 
      
 53 
     | 
    
         
            +
                tests('when key is missing but value is nullable (#1477)') do
         
     | 
| 
      
 54 
     | 
    
         
            +
                  data_matches_schema({"key" => Fog::Nullable::String}, {:allow_optional_rules => true}) { {} }
         
     | 
| 
      
 55 
     | 
    
         
            +
                end
         
     | 
| 
      
 56 
     | 
    
         
            +
              end
         
     | 
| 
       18 
57 
     | 
    
         | 
| 
       19 
     | 
    
         
            -
             
     | 
| 
       20 
     | 
    
         
            -
                    formats_kernel([{:a => :b}], [{:a => Symbol}])
         
     | 
| 
       21 
     | 
    
         
            -
                  end
         
     | 
| 
      
 58 
     | 
    
         
            +
              tests('#formats backwards compatible changes') do
         
     | 
| 
       22 
59 
     | 
    
         | 
| 
       23 
     | 
    
         
            -
             
     | 
| 
       24 
     | 
    
         
            -
             
     | 
| 
       25 
     | 
    
         
            -
             
     | 
| 
      
 60 
     | 
    
         
            +
                tests('when value matches schema expectation') do
         
     | 
| 
      
 61 
     | 
    
         
            +
                  formats({"key" => String}) { {"key" => "Value"} }
         
     | 
| 
      
 62 
     | 
    
         
            +
                end
         
     | 
| 
       26 
63 
     | 
    
         | 
| 
      
 64 
     | 
    
         
            +
                tests('when values within an array all match schema expectation') do
         
     | 
| 
      
 65 
     | 
    
         
            +
                  formats({"key" => [Integer]}) { {"key" => [1, 2]} }
         
     | 
| 
       27 
66 
     | 
    
         
             
                end
         
     | 
| 
       28 
67 
     | 
    
         | 
| 
       29 
     | 
    
         
            -
                tests(' 
     | 
| 
      
 68 
     | 
    
         
            +
                tests('when nested values match schema expectation') do
         
     | 
| 
      
 69 
     | 
    
         
            +
                  formats({"key" => {:nested_key => String}}) { {"key" => {:nested_key => "Value"}} }
         
     | 
| 
      
 70 
     | 
    
         
            +
                end
         
     | 
| 
       30 
71 
     | 
    
         | 
| 
       31 
     | 
    
         
            -
             
     | 
| 
       32 
     | 
    
         
            -
             
     | 
| 
       33 
     | 
    
         
            -
             
     | 
| 
      
 72 
     | 
    
         
            +
                tests('when collection of values all match schema expectation') do
         
     | 
| 
      
 73 
     | 
    
         
            +
                  formats([{"key" => String}]) { [{"key" => "Value"}, {"key" => "Value"}] }
         
     | 
| 
      
 74 
     | 
    
         
            +
                end
         
     | 
| 
       34 
75 
     | 
    
         | 
| 
       35 
     | 
    
         
            -
             
     | 
| 
       36 
     | 
    
         
            -
             
     | 
| 
       37 
     | 
    
         
            -
             
     | 
| 
      
 76 
     | 
    
         
            +
                tests('when collection is empty although schema covers optional members') do
         
     | 
| 
      
 77 
     | 
    
         
            +
                  formats([{"key" => String}]) { [] }
         
     | 
| 
      
 78 
     | 
    
         
            +
                end
         
     | 
| 
       38 
79 
     | 
    
         | 
| 
       39 
     | 
    
         
            -
             
     | 
| 
       40 
     | 
    
         
            -
             
     | 
| 
       41 
     | 
    
         
            -
             
     | 
| 
      
 80 
     | 
    
         
            +
                tests('when additional keys are passed and not strict') do
         
     | 
| 
      
 81 
     | 
    
         
            +
                  formats({"key" => String}, false) { {"key" => "Value", :extra => "Bonus"} }
         
     | 
| 
      
 82 
     | 
    
         
            +
                end
         
     | 
| 
      
 83 
     | 
    
         
            +
             
     | 
| 
      
 84 
     | 
    
         
            +
                tests('when value is nil and schema expects NilClass') do
         
     | 
| 
      
 85 
     | 
    
         
            +
                  formats({"key" => NilClass}) { {"key" => nil} }
         
     | 
| 
      
 86 
     | 
    
         
            +
                end
         
     | 
| 
       42 
87 
     | 
    
         | 
| 
       43 
     | 
    
         
            -
             
     | 
| 
       44 
     | 
    
         
            -
             
     | 
| 
       45 
     | 
    
         
            -
             
     | 
| 
      
 88 
     | 
    
         
            +
                tests('when value and schema match as hashes') do
         
     | 
| 
      
 89 
     | 
    
         
            +
                  formats({}) { {} }
         
     | 
| 
      
 90 
     | 
    
         
            +
                end
         
     | 
| 
       46 
91 
     | 
    
         | 
| 
       47 
     | 
    
         
            -
             
     | 
| 
       48 
     | 
    
         
            -
             
     | 
| 
       49 
     | 
    
         
            -
             
     | 
| 
      
 92 
     | 
    
         
            +
                tests('when value and schema match as arrays') do
         
     | 
| 
      
 93 
     | 
    
         
            +
                  formats([]) { [] }
         
     | 
| 
      
 94 
     | 
    
         
            +
                end
         
     | 
| 
       50 
95 
     | 
    
         | 
| 
      
 96 
     | 
    
         
            +
                tests('when value is a Time') do
         
     | 
| 
      
 97 
     | 
    
         
            +
                  formats({"time" => Time}) { {"time" => Time.now} }
         
     | 
| 
      
 98 
     | 
    
         
            +
                end
         
     | 
| 
       51 
99 
     | 
    
         | 
| 
       52 
     | 
    
         
            -
             
     | 
| 
       53 
     | 
    
         
            -
             
     | 
| 
       54 
     | 
    
         
            -
             
     | 
| 
      
 100 
     | 
    
         
            +
                tests('when key is missing but value should be NilClass (#1477)') do
         
     | 
| 
      
 101 
     | 
    
         
            +
                  formats({"key" => NilClass}) { {} }
         
     | 
| 
      
 102 
     | 
    
         
            +
                end
         
     | 
| 
       55 
103 
     | 
    
         | 
| 
      
 104 
     | 
    
         
            +
                tests('when key is missing but value is nullable (#1477)') do
         
     | 
| 
      
 105 
     | 
    
         
            +
                  formats({"key" => Fog::Nullable::String}) { {} }
         
     | 
| 
       56 
106 
     | 
    
         
             
                end
         
     | 
| 
       57 
107 
     | 
    
         | 
| 
       58 
108 
     | 
    
         
             
              end
         
     | 
| 
       59 
109 
     | 
    
         | 
| 
      
 110 
     | 
    
         
            +
             
     | 
| 
       60 
111 
     | 
    
         
             
            end
         
     |