fog 1.5.0 → 1.6.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.travis.yml +21 -0
- data/README.md +3 -1
- data/Rakefile +4 -1
- data/changelog.txt +462 -0
- data/docs/storage/index.markdown +4 -4
- data/fog.gemspec +2 -2
- data/lib/fog.rb +1 -1
- data/lib/fog/atmos.rb +11 -0
- data/lib/fog/atmos/models/storage/directories.rb +48 -0
- data/lib/fog/atmos/models/storage/directory.rb +53 -0
- data/lib/fog/atmos/models/storage/file.rb +107 -0
- data/lib/fog/atmos/models/storage/files.rb +73 -0
- data/lib/fog/atmos/requests/storage/delete_namespace.rb +19 -0
- data/lib/fog/atmos/requests/storage/get_namespace.rb +20 -0
- data/lib/fog/atmos/requests/storage/head_namespace.rb +20 -0
- data/lib/fog/atmos/requests/storage/post_namespace.rb +20 -0
- data/lib/fog/atmos/requests/storage/put_namespace.rb +20 -0
- data/lib/fog/atmos/storage.rb +186 -0
- data/lib/fog/aws.rb +2 -0
- data/lib/fog/aws/auto_scaling.rb +15 -1
- data/lib/fog/aws/compute.rb +26 -17
- data/lib/fog/aws/elb.rb +14 -2
- data/lib/fog/aws/glacier.rb +172 -0
- data/lib/fog/aws/iam.rb +35 -29
- data/lib/fog/aws/models/auto_scaling/group.rb +1 -1
- data/lib/fog/aws/models/compute/flavors.rb +11 -0
- data/lib/fog/aws/models/compute/security_group.rb +22 -6
- data/lib/fog/aws/models/compute/server.rb +5 -1
- data/lib/fog/aws/models/compute/spot_request.rb +12 -0
- data/lib/fog/aws/models/compute/spot_requests.rb +1 -2
- data/lib/fog/aws/models/compute/volume.rb +7 -1
- data/lib/fog/aws/models/glacier/archive.rb +70 -0
- data/lib/fog/aws/models/glacier/archives.rb +30 -0
- data/lib/fog/aws/models/glacier/job.rb +65 -0
- data/lib/fog/aws/models/glacier/jobs.rb +45 -0
- data/lib/fog/aws/models/glacier/vault.rb +53 -0
- data/lib/fog/aws/models/glacier/vaults.rb +28 -0
- data/lib/fog/aws/models/rds/server.rb +3 -1
- data/lib/fog/aws/models/rds/snapshot.rb +1 -0
- data/lib/fog/aws/models/rds/snapshots.rb +3 -0
- data/lib/fog/aws/models/storage/file.rb +4 -3
- data/lib/fog/aws/parsers/auto_scaling/describe_auto_scaling_groups.rb +8 -1
- data/lib/fog/aws/parsers/compute/create_volume.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_instance_status.rb +8 -1
- data/lib/fog/aws/parsers/compute/describe_instances.rb +2 -0
- data/lib/fog/aws/parsers/compute/describe_reserved_instances_offerings.rb +1 -1
- data/lib/fog/aws/parsers/compute/describe_volumes.rb +2 -2
- data/lib/fog/aws/parsers/compute/run_instances.rb +2 -0
- data/lib/fog/aws/parsers/compute/spot_instance_requests.rb +1 -1
- data/lib/fog/aws/parsers/dns/list_resource_record_sets.rb +3 -1
- data/lib/fog/aws/parsers/rds/db_parser.rb +3 -1
- data/lib/fog/aws/parsers/rds/snapshot_parser.rb +1 -0
- data/lib/fog/aws/rds.rb +9 -9
- data/lib/fog/aws/requests/auto_scaling/create_auto_scaling_group.rb +1 -0
- data/lib/fog/aws/requests/auto_scaling/delete_auto_scaling_group.rb +1 -1
- data/lib/fog/aws/requests/compute/create_volume.rb +53 -14
- data/lib/fog/aws/requests/compute/describe_instance_status.rb +2 -0
- data/lib/fog/aws/requests/compute/describe_instances.rb +3 -1
- data/lib/fog/aws/requests/compute/describe_internet_gateways.rb +13 -7
- data/lib/fog/aws/requests/compute/describe_spot_instance_requests.rb +1 -0
- data/lib/fog/aws/requests/compute/describe_subnets.rb +13 -7
- data/lib/fog/aws/requests/compute/describe_volumes.rb +2 -0
- data/lib/fog/aws/requests/compute/describe_vpcs.rb +12 -6
- data/lib/fog/aws/requests/compute/request_spot_instances.rb +2 -0
- data/lib/fog/aws/requests/compute/run_instances.rb +8 -2
- data/lib/fog/aws/requests/dns/change_resource_record_sets.rb +20 -1
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +2 -2
- data/lib/fog/aws/requests/elb/describe_load_balancers.rb +1 -1
- data/lib/fog/aws/requests/glacier/abort_multipart_upload.rb +35 -0
- data/lib/fog/aws/requests/glacier/complete_multipart_upload.rb +42 -0
- data/lib/fog/aws/requests/glacier/create_archive.rb +43 -0
- data/lib/fog/aws/requests/glacier/create_vault.rb +34 -0
- data/lib/fog/aws/requests/glacier/delete_archive.rb +35 -0
- data/lib/fog/aws/requests/glacier/delete_vault.rb +34 -0
- data/lib/fog/aws/requests/glacier/delete_vault_notification_configuration.rb +33 -0
- data/lib/fog/aws/requests/glacier/describe_job.rb +35 -0
- data/lib/fog/aws/requests/glacier/describe_vault.rb +34 -0
- data/lib/fog/aws/requests/glacier/get_job_output.rb +41 -0
- data/lib/fog/aws/requests/glacier/get_vault_notification_configuration.rb +34 -0
- data/lib/fog/aws/requests/glacier/initiate_job.rb +41 -0
- data/lib/fog/aws/requests/glacier/initiate_multipart_upload.rb +38 -0
- data/lib/fog/aws/requests/glacier/list_jobs.rb +39 -0
- data/lib/fog/aws/requests/glacier/list_multipart_uploads.rb +37 -0
- data/lib/fog/aws/requests/glacier/list_parts.rb +37 -0
- data/lib/fog/aws/requests/glacier/list_vaults.rb +36 -0
- data/lib/fog/aws/requests/glacier/set_vault_notification_configuration.rb +37 -0
- data/lib/fog/aws/requests/glacier/upload_part.rb +46 -0
- data/lib/fog/aws/requests/rds/create_db_instance.rb +7 -5
- data/lib/fog/aws/requests/rds/create_db_instance_read_replica.rb +41 -1
- data/lib/fog/aws/requests/rds/create_db_snapshot.rb +1 -1
- data/lib/fog/aws/requests/rds/describe_db_instances.rb +8 -10
- data/lib/fog/aws/requests/rds/describe_db_security_groups.rb +1 -1
- data/lib/fog/aws/requests/rds/describe_db_snapshots.rb +2 -0
- data/lib/fog/aws/requests/rds/modify_db_instance.rb +7 -6
- data/lib/fog/aws/requests/rds/reboot_db_instance.rb +6 -5
- data/lib/fog/aws/requests/storage/get_object.rb +45 -2
- data/lib/fog/aws/requests/storage/upload_part.rb +1 -0
- data/lib/fog/aws/signaturev4.rb +73 -0
- data/lib/fog/aws/sqs.rb +2 -6
- data/lib/fog/bare_metal_cloud/compute.rb +3 -1
- data/lib/fog/bare_metal_cloud/requests/compute/add_server_by_configuration.rb +33 -0
- data/lib/fog/bare_metal_cloud/requests/compute/get_server.rb +17 -12
- data/lib/fog/bare_metal_cloud/requests/compute/list_configurations.rb +27 -0
- data/lib/fog/bare_metal_cloud/requests/compute/list_images.rb +4 -4
- data/lib/fog/bare_metal_cloud/requests/compute/list_plans.rb +7 -7
- data/lib/fog/bare_metal_cloud/requests/compute/list_servers.rb +2 -2
- data/lib/fog/bin.rb +7 -0
- data/lib/fog/bin/atmos.rb +31 -0
- data/lib/fog/bin/aws.rb +4 -0
- data/lib/fog/bin/ecloud.rb +4 -0
- data/lib/fog/bin/rackspace.rb +7 -0
- data/lib/fog/bin/serverlove.rb +31 -0
- data/lib/fog/bluebox/requests/compute/create_block.rb +18 -4
- data/lib/fog/brightbox/compute.rb +52 -0
- data/lib/fog/brightbox/models/compute/cloud_ip.rb +2 -0
- data/lib/fog/brightbox/models/compute/image.rb +1 -0
- data/lib/fog/brightbox/models/compute/server.rb +46 -3
- data/lib/fog/brightbox/requests/compute/create_cloud_ip.rb +3 -3
- data/lib/fog/cloudstack/compute.rb +4 -1
- data/lib/fog/cloudstack/models/compute/images.rb +15 -6
- data/lib/fog/cloudstack/models/compute/job.rb +1 -1
- data/lib/fog/cloudstack/requests/compute/attach_volume.rb +1 -1
- data/lib/fog/cloudstack/requests/compute/register_template.rb +35 -0
- data/lib/fog/compute.rb +15 -3
- data/lib/fog/core/errors.rb +1 -0
- data/lib/fog/core/time.rb +4 -0
- data/lib/fog/dynect/dns.rb +5 -5
- data/lib/fog/ecloud.rb +6 -0
- data/lib/fog/ecloud/compute.rb +3 -1
- data/lib/fog/ecloud/models/compute/ip_addresses.rb +1 -0
- data/lib/fog/ecloud/models/compute/networks.rb +1 -0
- data/lib/fog/ecloud/models/compute/server.rb +31 -1
- data/lib/fog/ecloud/requests/compute/virtual_machine_add_ip.rb +40 -0
- data/lib/fog/ecloud/requests/compute/virtual_machine_upload_file.rb +31 -0
- data/lib/fog/google/models/storage/directory.rb +2 -2
- data/lib/fog/google/models/storage/file.rb +2 -2
- data/lib/fog/google/requests/storage/get_bucket.rb +1 -2
- data/lib/fog/google/requests/storage/put_object.rb +1 -2
- data/lib/fog/google/storage.rb +1 -1
- data/lib/fog/hp/models/compute/image.rb +1 -1
- data/lib/fog/hp/models/compute/server.rb +4 -0
- data/lib/fog/hp/requests/compute/delete_security_group_rule.rb +4 -4
- data/lib/fog/hp/requests/storage/get_object.rb +8 -2
- data/lib/fog/hp/storage.rb +1 -0
- data/lib/fog/libvirt/models/compute/server.rb +1 -1
- data/lib/fog/libvirt/models/compute/templates/server.xml.erb +1 -1
- data/lib/fog/openstack.rb +7 -0
- data/lib/fog/openstack/compute.rb +4 -1
- data/lib/fog/openstack/models/compute/server.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_server.rb +8 -2
- data/lib/fog/openstack/requests/identity/list_roles_for_user_on_tenant.rb +1 -1
- data/lib/fog/openstack/requests/identity/list_tenants.rb +1 -0
- data/lib/fog/providers.rb +2 -0
- data/lib/fog/rackspace.rb +9 -7
- data/lib/fog/rackspace/block_storage.rb +114 -0
- data/lib/fog/rackspace/compute_v2.rb +123 -0
- data/lib/fog/rackspace/models/block_storage/snapshot.rb +46 -0
- data/lib/fog/rackspace/models/block_storage/snapshots.rb +25 -0
- data/lib/fog/rackspace/models/block_storage/volume.rb +58 -0
- data/lib/fog/rackspace/models/block_storage/volume_type.rb +14 -0
- data/lib/fog/rackspace/models/block_storage/volume_types.rb +25 -0
- data/lib/fog/rackspace/models/block_storage/volumes.rb +25 -0
- data/lib/fog/rackspace/models/compute_v2/attachment.rb +34 -0
- data/lib/fog/rackspace/models/compute_v2/attachments.rb +25 -0
- data/lib/fog/rackspace/models/compute_v2/flavor.rb +17 -0
- data/lib/fog/rackspace/models/compute_v2/flavors.rb +25 -0
- data/lib/fog/rackspace/models/compute_v2/image.rb +30 -0
- data/lib/fog/rackspace/models/compute_v2/images.rb +25 -0
- data/lib/fog/rackspace/models/compute_v2/server.rb +147 -0
- data/lib/fog/rackspace/models/compute_v2/servers.rb +25 -0
- data/lib/fog/rackspace/models/storage/directory.rb +3 -3
- data/lib/fog/rackspace/requests/block_storage/create_snapshot.rb +26 -0
- data/lib/fog/rackspace/requests/block_storage/create_volume.rb +27 -0
- data/lib/fog/rackspace/requests/block_storage/delete_snapshot.rb +15 -0
- data/lib/fog/rackspace/requests/block_storage/delete_volume.rb +15 -0
- data/lib/fog/rackspace/requests/block_storage/get_snapshot.rb +15 -0
- data/lib/fog/rackspace/requests/block_storage/get_volume.rb +15 -0
- data/lib/fog/rackspace/requests/block_storage/get_volume_type.rb +15 -0
- data/lib/fog/rackspace/requests/block_storage/list_snapshots.rb +15 -0
- data/lib/fog/rackspace/requests/block_storage/list_volume_types.rb +15 -0
- data/lib/fog/rackspace/requests/block_storage/list_volumes.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/attach_volume.rb +23 -0
- data/lib/fog/rackspace/requests/compute_v2/change_server_password.rb +22 -0
- data/lib/fog/rackspace/requests/compute_v2/confirm_resize_server.rb +20 -0
- data/lib/fog/rackspace/requests/compute_v2/create_server.rb +28 -0
- data/lib/fog/rackspace/requests/compute_v2/delete_attachment.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/delete_server.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/get_attachment.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/get_flavor.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/get_image.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/get_server.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/list_attachments.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/list_flavors.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/list_images.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +15 -0
- data/lib/fog/rackspace/requests/compute_v2/reboot_server.rb +22 -0
- data/lib/fog/rackspace/requests/compute_v2/rebuild_server.rb +22 -0
- data/lib/fog/rackspace/requests/compute_v2/resize_server.rb +22 -0
- data/lib/fog/rackspace/requests/compute_v2/revert_resize_server.rb +20 -0
- data/lib/fog/rackspace/requests/compute_v2/update_server.rb +22 -0
- data/lib/fog/rackspace/requests/storage/delete_object.rb +1 -1
- data/lib/fog/rackspace/requests/storage/get_object_https_url.rb +51 -0
- data/lib/fog/rackspace/requests/storage/post_set_meta_temp_url_key.rb +37 -0
- data/lib/fog/rackspace/storage.rb +4 -0
- data/lib/fog/serverlove.rb +10 -0
- data/lib/fog/serverlove/compute.rb +97 -0
- data/lib/fog/serverlove/models/compute/image.rb +57 -0
- data/lib/fog/serverlove/models/compute/images.rb +26 -0
- data/lib/fog/serverlove/models/compute/server.rb +72 -0
- data/lib/fog/serverlove/models/compute/servers.rb +26 -0
- data/lib/fog/serverlove/requests/compute/create_image.rb +32 -0
- data/lib/fog/serverlove/requests/compute/create_server.rb +34 -0
- data/lib/fog/serverlove/requests/compute/destroy_image.rb +13 -0
- data/lib/fog/serverlove/requests/compute/destroy_server.rb +13 -0
- data/lib/fog/serverlove/requests/compute/get_image.rb +13 -0
- data/lib/fog/serverlove/requests/compute/get_images.rb +13 -0
- data/lib/fog/serverlove/requests/compute/get_server.rb +13 -0
- data/lib/fog/serverlove/requests/compute/get_servers.rb +13 -0
- data/lib/fog/serverlove/requests/compute/load_standard_image.rb +13 -0
- data/lib/fog/serverlove/requests/compute/reset_server.rb +13 -0
- data/lib/fog/serverlove/requests/compute/shutdown_server.rb +13 -0
- data/lib/fog/serverlove/requests/compute/start_server.rb +13 -0
- data/lib/fog/serverlove/requests/compute/stop_server.rb +13 -0
- data/lib/fog/serverlove/requests/compute/update_image.rb +15 -0
- data/lib/fog/serverlove/requests/compute/update_server.rb +15 -0
- data/lib/fog/serverlove/util/compute/password_generator.rb +11 -0
- data/lib/fog/storage.rb +3 -0
- data/lib/fog/terremark/models/shared/image.rb +22 -0
- data/lib/fog/terremark/models/shared/images.rb +48 -0
- data/lib/fog/terremark/models/shared/internetservice.rb +67 -0
- data/lib/fog/terremark/models/shared/internetservices.rb +42 -0
- data/lib/fog/terremark/models/shared/nodeservice.rb +52 -0
- data/lib/fog/terremark/models/shared/nodeservices.rb +32 -0
- data/lib/fog/terremark/models/shared/server.rb +114 -15
- data/lib/fog/terremark/models/shared/servers.rb +7 -8
- data/lib/fog/terremark/models/shared/vdc.rb +6 -1
- data/lib/fog/terremark/parsers/shared/get_catalog.rb +7 -2
- data/lib/fog/terremark/parsers/shared/get_keys_list.rb +56 -0
- data/lib/fog/terremark/requests/shared/add_internet_service.rb +10 -9
- data/lib/fog/terremark/requests/shared/add_node_service.rb +10 -12
- data/lib/fog/terremark/requests/shared/configure_vapp.rb +61 -0
- data/lib/fog/terremark/requests/shared/create_internet_service.rb +16 -11
- data/lib/fog/terremark/requests/shared/delete_internet_service.rb +2 -1
- data/lib/fog/terremark/requests/shared/delete_node_service.rb +2 -1
- data/lib/fog/terremark/requests/shared/delete_public_ip.rb +2 -1
- data/lib/fog/terremark/requests/shared/get_internet_services.rb +2 -1
- data/lib/fog/terremark/requests/shared/get_keys_list.rb +36 -0
- data/lib/fog/terremark/requests/shared/get_node_services.rb +2 -1
- data/lib/fog/terremark/requests/shared/instantiate_vapp_template.rb +11 -1
- data/lib/fog/terremark/shared.rb +19 -1
- data/lib/fog/terremark/vcloud.rb +10 -1
- data/lib/fog/vcloud/compute.rb +13 -13
- data/lib/fog/vcloud/models/compute/catalog_items.rb +6 -2
- data/lib/fog/vcloud/models/compute/organizations.rb +1 -2
- data/lib/fog/vcloud/models/compute/server.rb +37 -3
- data/lib/fog/vcloud/models/compute/vapps.rb +1 -1
- data/lib/fog/vcloud/requests/compute/configure_org_network.rb +141 -0
- data/lib/fog/vcloud/requests/compute/configure_vm_cpus.rb +38 -0
- data/lib/fog/vcloud/requests/compute/configure_vm_memory.rb +11 -12
- data/lib/fog/vcloud/requests/compute/configure_vm_password.rb +39 -0
- data/lib/fog/vcloud/requests/compute/undeploy.rb +9 -1
- data/lib/fog/vsphere/requests/compute/vm_reboot.rb +1 -1
- data/tests/atmos/models/storage/file_update_tests.rb +19 -0
- data/tests/atmos/models/storage/nested_directories_tests.rb +23 -0
- data/tests/aws/models/compute/security_group_tests.rb +21 -12
- data/tests/aws/models/dns/records_tests.rb +8 -2
- data/tests/aws/models/glacier/model_tests.rb +47 -0
- data/tests/aws/models/iam/policies_tests.rb +2 -2
- data/tests/aws/models/rds/server_tests.rb +5 -2
- data/tests/aws/models/storage/directory_tests.rb +1 -1
- data/tests/aws/models/storage/file_tests.rb +1 -1
- data/tests/aws/models/storage/files_tests.rb +1 -1
- data/tests/aws/models/storage/url_tests.rb +8 -8
- data/tests/aws/models/storage/version_tests.rb +1 -1
- data/tests/aws/models/storage/versions_tests.rb +1 -1
- data/tests/aws/requests/auto_scaling/auto_scaling_tests.rb +5 -0
- data/tests/aws/requests/auto_scaling/helper.rb +2 -1
- data/tests/aws/requests/compute/instance_tests.rb +17 -23
- data/tests/aws/requests/compute/spot_instance_tests.rb +2 -1
- data/tests/aws/requests/compute/tag_tests.rb +1 -0
- data/tests/aws/requests/compute/volume_tests.rb +45 -4
- data/tests/aws/requests/elb/helper.rb +2 -2
- data/tests/aws/requests/elb/listener_tests.rb +2 -2
- data/tests/aws/requests/elb/load_balancer_tests.rb +1 -1
- data/tests/aws/requests/glacier/archive_tests.rb +13 -0
- data/tests/aws/requests/glacier/multipart_upload_tests.rb +30 -0
- data/tests/aws/requests/glacier/tree_hash_tests.rb +63 -0
- data/tests/aws/requests/glacier/vault_tests.rb +35 -0
- data/tests/aws/requests/rds/helper.rb +11 -5
- data/tests/aws/requests/rds/instance_tests.rb +0 -2
- data/tests/aws/requests/storage/acl_utils_tests.rb +1 -1
- data/tests/aws/requests/storage/bucket_tests.rb +1 -1
- data/tests/aws/requests/storage/multipart_upload_tests.rb +1 -1
- data/tests/aws/requests/storage/object_tests.rb +8 -0
- data/tests/aws/requests/storage/versioning_tests.rb +1 -1
- data/tests/aws/signaturev4_tests.rb +41 -0
- data/tests/brightbox/compute_tests.rb +9 -0
- data/tests/brightbox/requests/compute/helper.rb +21 -6
- data/tests/cloudstack/compute/models/volume_tests.rb +1 -1
- data/tests/cloudstack/requests/volume_tests.rb +1 -1
- data/tests/compute/helper.rb +10 -4
- data/tests/dynect/requests/dns/dns_tests.rb +39 -0
- data/tests/google/requests/storage/bucket_tests.rb +2 -3
- data/tests/google/requests/storage/object_tests.rb +1 -1
- data/tests/helper.rb +10 -3
- data/tests/helpers/formats_helper.rb +4 -2
- data/tests/helpers/formats_helper_tests.rb +9 -0
- data/tests/helpers/mock_helper.rb +6 -1
- data/tests/helpers/model_helper.rb +0 -3
- 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/security_group_tests.rb +1 -1
- data/tests/hp/models/compute/security_groups_tests.rb +1 -1
- data/tests/hp/requests/cdn/container_tests.rb +1 -1
- data/tests/hp/requests/compute/address_tests.rb +1 -1
- 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/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 +1 -1
- data/tests/hp/requests/storage/container_tests.rb +1 -1
- data/tests/hp/requests/storage/object_tests.rb +1 -1
- data/tests/local/models/file_tests.rb +1 -1
- data/tests/rackspace/models/block_storage/snapshot_tests.rb +20 -0
- data/tests/rackspace/models/block_storage/snapshots_tests.rb +20 -0
- data/tests/rackspace/models/block_storage/volume_tests.rb +27 -0
- data/tests/rackspace/models/block_storage/volume_types_tests.rb +20 -0
- data/tests/rackspace/models/block_storage/volumes_tests.rb +11 -0
- data/tests/rackspace/models/compute_v2/flavors_tests.rb +20 -0
- data/tests/rackspace/models/compute_v2/images_tests.rb +22 -0
- data/tests/rackspace/models/compute_v2/server_tests.rb +62 -0
- data/tests/rackspace/models/compute_v2/servers_tests.rb +14 -0
- data/tests/rackspace/requests/block_storage/snapshot_tests.rb +81 -0
- data/tests/rackspace/requests/block_storage/volume_tests.rb +61 -0
- data/tests/rackspace/requests/block_storage/volume_type_tests.rb +31 -0
- data/tests/rackspace/requests/compute_v2/attachment_tests.rb +68 -0
- data/tests/rackspace/requests/compute_v2/flavor_tests.rb +43 -0
- data/tests/rackspace/requests/compute_v2/image_tests.rb +47 -0
- data/tests/rackspace/requests/compute_v2/server_tests.rb +147 -0
- data/tests/rackspace/requests/storage/account_tests.rb +17 -0
- data/tests/rackspace/requests/storage/container_tests.rb +1 -1
- data/tests/rackspace/requests/storage/large_object_tests.rb +1 -1
- data/tests/rackspace/requests/storage/object_tests.rb +41 -2
- data/tests/serverlove/requests/compute/image_tests.rb +57 -0
- data/tests/serverlove/requests/compute/server_tests.rb +85 -0
- data/tests/serverlove/util/compute/password_generator_tests.rb +19 -0
- data/tests/storage/models/directories_tests.rb +1 -1
- data/tests/storage/models/directory_test.rb +1 -1
- data/tests/storage/models/file_tests.rb +1 -1
- data/tests/storage/models/files_tests.rb +1 -1
- metadata +188 -3
@@ -171,6 +171,45 @@ Shindo.tests('Dynect::dns | DNS requests', ['dynect', 'dns']) do
|
|
171
171
|
tests("delete_zone('#{@domain}')").formats(delete_zone_format) do
|
172
172
|
@dns.delete_zone(@domain).body
|
173
173
|
end
|
174
|
+
|
175
|
+
tests("job handling") do
|
176
|
+
pending unless Fog.mocking?
|
177
|
+
|
178
|
+
old_mock_value = Excon.defaults[:mock]
|
179
|
+
Excon.stubs.clear
|
180
|
+
|
181
|
+
tests("returns final response from a complete job") do
|
182
|
+
begin
|
183
|
+
Excon.defaults[:mock] = true
|
184
|
+
|
185
|
+
Excon.stub({:method => :post, :path => "/REST/Session"}, {:body=>"{\"status\": \"success\", \"data\": {\"token\": \"foobar\", \"version\": \"2.3.1\"}, \"job_id\": 150583906, \"msgs\": [{\"INFO\": \"login: Login successful\", \"SOURCE\": \"BLL\", \"ERR_CD\": null, \"LVL\": \"INFO\"}]}", :headers=>{"Content-Type"=>"application/json"}, :status=>200})
|
186
|
+
|
187
|
+
Excon.stub({:method => :get, :path => "/REST/Zone/example.com"}, {:status => 307, :body => '/REST/Job/150576635', :headers => {'Content-Type' => 'text/html', 'Location' => '/REST/Job/150576635'}})
|
188
|
+
Excon.stub({:method => :get, :path => "/REST/Job/150576635"}, {:status => 307, :body => '{"status":"success"}', :headers => {'Content-Type' => 'application/json'}})
|
189
|
+
|
190
|
+
Fog::DNS::Dynect::Real.new.request(:method => :get, :path => "Zone/example.com").body.should == { "status" => "success" }
|
191
|
+
ensure
|
192
|
+
Excon.stubs.clear
|
193
|
+
Excon.defaults[:mock] = old_mock_value
|
194
|
+
end
|
195
|
+
end
|
196
|
+
|
197
|
+
tests("passes expects through when polling a job") do
|
198
|
+
begin
|
199
|
+
Excon.defaults[:mock] = true
|
200
|
+
|
201
|
+
Excon.stub({:method => :post, :path => "/REST/Session"}, {:body=>"{\"status\": \"success\", \"data\": {\"token\": \"foobar\", \"version\": \"2.3.1\"}, \"job_id\": 150583906, \"msgs\": [{\"INFO\": \"login: Login successful\", \"SOURCE\": \"BLL\", \"ERR_CD\": null, \"LVL\": \"INFO\"}]}", :headers=>{"Content-Type"=>"application/json"}, :status=>200})
|
202
|
+
|
203
|
+
Excon.stub({:method => :get, :path => "/REST/Zone/example.com"}, {:status => 307, :body => '/REST/Job/150576635', :headers => {'Content-Type' => 'text/html', 'Location' => '/REST/Job/150576635'}})
|
204
|
+
Excon.stub({:method => :get, :path => "/REST/Job/150576635"}, {:status => 404, :body => '{"status":"success"}', :headers => {'Content-Type' => 'application/json'}})
|
205
|
+
|
206
|
+
Fog::DNS::Dynect::Real.new.request(:method => :get, :expects => 404, :path => "Zone/example.com").body.should == { "status" => "success" }
|
207
|
+
ensure
|
208
|
+
Excon.stubs.clear
|
209
|
+
Excon.defaults[:mock] = old_mock_value
|
210
|
+
end
|
211
|
+
end
|
212
|
+
end
|
174
213
|
end
|
175
214
|
|
176
215
|
tests('failure') do
|
@@ -1,4 +1,4 @@
|
|
1
|
-
Shindo.tests('Fog::Storage[:google] | bucket requests', [
|
1
|
+
Shindo.tests('Fog::Storage[:google] | bucket requests', ["google"]) do
|
2
2
|
|
3
3
|
tests('success') do
|
4
4
|
|
@@ -16,8 +16,7 @@ Shindo.tests('Fog::Storage[:google] | bucket requests', [:google]) do
|
|
16
16
|
'DisplayName' => String,
|
17
17
|
'ID' => String
|
18
18
|
},
|
19
|
-
'Size' => Integer
|
20
|
-
'StorageClass' => String
|
19
|
+
'Size' => Integer
|
21
20
|
}]
|
22
21
|
}
|
23
22
|
|
data/tests/helper.rb
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
require 'fog'
|
2
|
-
require 'fog/bin' # for available_providers
|
2
|
+
require 'fog/bin' # for available_providers and registered_providers
|
3
3
|
|
4
4
|
require File.expand_path(File.join(File.dirname(__FILE__), 'helpers', 'mock_helper'))
|
5
5
|
|
@@ -12,9 +12,16 @@ def array_differences(array_a, array_b)
|
|
12
12
|
end
|
13
13
|
|
14
14
|
# check to see which credentials are available and add others to the skipped tags list
|
15
|
-
all_providers =
|
15
|
+
all_providers = Fog.registered_providers.map {|provider| provider.downcase}
|
16
|
+
|
17
|
+
# Manually remove these providers since they are local applications, not lacking credentials
|
18
|
+
all_providers = all_providers - ["libvirt", "virtualbox", "vmfusion"]
|
19
|
+
|
16
20
|
available_providers = Fog.available_providers.map {|provider| provider.downcase}
|
17
|
-
|
21
|
+
|
22
|
+
unavailable_providers = all_providers - available_providers
|
23
|
+
|
24
|
+
for provider in unavailable_providers
|
18
25
|
Formatador.display_line("[yellow]Skipping tests for [bold]#{provider}[/] [yellow]due to lacking credentials (add some to '~/.fog' to run them)[/]")
|
19
26
|
Thread.current[:tags] << ('-' << provider)
|
20
27
|
end
|
@@ -48,7 +48,8 @@ module Shindo
|
|
48
48
|
format.delete(key)
|
49
49
|
case value
|
50
50
|
when Array
|
51
|
-
|
51
|
+
p("#{key.inspect} not Array: #{datum.inspect}") unless datum.is_a?(Array)
|
52
|
+
valid &&= datum.is_a?(Array)
|
52
53
|
if datum.is_a?(Array) && !value.empty?
|
53
54
|
for element in datum
|
54
55
|
type = value.first
|
@@ -60,7 +61,8 @@ module Shindo
|
|
60
61
|
end
|
61
62
|
end
|
62
63
|
when Hash
|
63
|
-
|
64
|
+
p("#{key.inspect} not Hash: #{datum.inspect}") unless datum.is_a?(Hash)
|
65
|
+
valid &&= datum.is_a?(Hash)
|
64
66
|
valid &&= formats_kernel(datum, value, false, strict)
|
65
67
|
else
|
66
68
|
p "#{key.inspect} not #{value.inspect}: #{datum.inspect}" unless datum.is_a?(value)
|
@@ -40,6 +40,15 @@ Shindo.tests('test_helper', 'meta') do
|
|
40
40
|
!formats_kernel({}, {:a => String})
|
41
41
|
end
|
42
42
|
|
43
|
+
test('when an array is expected but another data type is found') do
|
44
|
+
!formats_kernel({:a => 'not an array'}, {:a => []})
|
45
|
+
end
|
46
|
+
|
47
|
+
test('when a hash is expected but another data type is found') do
|
48
|
+
!formats_kernel({:a => 'not a hash'}, {:a => {}}, true, false)
|
49
|
+
end
|
50
|
+
|
51
|
+
|
43
52
|
test('non strict extra data') do
|
44
53
|
!formats_kernel({:a => :b, :b => :c}, {:z => Symbol}, true, false)
|
45
54
|
end
|
@@ -11,12 +11,17 @@ if Fog.mock?
|
|
11
11
|
Fog.credentials = {
|
12
12
|
:aws_access_key_id => 'aws_access_key_id',
|
13
13
|
:aws_secret_access_key => 'aws_secret_access_key',
|
14
|
+
:atmos_storage_token => 'atmos_token',
|
15
|
+
:atmos_storage_secret => 'atmos_secret',
|
16
|
+
:atmos_storage_endpoint => 'http://atmos.is.cool:1000/test1.0',
|
14
17
|
:bluebox_api_key => 'bluebox_api_key',
|
15
18
|
:bluebox_customer_id => 'bluebox_customer_id',
|
16
19
|
:brightbox_client_id => 'brightbox_client_id',
|
17
20
|
:brightbox_secret => 'brightbox_secret',
|
21
|
+
:cloudstack_disk_offering_id => '',
|
18
22
|
:cloudstack_host => 'http://cloudstack.example.org',
|
19
|
-
:
|
23
|
+
:cloudstack_network_ids => '',
|
24
|
+
:cloudstack_service_offering_id => '4437ac6c-9fe3-477a-57ec-60a5a45896a4',
|
20
25
|
:cloudstack_template_id => '8a31cf9c-f248-0588-256e-9dbf58785216',
|
21
26
|
:cloudstack_zone_id => 'c554c592-e09c-9df5-7688-4a32754a4305',
|
22
27
|
:clodo_api_key => 'clodo_api_key',
|
@@ -0,0 +1,20 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::BlockStorage | snapshot', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::BlockStorage.new
|
6
|
+
volume = service.volumes.create({
|
7
|
+
:display_name => "fog_#{Time.now.to_i.to_s}",
|
8
|
+
:size => 100
|
9
|
+
})
|
10
|
+
|
11
|
+
volume.wait_for { ready? }
|
12
|
+
|
13
|
+
options = { :display_name => "fog_#{Time.now.to_i.to_s}", :volume_id => volume.id }
|
14
|
+
model_tests(service.snapshots, options, false) do
|
15
|
+
@instance.wait_for { ready? }
|
16
|
+
end
|
17
|
+
|
18
|
+
volume.wait_for { snapshots.empty? }
|
19
|
+
volume.destroy
|
20
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::BlockStorage | snapshots', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::BlockStorage.new
|
6
|
+
volume = service.volumes.create({
|
7
|
+
:display_name => "fog_#{Time.now.to_i.to_s}",
|
8
|
+
:size => 100
|
9
|
+
})
|
10
|
+
|
11
|
+
volume.wait_for { ready? }
|
12
|
+
|
13
|
+
options = { :display_name => "fog_#{Time.now.to_i.to_s}", :volume_id => volume.id }
|
14
|
+
collection_tests(service.snapshots, options, false) do
|
15
|
+
@instance.wait_for { ready? }
|
16
|
+
end
|
17
|
+
|
18
|
+
volume.wait_for { snapshots.empty? }
|
19
|
+
volume.destroy
|
20
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::BlockStorage | volume', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::BlockStorage.new
|
6
|
+
options = { :display_name => "fog_#{Time.now.to_i.to_s}", :size => 100 }
|
7
|
+
|
8
|
+
model_tests(service.volumes, options, false) do
|
9
|
+
@instance.wait_for { ready? }
|
10
|
+
|
11
|
+
tests('#attached?').succeeds do
|
12
|
+
@instance.state = 'in-use'
|
13
|
+
returns(true) { @instance.attached? }
|
14
|
+
end
|
15
|
+
|
16
|
+
tests('#snapshots').succeeds do
|
17
|
+
snapshot = service.snapshots.create({ :volume_id => @instance.id })
|
18
|
+
snapshot.wait_for { ready? }
|
19
|
+
|
20
|
+
returns(true) { @instance.snapshots.first.id == snapshot.id }
|
21
|
+
|
22
|
+
snapshot.destroy
|
23
|
+
end
|
24
|
+
|
25
|
+
@instance.wait_for { snapshots.empty? }
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::BlockStorage | volume_types', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::BlockStorage.new
|
6
|
+
|
7
|
+
tests("success") do
|
8
|
+
tests("#all").succeeds do
|
9
|
+
service.volume_types.all
|
10
|
+
end
|
11
|
+
|
12
|
+
tests("#get").succeeds do
|
13
|
+
service.volume_types.get(1)
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
tests("failure").returns(nil) do
|
18
|
+
service.volume_types.get('some_random_identity')
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::BlockStorage | volumes', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::BlockStorage.new
|
6
|
+
options = { :display_name => "fog_#{Time.now.to_i.to_s}", :size => 100 }
|
7
|
+
|
8
|
+
collection_tests(service.volumes, options, false) do
|
9
|
+
@instance.wait_for { ready? }
|
10
|
+
end
|
11
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
Shindo.tests('Fog::Compute::RackspaceV2 | flavors', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Compute::RackspaceV2.new
|
6
|
+
|
7
|
+
tests("success") do
|
8
|
+
tests("#all").succeeds do
|
9
|
+
service.flavors.all
|
10
|
+
end
|
11
|
+
|
12
|
+
tests("#get").succeeds do
|
13
|
+
service.flavors.get(2)
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
tests("failure").returns(nil) do
|
18
|
+
service.flavors.get('some_random_identity')
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,22 @@
|
|
1
|
+
Shindo.tests('Fog::Compute::RackspaceV2 | images', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Compute::RackspaceV2.new
|
6
|
+
image_id = nil
|
7
|
+
|
8
|
+
tests("success") do
|
9
|
+
tests("#all").succeeds do
|
10
|
+
images = service.images.all
|
11
|
+
image_id = images.first.id
|
12
|
+
end
|
13
|
+
|
14
|
+
tests("#get").succeeds do
|
15
|
+
service.images.get(image_id)
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
tests("failure").returns(nil) do
|
20
|
+
service.images.get('some_random_identity')
|
21
|
+
end
|
22
|
+
end
|
@@ -0,0 +1,62 @@
|
|
1
|
+
Shindo.tests('Fog::Compute::RackspaceV2 | server', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Compute::RackspaceV2.new
|
6
|
+
options = {
|
7
|
+
:name => "fog_server_#{Time.now.to_i.to_s}",
|
8
|
+
:flavor_id => 2,
|
9
|
+
:image_id => '3afe97b2-26dc-49c5-a2cc-a2fc8d80c001'
|
10
|
+
}
|
11
|
+
|
12
|
+
model_tests(service.servers, options, false) do
|
13
|
+
@instance.wait_for { ready? }
|
14
|
+
tests('#reboot("SOFT")').succeeds do
|
15
|
+
@instance.reboot('SOFT')
|
16
|
+
returns('REBOOT') { @instance.state }
|
17
|
+
end
|
18
|
+
|
19
|
+
@instance.wait_for { ready? }
|
20
|
+
tests('#reboot("HARD")').succeeds do
|
21
|
+
@instance.reboot('HARD')
|
22
|
+
returns('HARD_REBOOT') { @instance.state }
|
23
|
+
end
|
24
|
+
|
25
|
+
@instance.wait_for { ready? }
|
26
|
+
tests('#rebuild').succeeds do
|
27
|
+
@instance.rebuild('5cebb13a-f783-4f8c-8058-c4182c724ccd')
|
28
|
+
returns('REBUILD') { @instance.state }
|
29
|
+
end
|
30
|
+
|
31
|
+
@instance.wait_for { ready? }
|
32
|
+
tests('#resize').succeeds do
|
33
|
+
@instance.resize(3)
|
34
|
+
returns('RESIZE') { @instance.state }
|
35
|
+
end
|
36
|
+
|
37
|
+
@instance.wait_for { state == 'VERIFY_RESIZE' }
|
38
|
+
tests('#confirm_resize').succeeds do
|
39
|
+
@instance.confirm_resize
|
40
|
+
end
|
41
|
+
|
42
|
+
@instance.wait_for { ready? }
|
43
|
+
tests('#resize').succeeds do
|
44
|
+
@instance.resize(2)
|
45
|
+
returns('RESIZE') { @instance.state }
|
46
|
+
end
|
47
|
+
|
48
|
+
@instance.wait_for { state == 'VERIFY_RESIZE' }
|
49
|
+
tests('#revert_resize').succeeds do
|
50
|
+
@instance.revert_resize
|
51
|
+
end
|
52
|
+
|
53
|
+
@instance.wait_for { ready? }
|
54
|
+
tests('#change_admin_password').succeeds do
|
55
|
+
@instance.change_admin_password('somerandompassword')
|
56
|
+
returns('PASSWORD') { @instance.state }
|
57
|
+
returns('somerandompassword') { @instance.password }
|
58
|
+
end
|
59
|
+
|
60
|
+
@instance.wait_for { ready? }
|
61
|
+
end
|
62
|
+
end
|