tecnh-fog 0.2.23.vpc
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile +13 -0
- data/Gemfile.lock +75 -0
- data/README.rdoc +140 -0
- data/Rakefile +153 -0
- data/benchs/fog_vs.rb +106 -0
- data/benchs/params.rb +43 -0
- data/benchs/parse_vs_push.rb +60 -0
- data/bin/fog +42 -0
- data/examples/bluebox_create.rb +33 -0
- data/fog.gemspec +631 -0
- data/lib/fog.rb +86 -0
- data/lib/fog/attributes.rb +183 -0
- data/lib/fog/aws.rb +195 -0
- data/lib/fog/aws/bin.rb +73 -0
- data/lib/fog/aws/ec2.rb +221 -0
- data/lib/fog/aws/elb.rb +105 -0
- data/lib/fog/aws/models/ec2/address.rb +67 -0
- data/lib/fog/aws/models/ec2/addresses.rb +62 -0
- data/lib/fog/aws/models/ec2/flavor.rb +21 -0
- data/lib/fog/aws/models/ec2/flavors.rb +43 -0
- data/lib/fog/aws/models/ec2/image.rb +44 -0
- data/lib/fog/aws/models/ec2/images.rb +42 -0
- data/lib/fog/aws/models/ec2/key_pair.rb +34 -0
- data/lib/fog/aws/models/ec2/key_pairs.rb +43 -0
- data/lib/fog/aws/models/ec2/security_group.rb +55 -0
- data/lib/fog/aws/models/ec2/security_groups.rb +43 -0
- data/lib/fog/aws/models/ec2/server.rb +178 -0
- data/lib/fog/aws/models/ec2/servers.rb +49 -0
- data/lib/fog/aws/models/ec2/snapshot.rb +57 -0
- data/lib/fog/aws/models/ec2/snapshots.rb +65 -0
- data/lib/fog/aws/models/ec2/volume.rb +97 -0
- data/lib/fog/aws/models/ec2/volumes.rb +58 -0
- data/lib/fog/aws/models/s3/directories.rb +49 -0
- data/lib/fog/aws/models/s3/directory.rb +70 -0
- data/lib/fog/aws/models/s3/file.rb +84 -0
- data/lib/fog/aws/models/s3/files.rb +88 -0
- data/lib/fog/aws/parsers/ec2/allocate_address.rb +19 -0
- data/lib/fog/aws/parsers/ec2/attach_volume.rb +22 -0
- data/lib/fog/aws/parsers/ec2/basic.rb +25 -0
- data/lib/fog/aws/parsers/ec2/create_image.rb +20 -0
- data/lib/fog/aws/parsers/ec2/create_key_pair.rb +20 -0
- data/lib/fog/aws/parsers/ec2/create_snapshot.rb +26 -0
- data/lib/fog/aws/parsers/ec2/create_volume.rb +24 -0
- data/lib/fog/aws/parsers/ec2/deregister_image.rb +20 -0
- data/lib/fog/aws/parsers/ec2/describe_addresses.rb +30 -0
- data/lib/fog/aws/parsers/ec2/describe_availability_zones.rb +30 -0
- data/lib/fog/aws/parsers/ec2/describe_images.rb +60 -0
- data/lib/fog/aws/parsers/ec2/describe_instances.rb +93 -0
- data/lib/fog/aws/parsers/ec2/describe_key_pairs.rb +30 -0
- data/lib/fog/aws/parsers/ec2/describe_regions.rb +30 -0
- data/lib/fog/aws/parsers/ec2/describe_reserved_instances.rb +36 -0
- data/lib/fog/aws/parsers/ec2/describe_security_groups.rb +75 -0
- data/lib/fog/aws/parsers/ec2/describe_snapshots.rb +34 -0
- data/lib/fog/aws/parsers/ec2/describe_volumes.rb +57 -0
- data/lib/fog/aws/parsers/ec2/detach_volume.rb +22 -0
- data/lib/fog/aws/parsers/ec2/get_console_output.rb +32 -0
- data/lib/fog/aws/parsers/ec2/register_image.rb +20 -0
- data/lib/fog/aws/parsers/ec2/run_instances.rb +89 -0
- data/lib/fog/aws/parsers/ec2/start_stop_instances.rb +41 -0
- data/lib/fog/aws/parsers/ec2/terminate_instances.rb +55 -0
- data/lib/fog/aws/parsers/elb/create_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/elb/delete_load_balancer.rb +24 -0
- data/lib/fog/aws/parsers/elb/deregister_instances_from_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/elb/describe_instance_health.rb +30 -0
- data/lib/fog/aws/parsers/elb/describe_load_balancers.rb +101 -0
- data/lib/fog/aws/parsers/elb/disable_availability_zones_for_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/elb/enable_availability_zones_for_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/elb/register_instances_with_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/s3/access_control_list.rb +46 -0
- data/lib/fog/aws/parsers/s3/copy_object.rb +22 -0
- data/lib/fog/aws/parsers/s3/get_bucket.rb +46 -0
- data/lib/fog/aws/parsers/s3/get_bucket_location.rb +20 -0
- data/lib/fog/aws/parsers/s3/get_bucket_logging.rb +40 -0
- data/lib/fog/aws/parsers/s3/get_bucket_object_versions.rb +88 -0
- data/lib/fog/aws/parsers/s3/get_bucket_versioning.rb +24 -0
- data/lib/fog/aws/parsers/s3/get_request_payment.rb +20 -0
- data/lib/fog/aws/parsers/s3/get_service.rb +32 -0
- data/lib/fog/aws/parsers/simpledb/basic.rb +31 -0
- data/lib/fog/aws/parsers/simpledb/domain_metadata.rb +32 -0
- data/lib/fog/aws/parsers/simpledb/get_attributes.rb +36 -0
- data/lib/fog/aws/parsers/simpledb/list_domains.rb +30 -0
- data/lib/fog/aws/parsers/simpledb/select.rb +41 -0
- data/lib/fog/aws/requests/ec2/allocate_address.rb +51 -0
- data/lib/fog/aws/requests/ec2/associate_address.rb +57 -0
- data/lib/fog/aws/requests/ec2/attach_volume.rb +81 -0
- data/lib/fog/aws/requests/ec2/authorize_security_group_ingress.rb +86 -0
- data/lib/fog/aws/requests/ec2/create_image.rb +58 -0
- data/lib/fog/aws/requests/ec2/create_key_pair.rb +54 -0
- data/lib/fog/aws/requests/ec2/create_security_group.rb +53 -0
- data/lib/fog/aws/requests/ec2/create_snapshot.rb +64 -0
- data/lib/fog/aws/requests/ec2/create_volume.rb +73 -0
- data/lib/fog/aws/requests/ec2/delete_key_pair.rb +43 -0
- data/lib/fog/aws/requests/ec2/delete_security_group.rb +45 -0
- data/lib/fog/aws/requests/ec2/delete_snapshot.rb +46 -0
- data/lib/fog/aws/requests/ec2/delete_volume.rb +52 -0
- data/lib/fog/aws/requests/ec2/deregister_image.rb +51 -0
- data/lib/fog/aws/requests/ec2/describe_addresses.rb +56 -0
- data/lib/fog/aws/requests/ec2/describe_availability_zones.rb +64 -0
- data/lib/fog/aws/requests/ec2/describe_images.rb +70 -0
- data/lib/fog/aws/requests/ec2/describe_instances.rb +129 -0
- data/lib/fog/aws/requests/ec2/describe_key_pairs.rb +58 -0
- data/lib/fog/aws/requests/ec2/describe_regions.rb +61 -0
- data/lib/fog/aws/requests/ec2/describe_reserved_instances.rb +48 -0
- data/lib/fog/aws/requests/ec2/describe_security_groups.rb +66 -0
- data/lib/fog/aws/requests/ec2/describe_snapshots.rb +80 -0
- data/lib/fog/aws/requests/ec2/describe_volumes.rb +86 -0
- data/lib/fog/aws/requests/ec2/detach_volume.rb +58 -0
- data/lib/fog/aws/requests/ec2/disassociate_address.rb +52 -0
- data/lib/fog/aws/requests/ec2/get_console_output.rb +52 -0
- data/lib/fog/aws/requests/ec2/modify_image_attributes.rb +39 -0
- data/lib/fog/aws/requests/ec2/modify_snapshot_attribute.rb +38 -0
- data/lib/fog/aws/requests/ec2/reboot_instances.rb +50 -0
- data/lib/fog/aws/requests/ec2/register_image.rb +89 -0
- data/lib/fog/aws/requests/ec2/release_address.rb +43 -0
- data/lib/fog/aws/requests/ec2/revoke_security_group_ingress.rb +74 -0
- data/lib/fog/aws/requests/ec2/run_instances.rb +159 -0
- data/lib/fog/aws/requests/ec2/start_instances.rb +38 -0
- data/lib/fog/aws/requests/ec2/stop_instances.rb +38 -0
- data/lib/fog/aws/requests/ec2/terminate_instances.rb +94 -0
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +59 -0
- data/lib/fog/aws/requests/elb/delete_load_balancer.rb +42 -0
- data/lib/fog/aws/requests/elb/deregister_instances_from_load_balancer.rb +47 -0
- data/lib/fog/aws/requests/elb/describe_instance_health.rb +46 -0
- data/lib/fog/aws/requests/elb/describe_load_balancers.rb +59 -0
- data/lib/fog/aws/requests/elb/disable_availability_zones_for_load_balancer.rb +46 -0
- data/lib/fog/aws/requests/elb/enable_availability_zones_for_load_balancer.rb +46 -0
- data/lib/fog/aws/requests/elb/register_instances_with_load_balancer.rb +47 -0
- data/lib/fog/aws/requests/s3/copy_object.rb +72 -0
- data/lib/fog/aws/requests/s3/delete_bucket.rb +46 -0
- data/lib/fog/aws/requests/s3/delete_object.rb +45 -0
- data/lib/fog/aws/requests/s3/get_bucket.rb +98 -0
- data/lib/fog/aws/requests/s3/get_bucket_acl.rb +55 -0
- data/lib/fog/aws/requests/s3/get_bucket_location.rb +48 -0
- data/lib/fog/aws/requests/s3/get_bucket_logging.rb +55 -0
- data/lib/fog/aws/requests/s3/get_bucket_object_versions.rb +80 -0
- data/lib/fog/aws/requests/s3/get_bucket_versioning.rb +45 -0
- data/lib/fog/aws/requests/s3/get_object.rb +104 -0
- data/lib/fog/aws/requests/s3/get_object_acl.rb +66 -0
- data/lib/fog/aws/requests/s3/get_object_torrent.rb +55 -0
- data/lib/fog/aws/requests/s3/get_object_url.rb +54 -0
- data/lib/fog/aws/requests/s3/get_request_payment.rb +48 -0
- data/lib/fog/aws/requests/s3/get_service.rb +53 -0
- data/lib/fog/aws/requests/s3/head_object.rb +64 -0
- data/lib/fog/aws/requests/s3/put_bucket.rb +65 -0
- data/lib/fog/aws/requests/s3/put_bucket_acl.rb +80 -0
- data/lib/fog/aws/requests/s3/put_bucket_logging.rb +87 -0
- data/lib/fog/aws/requests/s3/put_bucket_versioning.rb +40 -0
- data/lib/fog/aws/requests/s3/put_object.rb +71 -0
- data/lib/fog/aws/requests/s3/put_object_url.rb +54 -0
- data/lib/fog/aws/requests/s3/put_request_payment.rb +47 -0
- data/lib/fog/aws/requests/simpledb/batch_put_attributes.rb +64 -0
- data/lib/fog/aws/requests/simpledb/create_domain.rb +43 -0
- data/lib/fog/aws/requests/simpledb/delete_attributes.rb +65 -0
- data/lib/fog/aws/requests/simpledb/delete_domain.rb +44 -0
- data/lib/fog/aws/requests/simpledb/domain_metadata.rb +75 -0
- data/lib/fog/aws/requests/simpledb/get_attributes.rb +71 -0
- data/lib/fog/aws/requests/simpledb/list_domains.rb +58 -0
- data/lib/fog/aws/requests/simpledb/put_attributes.rb +78 -0
- data/lib/fog/aws/requests/simpledb/select.rb +42 -0
- data/lib/fog/aws/s3.rb +209 -0
- data/lib/fog/aws/simpledb.rb +171 -0
- data/lib/fog/bin.rb +68 -0
- data/lib/fog/bluebox.rb +87 -0
- data/lib/fog/bluebox/bin.rb +43 -0
- data/lib/fog/bluebox/models/flavor.rb +43 -0
- data/lib/fog/bluebox/models/flavors.rb +32 -0
- data/lib/fog/bluebox/models/image.rb +17 -0
- data/lib/fog/bluebox/models/images.rb +34 -0
- data/lib/fog/bluebox/models/server.rb +79 -0
- data/lib/fog/bluebox/models/servers.rb +33 -0
- data/lib/fog/bluebox/requests/create_block.rb +39 -0
- data/lib/fog/bluebox/requests/destroy_block.rb +32 -0
- data/lib/fog/bluebox/requests/get_block.rb +32 -0
- data/lib/fog/bluebox/requests/get_blocks.rb +34 -0
- data/lib/fog/bluebox/requests/get_product.rb +32 -0
- data/lib/fog/bluebox/requests/get_products.rb +31 -0
- data/lib/fog/bluebox/requests/get_template.rb +32 -0
- data/lib/fog/bluebox/requests/get_templates.rb +32 -0
- data/lib/fog/bluebox/requests/reboot_block.rb +33 -0
- data/lib/fog/collection.rb +121 -0
- data/lib/fog/connection.rb +35 -0
- data/lib/fog/credentials.rb +56 -0
- data/lib/fog/deprecation.rb +17 -0
- data/lib/fog/errors.rb +20 -0
- data/lib/fog/go_grid.rb +97 -0
- data/lib/fog/go_grid/bin.rb +30 -0
- data/lib/fog/go_grid/requests/common_lookup_list.rb +34 -0
- data/lib/fog/go_grid/requests/grid_image_list.rb +37 -0
- data/lib/fog/go_grid/requests/grid_ip_list.rb +36 -0
- data/lib/fog/go_grid/requests/grid_loadbalancer_list.rb +34 -0
- data/lib/fog/go_grid/requests/grid_server_add.rb +42 -0
- data/lib/fog/go_grid/requests/grid_server_delete.rb +31 -0
- data/lib/fog/go_grid/requests/grid_server_get.rb +31 -0
- data/lib/fog/go_grid/requests/grid_server_list.rb +36 -0
- data/lib/fog/go_grid/requests/grid_server_power.rb +32 -0
- data/lib/fog/hmac.rb +48 -0
- data/lib/fog/linode.rb +80 -0
- data/lib/fog/linode/bin.rb +30 -0
- data/lib/fog/linode/requests/avail_datacenters.rb +29 -0
- data/lib/fog/linode/requests/avail_distributions.rb +36 -0
- data/lib/fog/linode/requests/avail_kernels.rb +34 -0
- data/lib/fog/linode/requests/avail_linodeplans.rb +33 -0
- data/lib/fog/linode/requests/avail_stackscripts.rb +35 -0
- data/lib/fog/linode/requests/linode_create.rb +39 -0
- data/lib/fog/linode/requests/linode_delete.rb +34 -0
- data/lib/fog/linode/requests/linode_list.rb +36 -0
- data/lib/fog/linode/requests/linode_reboot.rb +34 -0
- data/lib/fog/local.rb +59 -0
- data/lib/fog/local/bin.rb +34 -0
- data/lib/fog/local/models/directories.rb +37 -0
- data/lib/fog/local/models/directory.rb +50 -0
- data/lib/fog/local/models/file.rb +58 -0
- data/lib/fog/local/models/files.rb +74 -0
- data/lib/fog/model.rb +57 -0
- data/lib/fog/new_servers.rb +89 -0
- data/lib/fog/new_servers/bin.rb +30 -0
- data/lib/fog/new_servers/requests/add_server.rb +39 -0
- data/lib/fog/new_servers/requests/cancel_server.rb +36 -0
- data/lib/fog/new_servers/requests/get_server.rb +42 -0
- data/lib/fog/new_servers/requests/list_images.rb +33 -0
- data/lib/fog/new_servers/requests/list_plans.rb +36 -0
- data/lib/fog/new_servers/requests/list_servers.rb +43 -0
- data/lib/fog/new_servers/requests/reboot_server.rb +30 -0
- data/lib/fog/parser.rb +93 -0
- data/lib/fog/rackspace.rb +27 -0
- data/lib/fog/rackspace/bin.rb +48 -0
- data/lib/fog/rackspace/files.rb +134 -0
- data/lib/fog/rackspace/models/files/directories.rb +40 -0
- data/lib/fog/rackspace/models/files/directory.rb +45 -0
- data/lib/fog/rackspace/models/files/file.rb +61 -0
- data/lib/fog/rackspace/models/files/files.rb +87 -0
- data/lib/fog/rackspace/models/servers/flavor.rb +45 -0
- data/lib/fog/rackspace/models/servers/flavors.rb +34 -0
- data/lib/fog/rackspace/models/servers/image.rb +47 -0
- data/lib/fog/rackspace/models/servers/images.rb +41 -0
- data/lib/fog/rackspace/models/servers/server.rb +111 -0
- data/lib/fog/rackspace/models/servers/servers.rb +42 -0
- data/lib/fog/rackspace/requests/files/delete_container.rb +31 -0
- data/lib/fog/rackspace/requests/files/delete_object.rb +32 -0
- data/lib/fog/rackspace/requests/files/get_container.rb +52 -0
- data/lib/fog/rackspace/requests/files/get_containers.rb +41 -0
- data/lib/fog/rackspace/requests/files/get_object.rb +33 -0
- data/lib/fog/rackspace/requests/files/head_container.rb +37 -0
- data/lib/fog/rackspace/requests/files/head_containers.rb +34 -0
- data/lib/fog/rackspace/requests/files/head_object.rb +32 -0
- data/lib/fog/rackspace/requests/files/put_container.rb +31 -0
- data/lib/fog/rackspace/requests/files/put_object.rb +34 -0
- data/lib/fog/rackspace/requests/servers/create_image.rb +62 -0
- data/lib/fog/rackspace/requests/servers/create_server.rb +94 -0
- data/lib/fog/rackspace/requests/servers/delete_image.rb +45 -0
- data/lib/fog/rackspace/requests/servers/delete_server.rb +43 -0
- data/lib/fog/rackspace/requests/servers/get_flavor_details.rb +34 -0
- data/lib/fog/rackspace/requests/servers/get_image_details.rb +35 -0
- data/lib/fog/rackspace/requests/servers/get_server_details.rb +52 -0
- data/lib/fog/rackspace/requests/servers/list_addresses.rb +43 -0
- data/lib/fog/rackspace/requests/servers/list_flavors.rb +32 -0
- data/lib/fog/rackspace/requests/servers/list_flavors_detail.rb +34 -0
- data/lib/fog/rackspace/requests/servers/list_images.rb +40 -0
- data/lib/fog/rackspace/requests/servers/list_images_detail.rb +49 -0
- data/lib/fog/rackspace/requests/servers/list_private_addresses.rb +41 -0
- data/lib/fog/rackspace/requests/servers/list_public_addresses.rb +41 -0
- data/lib/fog/rackspace/requests/servers/list_servers.rb +41 -0
- data/lib/fog/rackspace/requests/servers/list_servers_detail.rb +56 -0
- data/lib/fog/rackspace/requests/servers/reboot_server.rb +32 -0
- data/lib/fog/rackspace/requests/servers/update_server.rb +45 -0
- data/lib/fog/rackspace/servers.rb +110 -0
- data/lib/fog/service.rb +87 -0
- data/lib/fog/slicehost.rb +92 -0
- data/lib/fog/slicehost/bin.rb +42 -0
- data/lib/fog/slicehost/models/flavor.rb +43 -0
- data/lib/fog/slicehost/models/flavors.rb +31 -0
- data/lib/fog/slicehost/models/image.rb +15 -0
- data/lib/fog/slicehost/models/images.rb +33 -0
- data/lib/fog/slicehost/models/server.rb +62 -0
- data/lib/fog/slicehost/models/servers.rb +35 -0
- data/lib/fog/slicehost/parsers/create_slice.rb +29 -0
- data/lib/fog/slicehost/parsers/get_backups.rb +30 -0
- data/lib/fog/slicehost/parsers/get_flavor.rb +24 -0
- data/lib/fog/slicehost/parsers/get_flavors.rb +28 -0
- data/lib/fog/slicehost/parsers/get_image.rb +24 -0
- data/lib/fog/slicehost/parsers/get_images.rb +28 -0
- data/lib/fog/slicehost/parsers/get_slice.rb +29 -0
- data/lib/fog/slicehost/parsers/get_slices.rb +33 -0
- data/lib/fog/slicehost/requests/create_slice.rb +47 -0
- data/lib/fog/slicehost/requests/delete_slice.rb +43 -0
- data/lib/fog/slicehost/requests/get_backups.rb +35 -0
- data/lib/fog/slicehost/requests/get_flavor.rb +38 -0
- data/lib/fog/slicehost/requests/get_flavors.rb +35 -0
- data/lib/fog/slicehost/requests/get_image.rb +36 -0
- data/lib/fog/slicehost/requests/get_images.rb +33 -0
- data/lib/fog/slicehost/requests/get_slice.rb +44 -0
- data/lib/fog/slicehost/requests/get_slices.rb +41 -0
- data/lib/fog/slicehost/requests/reboot_slice.rb +42 -0
- data/lib/fog/ssh.rb +108 -0
- data/lib/fog/terremark.rb +11 -0
- data/lib/fog/terremark/bin.rb +44 -0
- data/lib/fog/terremark/ecloud.rb +66 -0
- data/lib/fog/terremark/models/shared/address.rb +29 -0
- data/lib/fog/terremark/models/shared/addresses.rb +49 -0
- data/lib/fog/terremark/models/shared/network.rb +35 -0
- data/lib/fog/terremark/models/shared/networks.rb +52 -0
- data/lib/fog/terremark/models/shared/server.rb +110 -0
- data/lib/fog/terremark/models/shared/servers.rb +55 -0
- data/lib/fog/terremark/models/shared/task.rb +50 -0
- data/lib/fog/terremark/models/shared/tasks.rb +58 -0
- data/lib/fog/terremark/models/shared/vdc.rb +39 -0
- data/lib/fog/terremark/models/shared/vdcs.rb +52 -0
- data/lib/fog/terremark/parser.rb +18 -0
- data/lib/fog/terremark/parsers/shared/get_catalog.rb +46 -0
- data/lib/fog/terremark/parsers/shared/get_catalog_item.rb +46 -0
- data/lib/fog/terremark/parsers/shared/get_internet_services.rb +60 -0
- data/lib/fog/terremark/parsers/shared/get_network_ips.rb +29 -0
- data/lib/fog/terremark/parsers/shared/get_node_services.rb +36 -0
- data/lib/fog/terremark/parsers/shared/get_organization.rb +47 -0
- data/lib/fog/terremark/parsers/shared/get_organizations.rb +27 -0
- data/lib/fog/terremark/parsers/shared/get_public_ips.rb +30 -0
- data/lib/fog/terremark/parsers/shared/get_tasks_list.rb +52 -0
- data/lib/fog/terremark/parsers/shared/get_vapp_template.rb +46 -0
- data/lib/fog/terremark/parsers/shared/get_vdc.rb +108 -0
- data/lib/fog/terremark/parsers/shared/instantiate_vapp_template.rb +41 -0
- data/lib/fog/terremark/parsers/shared/internet_service.rb +65 -0
- data/lib/fog/terremark/parsers/shared/network.rb +51 -0
- data/lib/fog/terremark/parsers/shared/node_service.rb +32 -0
- data/lib/fog/terremark/parsers/shared/public_ip.rb +26 -0
- data/lib/fog/terremark/parsers/shared/task.rb +40 -0
- data/lib/fog/terremark/parsers/shared/vapp.rb +77 -0
- data/lib/fog/terremark/requests/shared/add_internet_service.rb +63 -0
- data/lib/fog/terremark/requests/shared/add_node_service.rb +63 -0
- data/lib/fog/terremark/requests/shared/create_internet_service.rb +63 -0
- data/lib/fog/terremark/requests/shared/delete_internet_service.rb +30 -0
- data/lib/fog/terremark/requests/shared/delete_node_service.rb +30 -0
- data/lib/fog/terremark/requests/shared/delete_public_ip.rb +30 -0
- data/lib/fog/terremark/requests/shared/delete_vapp.rb +30 -0
- data/lib/fog/terremark/requests/shared/deploy_vapp.rb +43 -0
- data/lib/fog/terremark/requests/shared/get_catalog.rb +40 -0
- data/lib/fog/terremark/requests/shared/get_catalog_item.rb +43 -0
- data/lib/fog/terremark/requests/shared/get_internet_services.rb +43 -0
- data/lib/fog/terremark/requests/shared/get_network.rb +73 -0
- data/lib/fog/terremark/requests/shared/get_network_ips.rb +40 -0
- data/lib/fog/terremark/requests/shared/get_node_services.rb +38 -0
- data/lib/fog/terremark/requests/shared/get_organization.rb +86 -0
- data/lib/fog/terremark/requests/shared/get_organizations.rb +49 -0
- data/lib/fog/terremark/requests/shared/get_public_ip.rb +41 -0
- data/lib/fog/terremark/requests/shared/get_public_ips.rb +72 -0
- data/lib/fog/terremark/requests/shared/get_task.rb +47 -0
- data/lib/fog/terremark/requests/shared/get_tasks_list.rb +40 -0
- data/lib/fog/terremark/requests/shared/get_vapp.rb +50 -0
- data/lib/fog/terremark/requests/shared/get_vapp_template.rb +43 -0
- data/lib/fog/terremark/requests/shared/get_vdc.rb +125 -0
- data/lib/fog/terremark/requests/shared/instantiate_vapp_template.rb +79 -0
- data/lib/fog/terremark/requests/shared/power_off.rb +43 -0
- data/lib/fog/terremark/requests/shared/power_on.rb +43 -0
- data/lib/fog/terremark/requests/shared/power_reset.rb +43 -0
- data/lib/fog/terremark/requests/shared/power_shutdown.rb +32 -0
- data/lib/fog/terremark/shared.rb +289 -0
- data/lib/fog/terremark/vcloud.rb +113 -0
- data/lib/fog/vcloud.rb +394 -0
- data/lib/fog/vcloud/bin.rb +57 -0
- data/lib/fog/vcloud/collection.rb +12 -0
- data/lib/fog/vcloud/extension.rb +37 -0
- data/lib/fog/vcloud/generators.rb +33 -0
- data/lib/fog/vcloud/model.rb +22 -0
- data/lib/fog/vcloud/models/vdc.rb +26 -0
- data/lib/fog/vcloud/models/vdcs.rb +41 -0
- data/lib/fog/vcloud/requests/get_network.rb +47 -0
- data/lib/fog/vcloud/requests/get_organization.rb +47 -0
- data/lib/fog/vcloud/requests/get_vdc.rb +82 -0
- data/lib/fog/vcloud/requests/get_versions.rb +34 -0
- data/lib/fog/vcloud/requests/login.rb +46 -0
- data/lib/fog/vcloud/terremark/ecloud.rb +199 -0
- data/lib/fog/vcloud/terremark/ecloud/models/catalog.rb +30 -0
- data/lib/fog/vcloud/terremark/ecloud/models/catalog_item.rb +31 -0
- data/lib/fog/vcloud/terremark/ecloud/models/firewall_acl.rb +28 -0
- data/lib/fog/vcloud/terremark/ecloud/models/firewall_acls.rb +31 -0
- data/lib/fog/vcloud/terremark/ecloud/models/internet_service.rb +84 -0
- data/lib/fog/vcloud/terremark/ecloud/models/internet_services.rb +39 -0
- data/lib/fog/vcloud/terremark/ecloud/models/ip.rb +51 -0
- data/lib/fog/vcloud/terremark/ecloud/models/ips.rb +32 -0
- data/lib/fog/vcloud/terremark/ecloud/models/network.rb +73 -0
- data/lib/fog/vcloud/terremark/ecloud/models/networks.rb +39 -0
- data/lib/fog/vcloud/terremark/ecloud/models/node.rb +47 -0
- data/lib/fog/vcloud/terremark/ecloud/models/nodes.rb +30 -0
- data/lib/fog/vcloud/terremark/ecloud/models/public_ip.rb +25 -0
- data/lib/fog/vcloud/terremark/ecloud/models/public_ips.rb +48 -0
- data/lib/fog/vcloud/terremark/ecloud/models/server.rb +199 -0
- data/lib/fog/vcloud/terremark/ecloud/models/servers.rb +54 -0
- data/lib/fog/vcloud/terremark/ecloud/models/task.rb +23 -0
- data/lib/fog/vcloud/terremark/ecloud/models/tasks.rb +30 -0
- data/lib/fog/vcloud/terremark/ecloud/models/vdc.rb +79 -0
- data/lib/fog/vcloud/terremark/ecloud/models/vdcs.rb +30 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/add_internet_service.rb +140 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/add_node.rb +65 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/clone_vapp.rb +50 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_internet_service.rb +93 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_network.rb +54 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_network_ip.rb +53 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_node.rb +54 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_vapp.rb +116 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/delete_internet_service.rb +33 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/delete_node.rb +28 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/delete_vapp.rb +19 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_catalog.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_catalog_item.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_customization_options.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_firewall_acl.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_firewall_acls.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_internet_services.rb +66 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network.rb +48 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_extensions.rb +36 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_ip.rb +44 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_ips.rb +50 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_node.rb +45 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_nodes.rb +44 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_public_ip.rb +35 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_public_ips.rb +40 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_task.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_task_list.rb +19 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_vapp.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_vapp_template.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_vdc.rb +86 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/instantiate_vapp_template.rb +100 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/power_off.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/power_on.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/power_reset.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/power_shutdown.rb +18 -0
- data/lib/fog/vcloud/terremark/vcloud.rb +18 -0
- data/lib/fog/vcloud/terremark/vcloud/requests/get_vdc.rb +57 -0
- data/spec/aws/models/ec2/address_spec.rb +103 -0
- data/spec/aws/models/ec2/addresses_spec.rb +70 -0
- data/spec/aws/models/ec2/flavors_spec.rb +14 -0
- data/spec/aws/models/ec2/key_pair_spec.rb +86 -0
- data/spec/aws/models/ec2/key_pairs_spec.rb +71 -0
- data/spec/aws/models/ec2/security_group_spec.rb +88 -0
- data/spec/aws/models/ec2/security_groups_spec.rb +71 -0
- data/spec/aws/models/ec2/server_spec.rb +106 -0
- data/spec/aws/models/ec2/servers_spec.rb +21 -0
- data/spec/aws/models/ec2/snapshot_spec.rb +75 -0
- data/spec/aws/models/ec2/snapshots_spec.rb +85 -0
- data/spec/aws/models/ec2/volume_spec.rb +152 -0
- data/spec/aws/models/ec2/volumes_spec.rb +71 -0
- data/spec/aws/models/s3/directories_spec.rb +49 -0
- data/spec/aws/models/s3/directory_spec.rb +112 -0
- data/spec/aws/models/s3/file_spec.rb +121 -0
- data/spec/aws/models/s3/files_spec.rb +117 -0
- data/spec/aws/requests/ec2/describe_images_spec.rb +44 -0
- data/spec/aws/requests/s3/copy_object_spec.rb +61 -0
- data/spec/aws/requests/s3/delete_bucket_spec.rb +35 -0
- data/spec/aws/requests/s3/delete_object_spec.rb +36 -0
- data/spec/aws/requests/s3/get_bucket_location_spec.rb +30 -0
- data/spec/aws/requests/s3/get_bucket_spec.rb +114 -0
- data/spec/aws/requests/s3/get_object_spec.rb +58 -0
- data/spec/aws/requests/s3/get_request_payment_spec.rb +30 -0
- data/spec/aws/requests/s3/get_service_spec.rb +32 -0
- data/spec/aws/requests/s3/head_object_spec.rb +26 -0
- data/spec/aws/requests/s3/put_bucket_spec.rb +19 -0
- data/spec/aws/requests/s3/put_object_spec.rb +43 -0
- data/spec/aws/requests/s3/put_request_payment_spec.rb +29 -0
- data/spec/aws/requests/simpledb/batch_put_attributes_spec.rb +31 -0
- data/spec/aws/requests/simpledb/create_domain_spec.rb +29 -0
- data/spec/aws/requests/simpledb/delete_attributes_spec.rb +39 -0
- data/spec/aws/requests/simpledb/delete_domain_spec.rb +28 -0
- data/spec/aws/requests/simpledb/domain_metadata_spec.rb +52 -0
- data/spec/aws/requests/simpledb/get_attributes_spec.rb +56 -0
- data/spec/aws/requests/simpledb/list_domains_spec.rb +30 -0
- data/spec/aws/requests/simpledb/put_attributes_spec.rb +49 -0
- data/spec/aws/requests/simpledb/select_spec.rb +26 -0
- data/spec/bluebox/models/flavors_spec.rb +14 -0
- data/spec/bluebox/models/server_spec.rb +25 -0
- data/spec/bluebox/models/servers_spec.rb +27 -0
- data/spec/compact_progress_bar_formatter.rb +195 -0
- data/spec/lorem.txt +1 -0
- data/spec/rackspace/models/servers/flavors_spec.rb +14 -0
- data/spec/rackspace/models/servers/server_spec.rb +51 -0
- data/spec/rackspace/models/servers/servers_spec.rb +22 -0
- data/spec/rackspace/requests/files/delete_container_spec.rb +24 -0
- data/spec/rackspace/requests/files/delete_object_spec.rb +37 -0
- data/spec/rackspace/requests/files/get_container_spec.rb +35 -0
- data/spec/rackspace/requests/files/get_containers_spec.rb +22 -0
- data/spec/rackspace/requests/files/get_object_spec.rb +21 -0
- data/spec/rackspace/requests/files/head_container_spec.rb +30 -0
- data/spec/rackspace/requests/files/head_containers_spec.rb +19 -0
- data/spec/rackspace/requests/files/head_object_spec.rb +21 -0
- data/spec/rackspace/requests/files/put_container_spec.rb +15 -0
- data/spec/rackspace/requests/files/put_object_spec.rb +20 -0
- data/spec/shared_examples/flavors_examples.rb +16 -0
- data/spec/shared_examples/server_examples.rb +43 -0
- data/spec/shared_examples/servers_examples.rb +37 -0
- data/spec/slicehost/models/flavors_spec.rb +14 -0
- data/spec/slicehost/models/server_spec.rb +51 -0
- data/spec/slicehost/models/servers_spec.rb +22 -0
- data/spec/spec_helper.rb +121 -0
- data/spec/vcloud/bin_spec.rb +31 -0
- data/spec/vcloud/models/vdc_spec.rb +52 -0
- data/spec/vcloud/models/vdcs_spec.rb +1 -0
- data/spec/vcloud/requests/get_network_spec.rb +44 -0
- data/spec/vcloud/requests/get_organization_spec.rb +53 -0
- data/spec/vcloud/requests/get_vdc_spec.rb +63 -0
- data/spec/vcloud/requests/get_versions_spec.rb +54 -0
- data/spec/vcloud/requests/login_spec.rb +24 -0
- data/spec/vcloud/spec_helper.rb +383 -0
- data/spec/vcloud/terremark/ecloud/models/internet_service_spec.rb +66 -0
- data/spec/vcloud/terremark/ecloud/models/internet_services_spec.rb +29 -0
- data/spec/vcloud/terremark/ecloud/models/ip_spec.rb +36 -0
- data/spec/vcloud/terremark/ecloud/models/ips_spec.rb +28 -0
- data/spec/vcloud/terremark/ecloud/models/network_spec.rb +69 -0
- data/spec/vcloud/terremark/ecloud/models/networks_spec.rb +27 -0
- data/spec/vcloud/terremark/ecloud/models/node_spec.rb +38 -0
- data/spec/vcloud/terremark/ecloud/models/nodes_spec.rb +29 -0
- data/spec/vcloud/terremark/ecloud/models/public_ip_spec.rb +40 -0
- data/spec/vcloud/terremark/ecloud/models/public_ips_spec.rb +27 -0
- data/spec/vcloud/terremark/ecloud/models/vdc_spec.rb +63 -0
- data/spec/vcloud/terremark/ecloud/models/vdcs_spec.rb +28 -0
- data/spec/vcloud/terremark/ecloud/requests/add_internet_service_spec.rb +70 -0
- data/spec/vcloud/terremark/ecloud/requests/add_node_spec.rb +52 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_internet_service_spec.rb +60 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_node_spec.rb +58 -0
- data/spec/vcloud/terremark/ecloud/requests/delete_internet_service_spec.rb +36 -0
- data/spec/vcloud/terremark/ecloud/requests/delete_node_spec.rb +34 -0
- data/spec/vcloud/terremark/ecloud/requests/get_internet_services_spec.rb +115 -0
- data/spec/vcloud/terremark/ecloud/requests/get_network_ip_spec.rb +41 -0
- data/spec/vcloud/terremark/ecloud/requests/get_network_ips_spec.rb +59 -0
- data/spec/vcloud/terremark/ecloud/requests/get_network_spec.rb +41 -0
- data/spec/vcloud/terremark/ecloud/requests/get_node_spec.rb +41 -0
- data/spec/vcloud/terremark/ecloud/requests/get_nodes_spec.rb +58 -0
- data/spec/vcloud/terremark/ecloud/requests/get_public_ip_spec.rb +39 -0
- data/spec/vcloud/terremark/ecloud/requests/get_public_ips_spec.rb +52 -0
- data/spec/vcloud/terremark/ecloud/requests/get_vdc_spec.rb +110 -0
- data/spec/vcloud/terremark/ecloud/requests/login_spec.rb +10 -0
- data/spec/vcloud/vcloud_spec.rb +18 -0
- data/tests/aws/helper.rb +41 -0
- data/tests/aws/models/s3/directory_tests.rb +8 -0
- data/tests/aws/requests/ec2/address_tests.rb +80 -0
- data/tests/aws/requests/ec2/availability_zone_tests.rb +32 -0
- data/tests/aws/requests/ec2/instance_tests.rb +122 -0
- data/tests/aws/requests/ec2/key_pair_tests.rb +59 -0
- data/tests/aws/requests/ec2/region_tests.rb +30 -0
- data/tests/aws/requests/ec2/security_group_tests.rb +128 -0
- data/tests/aws/requests/ec2/snapshot_tests.rb +60 -0
- data/tests/aws/requests/ec2/volume_tests.rb +105 -0
- data/tests/bluebox/helper.rb +26 -0
- data/tests/bluebox/requests/block_tests.rb +68 -0
- data/tests/bluebox/requests/product_tests.rb +25 -0
- data/tests/bluebox/requests/template_tests.rb +32 -0
- data/tests/helper.rb +81 -0
- data/tests/helper_tests.rb +43 -0
- data/tests/helpers/model_helper.rb +76 -0
- data/tests/linode/helper.rb +25 -0
- data/tests/linode/requests/datacenter_tests.rb +18 -0
- data/tests/linode/requests/distribution_tests.rb +30 -0
- data/tests/linode/requests/linode_tests.rb +79 -0
- data/tests/linode/requests/linodeplans_tests.rb +37 -0
- data/tests/rackspace/helper.rb +39 -0
- data/tests/rackspace/requests/servers/address_tests.rb +40 -0
- data/tests/rackspace/requests/servers/flavor_tests.rb +34 -0
- data/tests/rackspace/requests/servers/image_tests.rb +59 -0
- data/tests/rackspace/requests/servers/server_tests.rb +83 -0
- data/tests/slicehost/helper.rb +16 -0
- data/tests/slicehost/requests/backup_tests.rb +17 -0
- data/tests/slicehost/requests/flavor_tests.rb +30 -0
- data/tests/slicehost/requests/image_tests.rb +28 -0
- data/tests/slicehost/requests/slice_tests.rb +63 -0
- metadata +778 -0
@@ -0,0 +1,28 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__),'..','..','..','spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
describe "Fog::Vcloud::Terremark::Ecloud::Vdcs", :type => :mock_tmrk_ecloud_model do
|
5
|
+
subject { @vcloud }
|
6
|
+
|
7
|
+
it { should respond_to :vdcs }
|
8
|
+
|
9
|
+
describe :class do
|
10
|
+
subject { @vcloud.vdcs.class }
|
11
|
+
its(:model) { should == Fog::Vcloud::Terremark::Ecloud::Vdc }
|
12
|
+
end
|
13
|
+
|
14
|
+
describe :vdcs do
|
15
|
+
subject { @vcloud.vdcs }
|
16
|
+
it { should_not respond_to :create }
|
17
|
+
|
18
|
+
it { should be_an_instance_of Fog::Vcloud::Terremark::Ecloud::Vdcs }
|
19
|
+
|
20
|
+
its(:length) { should == 2 }
|
21
|
+
|
22
|
+
it { should have_members_of_the_right_model }
|
23
|
+
|
24
|
+
its(:organization_uri) { should == @mock_organization[:info][:href] }
|
25
|
+
end
|
26
|
+
end
|
27
|
+
else
|
28
|
+
end
|
@@ -0,0 +1,70 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), '..', '..', '..', 'spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
describe "Fog::Vcloud, initialized w/ the TMRK Ecloud module", :type => :mock_tmrk_ecloud_request do
|
5
|
+
subject { @vcloud }
|
6
|
+
|
7
|
+
it { should respond_to :add_internet_service }
|
8
|
+
|
9
|
+
describe "#add_internet_service" do
|
10
|
+
before do
|
11
|
+
@public_ip = @vcloud.vdcs[0].public_ips[0]
|
12
|
+
@new_service_data = { :name => "Test Service",
|
13
|
+
:protocol => "HTTP",
|
14
|
+
:port => "80",
|
15
|
+
:enabled => "true",
|
16
|
+
:description => "this is a test",
|
17
|
+
:redirect_url => "" }
|
18
|
+
end
|
19
|
+
|
20
|
+
context "with a valid Public IP uri" do
|
21
|
+
it "has the right number of Internet Services before" do
|
22
|
+
before_services = @vcloud.get_internet_services(@public_ip.href)
|
23
|
+
before_services.body[:InternetService].should have(2).services
|
24
|
+
end
|
25
|
+
|
26
|
+
subject { @vcloud.add_internet_service(@public_ip.href.to_s + "/internetServices", @new_service_data ) }
|
27
|
+
|
28
|
+
it "has the right number of Internet Services after" do
|
29
|
+
subject
|
30
|
+
@vcloud.get_internet_services(@public_ip.href).body[:InternetService].should have(3).services
|
31
|
+
end
|
32
|
+
|
33
|
+
it_should_behave_like "all responses"
|
34
|
+
|
35
|
+
let(:body) { subject.body }
|
36
|
+
|
37
|
+
its(:body) { should be_an_instance_of Hash }
|
38
|
+
specify { body[:Href].should_not be_empty }
|
39
|
+
specify { body[:Name].should == @new_service_data[:name] }
|
40
|
+
specify { body[:Protocol].should == @new_service_data[:protocol] }
|
41
|
+
specify { body[:Enabled].should == @new_service_data[:enabled] }
|
42
|
+
specify { body[:Description].should == @new_service_data[:description] }
|
43
|
+
specify { body[:RedirectURL].should == @new_service_data[:redirect_url] }
|
44
|
+
specify { body[:Monitor].should == nil }
|
45
|
+
|
46
|
+
let(:public_ip) { subject.body[:PublicIpAddress] }
|
47
|
+
specify { public_ip.should be_an_instance_of Hash }
|
48
|
+
specify { public_ip[:Name].should == @public_ip.name }
|
49
|
+
specify { public_ip[:Id].should == @public_ip.id }
|
50
|
+
|
51
|
+
it "should update the mock object properly" do
|
52
|
+
subject
|
53
|
+
ip, service = @vcloud.mock_ip_and_service_from_service_url(body[:Href])
|
54
|
+
service[:href].should == body[:Href]
|
55
|
+
service[:id].should == body[:Id]
|
56
|
+
service[:nodes].should == []
|
57
|
+
end
|
58
|
+
|
59
|
+
end
|
60
|
+
|
61
|
+
context "with a public_ips_uri that doesn't exist" do
|
62
|
+
subject { lambda { @vcloud.add_internet_service(URI.parse('https://www.fakey.c/piv8vc99'), @new_service_data ) } }
|
63
|
+
|
64
|
+
it_should_behave_like "a request for a resource that doesn't exist"
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
68
|
+
else
|
69
|
+
end
|
70
|
+
|
@@ -0,0 +1,52 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), '..', '..', '..', 'spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
#FIXME: with rspec2
|
5
|
+
describe "Fog::Vcloud, initialized w/ the TMRK Ecloud module", :type => :mock_tmrk_ecloud_request do
|
6
|
+
subject { @vcloud }
|
7
|
+
|
8
|
+
it { should respond_to :add_node }
|
9
|
+
|
10
|
+
describe "#add_node" do
|
11
|
+
|
12
|
+
let(:new_node_data) { { :ip_address => '1.2.3.4',
|
13
|
+
:name => 'Foo',
|
14
|
+
:port => '9090',
|
15
|
+
:enabled => 'true',
|
16
|
+
:description => 'Foo Service'
|
17
|
+
} }
|
18
|
+
|
19
|
+
context "with a valid node services uri" do
|
20
|
+
|
21
|
+
subject { @vcloud.add_node(@mock_service[:href] + "/nodeServices", new_node_data) }
|
22
|
+
|
23
|
+
it_should_behave_like "all responses"
|
24
|
+
|
25
|
+
let(:service) { @vcloud.vdcs.first.public_ips.first.internet_services.first }
|
26
|
+
|
27
|
+
it "should change the count by 1" do
|
28
|
+
service.nodes.length.should == 2
|
29
|
+
subject
|
30
|
+
service.nodes.reload.length.should == 3
|
31
|
+
end
|
32
|
+
|
33
|
+
describe "#body" do
|
34
|
+
subject { @vcloud.add_node(@mock_service[:href] + "/nodeServices", new_node_data).body }
|
35
|
+
its(:Enabled) { should == new_node_data[:enabled] }
|
36
|
+
its(:Port) { should == new_node_data[:port] }
|
37
|
+
its(:IpAddress) { should == new_node_data[:ip_address] }
|
38
|
+
its(:Name) { should == new_node_data[:name] }
|
39
|
+
its(:Description) { should == new_node_data[:description] }
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
context "with a nodes uri that doesn't exist" do
|
44
|
+
subject { lambda { @vcloud.add_node(URI.parse('https://www.fakey.c/piv8vc99'), new_node_data ) } }
|
45
|
+
|
46
|
+
it_should_behave_like "a request for a resource that doesn't exist"
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
else
|
51
|
+
end
|
52
|
+
|
@@ -0,0 +1,60 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), '..', '..', '..', 'spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
describe "Fog::Vcloud, initialized w/ the TMRK Ecloud module", :type => :mock_tmrk_ecloud_request do
|
5
|
+
subject { @vcloud }
|
6
|
+
|
7
|
+
it { should respond_to :configure_internet_service }
|
8
|
+
|
9
|
+
describe "#configure_internet_service" do
|
10
|
+
before do
|
11
|
+
@public_ip = @vcloud.vdcs.first.public_ips.first
|
12
|
+
@original_service = @vcloud.get_internet_services(@public_ip.href).body[:InternetService].first
|
13
|
+
@ip_data = { :id => @public_ip.id, :name => @public_ip.name, :href => @public_ip.href.to_s }
|
14
|
+
@service_data = { :name => @original_service[:Name], :protocol => @original_service[:Protocol],
|
15
|
+
:port => @original_service[:Port], :description => @original_service[:Description],
|
16
|
+
:enabled => @original_service[:Enabled], :redirect_url => @original_service[:RedirectURL],
|
17
|
+
:id => @original_service[:Id], :href => @original_service[:Href], :timeout => @original_service[:Timeout] }
|
18
|
+
end
|
19
|
+
|
20
|
+
context "with a valid Internet Service uri and valid data" do
|
21
|
+
|
22
|
+
subject { @vcloud.configure_internet_service(@original_service[:Href], @service_data, @ip_data) }
|
23
|
+
|
24
|
+
it_should_behave_like "all responses"
|
25
|
+
|
26
|
+
context "with some changed data" do
|
27
|
+
before do
|
28
|
+
@service_data[:description] = "TEST BOOM"
|
29
|
+
@service_data[:redirect_url] = "http://google.com"
|
30
|
+
@service_data[:port] = "80"
|
31
|
+
end
|
32
|
+
it "should change data" do
|
33
|
+
@original_service[:Description].should == @mock_service[:description]
|
34
|
+
@original_service[:RedirectURL].should == @mock_service[:redirect_url]
|
35
|
+
@original_service[:Port].should == @mock_service[:port]
|
36
|
+
result = subject
|
37
|
+
result.body[:Description].should == @service_data[:description]
|
38
|
+
result.body[:RedirectURL].should == @service_data[:redirect_url]
|
39
|
+
result.body[:Port].should == @service_data[:port]
|
40
|
+
|
41
|
+
new_result = @vcloud.get_internet_services(@public_ip.href).body[:InternetService].first
|
42
|
+
|
43
|
+
new_result[:Description].should == @service_data[:description]
|
44
|
+
new_result[:RedirectURL].should == @service_data[:redirect_url]
|
45
|
+
new_result[:Port].should == @service_data[:port]
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
end
|
50
|
+
|
51
|
+
context "with an internet_services_uri that doesn't exist" do
|
52
|
+
subject { lambda { @vcloud.configure_internet_service(URI.parse('https://www.fakey.c/piv8vc99'), @service_data, @ip_data ) } }
|
53
|
+
|
54
|
+
it_should_behave_like "a request for a resource that doesn't exist"
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
else
|
59
|
+
end
|
60
|
+
|
@@ -0,0 +1,58 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), '..', '..', '..', 'spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
describe "Fog::Vcloud, initialized w/ the TMRK Ecloud module", :type => :mock_tmrk_ecloud_request do
|
5
|
+
subject { @vcloud }
|
6
|
+
|
7
|
+
it { should respond_to :configure_node }
|
8
|
+
|
9
|
+
describe "#configure_node" do
|
10
|
+
let(:original_node) { @vcloud.vdcs.first.public_ips.first.internet_services.first.nodes.first }
|
11
|
+
let(:node_data) { { :name => "TEST BOOM", :enabled => "false", :description => "TEST BOOM DESC" } }
|
12
|
+
|
13
|
+
context "with a valid node service uri" do
|
14
|
+
|
15
|
+
subject { @vcloud.configure_node(@mock_node[:href],node_data) }
|
16
|
+
|
17
|
+
it_should_behave_like "all responses"
|
18
|
+
|
19
|
+
describe "#body" do
|
20
|
+
subject { @vcloud.configure_node(@mock_node[:href],node_data).body }
|
21
|
+
|
22
|
+
its(:Description) { should == node_data[:description] }
|
23
|
+
its(:Href) { should == @mock_node[:href] }
|
24
|
+
its(:Name) { should == node_data[:name] }
|
25
|
+
its(:Id) { should == @mock_node[:id] }
|
26
|
+
its(:Port) { should == @mock_node[:port] }
|
27
|
+
its(:Enabled) { should == node_data[:enabled] }
|
28
|
+
its(:IpAddress) { should == @mock_node[:ip_address] }
|
29
|
+
end
|
30
|
+
|
31
|
+
it "should change the name" do
|
32
|
+
original_node.name.should == @mock_node[:name]
|
33
|
+
subject
|
34
|
+
original_node.reload.name.should == node_data[:name]
|
35
|
+
end
|
36
|
+
|
37
|
+
it "should change enabled" do
|
38
|
+
original_node.enabled.should == @mock_node[:enabled]
|
39
|
+
subject
|
40
|
+
original_node.reload.enabled.should == node_data[:enabled]
|
41
|
+
end
|
42
|
+
|
43
|
+
it "should change the description" do
|
44
|
+
original_node.description.should == @mock_node[:description]
|
45
|
+
subject
|
46
|
+
original_node.reload.description.should == node_data[:description]
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
context "with a nodes uri that doesn't exist" do
|
51
|
+
subject { lambda { @vcloud.configure_node(URI.parse('https://www.fakey.c/piv8vc99'), node_data) } }
|
52
|
+
|
53
|
+
it_should_behave_like "a request for a resource that doesn't exist"
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
57
|
+
else
|
58
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), '..', '..', '..', 'spec_helper')
|
2
|
+
|
3
|
+
#FIXME: Make this more sane with rspec2
|
4
|
+
if Fog.mocking?
|
5
|
+
describe "Fog::Vcloud, initialized w/ the TMRK Ecloud module", :type => :mock_tmrk_ecloud_request do
|
6
|
+
subject { @vcloud }
|
7
|
+
|
8
|
+
it { should respond_to :delete_internet_service }
|
9
|
+
|
10
|
+
describe "#delete_internet_service" do
|
11
|
+
context "with a valid internet service uri" do
|
12
|
+
subject { @vcloud.delete_internet_service(@mock_service[:href]) }
|
13
|
+
|
14
|
+
it_should_behave_like "all delete responses"
|
15
|
+
|
16
|
+
let(:public_ip) { @vcloud.vdcs.first.public_ips.first }
|
17
|
+
|
18
|
+
it "should change the count by -1" do
|
19
|
+
public_ip.internet_services.length.should == 2
|
20
|
+
subject
|
21
|
+
public_ip.internet_services.reload.length.should == 1
|
22
|
+
end
|
23
|
+
|
24
|
+
describe "#body" do
|
25
|
+
its(:body) { should == '' }
|
26
|
+
end
|
27
|
+
|
28
|
+
|
29
|
+
|
30
|
+
end
|
31
|
+
|
32
|
+
end
|
33
|
+
end
|
34
|
+
else
|
35
|
+
end
|
36
|
+
|
@@ -0,0 +1,34 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), '..', '..', '..', 'spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
#FIXME: with rspec2
|
5
|
+
describe "Fog::Vcloud, initialized w/ the TMRK Ecloud module", :type => :mock_tmrk_ecloud_request do
|
6
|
+
subject { @vcloud }
|
7
|
+
|
8
|
+
it { should respond_to :delete_node }
|
9
|
+
|
10
|
+
describe "#delete_node" do
|
11
|
+
context "with a valid node service uri" do
|
12
|
+
subject { @vcloud.delete_node(@mock_node[:href]) }
|
13
|
+
|
14
|
+
#it_should_behave_like "all delete responses"
|
15
|
+
|
16
|
+
let(:internet_service) { @vcloud.vdcs.first.public_ips.first.internet_services.first }
|
17
|
+
|
18
|
+
it "should change the count by -1" do
|
19
|
+
internet_service.nodes.length.should == 2
|
20
|
+
subject
|
21
|
+
internet_service.nodes.reload.length.should == 1
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
context "with a nodes uri that doesn't exist" do
|
26
|
+
subject { lambda { @vcloud.delete_node(URI.parse('https://www.fakey.c/piv8vc99')) } }
|
27
|
+
|
28
|
+
it_should_behave_like "a request for a resource that doesn't exist"
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
else
|
33
|
+
end
|
34
|
+
|
@@ -0,0 +1,115 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), '..', '..', '..', 'spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
describe "Fog::Vcloud, initialized w/ the TMRK Ecloud module", :type => :mock_tmrk_ecloud_request do
|
5
|
+
subject { @vcloud }
|
6
|
+
|
7
|
+
it { should respond_to :get_internet_services }
|
8
|
+
|
9
|
+
describe "#get_internet_services" do
|
10
|
+
context "with a valid VDC internet_services_uri" do
|
11
|
+
before { @services = @vcloud.get_internet_services( @mock_vdc[:href] + "/internetServices" ) }
|
12
|
+
subject { @services }
|
13
|
+
|
14
|
+
it_should_behave_like "all responses"
|
15
|
+
it { should have_headers_denoting_a_content_type_of "application/vnd.tmrk.ecloud.internetServicesList+xml" }
|
16
|
+
|
17
|
+
describe "#body" do
|
18
|
+
subject { @services.body }
|
19
|
+
|
20
|
+
it { should have(3).items }
|
21
|
+
|
22
|
+
its(:xmlns) { should == "urn:tmrk:eCloudExtensions-2.3" }
|
23
|
+
its(:xmlns_i) { should == "http://www.w3.org/2001/XMLSchema-instance" }
|
24
|
+
|
25
|
+
context "[:InternetService]" do
|
26
|
+
subject { @services.body[:InternetService] }
|
27
|
+
|
28
|
+
it { should have(4).items }
|
29
|
+
|
30
|
+
[0,1,2,3].each do |idx|
|
31
|
+
let(:service) { subject[idx] }
|
32
|
+
let(:mock_service) { @mock_vdc[:public_ips].map { |ip| ip[:services] }.flatten[idx] }
|
33
|
+
let(:mock_ip) { @mock_vdc[:public_ips].detect { |ip| ip[:services].detect { |ipservice| ipservice[:id] == service[:Id] } } }
|
34
|
+
specify { service.should be_an_instance_of Hash }
|
35
|
+
specify { service.should have(11).attributes }
|
36
|
+
specify { service[:Name].should == mock_service[:name] }
|
37
|
+
specify { service[:Id].should == mock_service[:id] }
|
38
|
+
specify { service[:Href].should == Fog::Vcloud::Terremark::Ecloud::Mock.internet_service_href(mock_service) }
|
39
|
+
|
40
|
+
specify { service[:PublicIpAddress].should be_an_instance_of Hash }
|
41
|
+
specify { service[:PublicIpAddress].should have(3).attributes }
|
42
|
+
specify { service[:PublicIpAddress][:Name].should == mock_ip[:name] }
|
43
|
+
specify { service[:PublicIpAddress][:Id].should == mock_ip[:id] }
|
44
|
+
|
45
|
+
specify { service[:Port].should == mock_service[:port] }
|
46
|
+
specify { service[:Protocol].should == mock_service[:protocol] }
|
47
|
+
specify { service[:Enabled].should == mock_service[:enabled] }
|
48
|
+
specify { service[:Timeout].should == mock_service[:timeout] }
|
49
|
+
specify { service[:Description].should == mock_service[:description] }
|
50
|
+
specify { service[:RedirectURL].should == mock_service[:redirect_url] }
|
51
|
+
specify { service[:Monitor].should == "" }
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
context "with a valid Public IP uri" do
|
58
|
+
before do
|
59
|
+
@mock_public_ip = @mock_vdc[:public_ips].first
|
60
|
+
@services = @vcloud.get_internet_services( @mock_public_ip[:href] + "/internetServices" )
|
61
|
+
end
|
62
|
+
subject { @services }
|
63
|
+
|
64
|
+
it_should_behave_like "all responses"
|
65
|
+
it { should have_headers_denoting_a_content_type_of "application/vnd.tmrk.ecloud.internetServicesList+xml" }
|
66
|
+
|
67
|
+
describe "#body" do
|
68
|
+
subject { @services.body }
|
69
|
+
|
70
|
+
it { should have(3).items }
|
71
|
+
|
72
|
+
its(:xmlns) { should == "urn:tmrk:eCloudExtensions-2.3" }
|
73
|
+
its(:xmlns_i) { should == "http://www.w3.org/2001/XMLSchema-instance" }
|
74
|
+
|
75
|
+
context "[:InternetService]" do
|
76
|
+
subject { @services.body[:InternetService] }
|
77
|
+
|
78
|
+
it { should have(2).items }
|
79
|
+
|
80
|
+
[0,1].each do |idx|
|
81
|
+
let(:service) { subject[idx] }
|
82
|
+
let(:mock_service) { @mock_public_ip[:services][idx] }
|
83
|
+
let(:mock_ip) { @mock_public_ip }
|
84
|
+
specify { service.should be_an_instance_of Hash }
|
85
|
+
specify { service.should have(11).attributes }
|
86
|
+
specify { service[:Name].should == mock_service[:name] }
|
87
|
+
specify { service[:Id].should == mock_service[:id] }
|
88
|
+
specify { service[:Href].should == Fog::Vcloud::Terremark::Ecloud::Mock.internet_service_href(mock_service) }
|
89
|
+
|
90
|
+
specify { service[:PublicIpAddress].should be_an_instance_of Hash }
|
91
|
+
specify { service[:PublicIpAddress].should have(3).attributes }
|
92
|
+
specify { service[:PublicIpAddress][:Name].should == mock_ip[:name] }
|
93
|
+
specify { service[:PublicIpAddress][:Id].should == mock_ip[:id] }
|
94
|
+
|
95
|
+
specify { service[:Port].should == mock_service[:port] }
|
96
|
+
specify { service[:Protocol].should == mock_service[:protocol] }
|
97
|
+
specify { service[:Enabled].should == mock_service[:enabled] }
|
98
|
+
specify { service[:Timeout].should == mock_service[:timeout] }
|
99
|
+
specify { service[:Description].should == mock_service[:description] }
|
100
|
+
specify { service[:RedirectURL].should == mock_service[:redirect_url] }
|
101
|
+
specify { service[:Monitor].should == "" }
|
102
|
+
end
|
103
|
+
end
|
104
|
+
end
|
105
|
+
end
|
106
|
+
|
107
|
+
context "with a public_ips_uri that doesn't exist" do
|
108
|
+
subject { lambda { @vcloud.get_internet_services(URI.parse('https://www.fakey.c/piv8vc99')) } }
|
109
|
+
|
110
|
+
it_should_behave_like "a request for a resource that doesn't exist"
|
111
|
+
end
|
112
|
+
end
|
113
|
+
end
|
114
|
+
else
|
115
|
+
end
|