fog 1.4.0 → 1.5.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.document +1 -1
- data/.irbrc +5 -10
- data/{README.rdoc → README.md} +66 -61
- data/Rakefile +4 -6
- data/changelog.txt +491 -0
- data/docs/about/users.markdown +1 -0
- data/fog.gemspec +4 -4
- data/lib/fog.rb +1 -1
- data/lib/fog/aws.rb +4 -0
- data/lib/fog/aws/auto_scaling.rb +3 -0
- data/lib/fog/aws/cloud_watch.rb +28 -0
- data/lib/fog/aws/compute.rb +7 -1
- data/lib/fog/aws/elasticache.rb +64 -6
- data/lib/fog/aws/models/auto_scaling/configuration.rb +3 -1
- data/lib/fog/aws/models/auto_scaling/group.rb +10 -9
- data/lib/fog/aws/models/auto_scaling/policies.rb +33 -0
- data/lib/fog/aws/models/auto_scaling/policy.rb +46 -0
- data/lib/fog/aws/models/cloud_watch/alarm.rb +50 -2
- data/lib/fog/aws/models/cloud_watch/alarms.rb +18 -1
- data/lib/fog/aws/models/compute/address.rb +2 -2
- data/lib/fog/aws/models/dns/records.rb +5 -0
- data/lib/fog/aws/models/elasticache/cluster.rb +1 -1
- data/lib/fog/aws/models/iam/users.rb +26 -4
- data/lib/fog/aws/parsers/auto_scaling/describe_policies.rb +7 -5
- data/lib/fog/aws/parsers/elb/describe_load_balancers.rb +1 -1
- data/lib/fog/aws/rds.rb +1 -1
- data/lib/fog/aws/requests/auto_scaling/create_auto_scaling_group.rb +8 -0
- data/lib/fog/aws/requests/auto_scaling/create_launch_configuration.rb +1 -2
- data/lib/fog/aws/requests/auto_scaling/delete_auto_scaling_group.rb +10 -2
- data/lib/fog/aws/requests/auto_scaling/delete_launch_configuration.rb +1 -1
- data/lib/fog/aws/requests/auto_scaling/delete_policy.rb +10 -1
- data/lib/fog/aws/requests/auto_scaling/describe_auto_scaling_instances.rb +0 -1
- data/lib/fog/aws/requests/auto_scaling/describe_policies.rb +13 -1
- data/lib/fog/aws/requests/auto_scaling/put_scaling_policy.rb +20 -1
- data/lib/fog/aws/requests/auto_scaling/update_auto_scaling_group.rb +1 -1
- data/lib/fog/aws/requests/cloud_watch/delete_alarms.rb +19 -1
- data/lib/fog/aws/requests/cloud_watch/describe_alarms.rb +20 -2
- data/lib/fog/aws/requests/cloud_watch/put_metric_alarm.rb +9 -0
- data/lib/fog/aws/requests/compute/allocate_address.rb +4 -5
- data/lib/fog/aws/requests/compute/create_dhcp_options.rb +6 -5
- data/lib/fog/aws/requests/compute/create_internet_gateway.rb +7 -6
- data/lib/fog/aws/requests/compute/create_subnet.rb +11 -10
- data/lib/fog/aws/requests/compute/create_vpc.rb +8 -7
- data/lib/fog/aws/requests/compute/delete_dhcp_options.rb +1 -0
- data/lib/fog/aws/requests/compute/delete_internet_gateway.rb +1 -0
- data/lib/fog/aws/requests/compute/delete_subnet.rb +1 -0
- data/lib/fog/aws/requests/compute/delete_vpc.rb +2 -1
- data/lib/fog/aws/requests/compute/describe_availability_zones.rb +1 -0
- data/lib/fog/aws/requests/compute/describe_dhcp_options.rb +1 -8
- data/lib/fog/aws/requests/compute/describe_instances.rb +3 -1
- data/lib/fog/aws/requests/compute/describe_internet_gateways.rb +1 -8
- data/lib/fog/aws/requests/compute/describe_subnets.rb +1 -9
- data/lib/fog/aws/requests/compute/describe_vpcs.rb +1 -8
- data/lib/fog/aws/requests/compute/release_address.rb +12 -4
- data/lib/fog/aws/requests/compute/start_instances.rb +1 -0
- data/lib/fog/aws/requests/compute/stop_instances.rb +1 -0
- data/lib/fog/aws/requests/elasticache/create_cache_cluster.rb +26 -2
- data/lib/fog/aws/requests/elasticache/delete_cache_cluster.rb +10 -1
- data/lib/fog/aws/requests/elasticache/describe_cache_clusters.rb +16 -1
- data/lib/fog/aws/requests/elasticache/modify_cache_cluster.rb +35 -3
- data/lib/fog/aws/requests/elasticache/reboot_cache_cluster.rb +10 -2
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +1 -1
- data/lib/fog/aws/requests/rds/describe_db_instances.rb +3 -3
- data/lib/fog/aws/sqs.rb +1 -1
- data/lib/fog/aws/storage.rb +1 -1
- data/lib/fog/bin/rackspace.rb +4 -0
- data/lib/fog/cloudstack/compute.rb +25 -18
- data/lib/fog/cloudstack/models/compute/image.rb +34 -34
- data/lib/fog/cloudstack/models/compute/job.rb +14 -1
- data/lib/fog/cloudstack/models/compute/jobs.rb +1 -1
- data/lib/fog/cloudstack/models/compute/security_group.rb +50 -0
- data/lib/fog/cloudstack/models/compute/security_group_rule.rb +62 -0
- data/lib/fog/cloudstack/models/compute/security_group_rules.rb +37 -0
- data/lib/fog/cloudstack/models/compute/security_groups.rb +27 -0
- data/lib/fog/cloudstack/models/compute/server.rb +63 -39
- data/lib/fog/cloudstack/models/compute/volume.rb +3 -7
- data/lib/fog/cloudstack/models/compute/zone.rb +1 -2
- data/lib/fog/cloudstack/requests/compute/assign_virtual_machine.rb +18 -0
- data/lib/fog/cloudstack/requests/compute/authorize_security_group_egress.rb +68 -0
- data/lib/fog/cloudstack/requests/compute/authorize_security_group_ingress.rb +55 -4
- data/lib/fog/cloudstack/requests/compute/create_security_group.rb +12 -4
- data/lib/fog/cloudstack/requests/compute/create_zone.rb +20 -0
- data/lib/fog/cloudstack/requests/compute/delete_security_group.rb +17 -0
- data/lib/fog/cloudstack/requests/compute/destroy_virtual_machine.rb +23 -1
- data/lib/fog/cloudstack/requests/compute/list_firewall_rules.rb +15 -0
- data/lib/fog/cloudstack/requests/compute/list_security_groups.rb +22 -4
- data/lib/fog/cloudstack/requests/compute/query_async_job_result.rb +15 -3
- data/lib/fog/cloudstack/requests/compute/revoke_security_group_egress.rb +42 -0
- data/lib/fog/cloudstack/requests/compute/revoke_security_group_ingress.rb +29 -3
- data/lib/fog/core.rb +1 -0
- data/lib/fog/core/attributes.rb +1 -1
- data/lib/fog/core/current_machine.rb +2 -2
- data/lib/fog/core/scp.rb +8 -0
- data/lib/fog/core/ssh.rb +8 -0
- data/lib/fog/dynect/dns.rb +14 -5
- data/lib/fog/ibm/requests/compute/create_instance.rb +1 -1
- data/lib/fog/libvirt/requests/compute/create_volume.rb +1 -1
- data/lib/fog/libvirt/requests/compute/list_volumes.rb +1 -1
- data/lib/fog/local/models/storage/file.rb +12 -1
- data/lib/fog/local/storage.rb +25 -1
- data/lib/fog/ninefold/compute.rb +1 -0
- data/lib/fog/openstack.rb +3 -1
- data/lib/fog/openstack/compute.rb +13 -2
- data/lib/fog/openstack/models/compute/servers.rb +10 -2
- data/lib/fog/openstack/requests/compute/create_flavor.rb +2 -2
- data/lib/fog/openstack/requests/compute/create_security_group.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_server.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_volume.rb +1 -1
- data/lib/fog/openstack/requests/compute/get_flavor_details.rb +7 -7
- data/lib/fog/openstack/requests/compute/get_quota.rb +1 -12
- data/lib/fog/openstack/requests/compute/get_quota_defaults.rb +1 -12
- data/lib/fog/openstack/requests/compute/get_volume_details.rb +1 -1
- data/lib/fog/openstack/requests/compute/list_flavors.rb +7 -7
- data/lib/fog/openstack/requests/compute/list_flavors_detail.rb +7 -7
- data/lib/fog/openstack/requests/compute/list_security_groups.rb +7 -7
- data/lib/fog/openstack/requests/compute/list_servers_detail.rb +4 -3
- data/lib/fog/openstack/requests/compute/list_volumes.rb +6 -8
- data/lib/fog/openstack/requests/compute/update_quota.rb +2 -15
- data/lib/fog/openstack/requests/identity/delete_role.rb +1 -1
- data/lib/fog/openstack/requests/identity/list_roles.rb +1 -1
- data/lib/fog/openstack/requests/image/create_image.rb +3 -1
- data/lib/fog/openstack/requests/image/list_public_images.rb +19 -1
- data/lib/fog/openstack/requests/image/list_public_images_detailed.rb +20 -2
- data/lib/fog/openstack/requests/image/update_image.rb +1 -1
- data/lib/fog/rackspace.rb +2 -0
- data/lib/fog/rackspace/databases.rb +121 -0
- data/lib/fog/rackspace/identity.rb +83 -0
- data/lib/fog/rackspace/load_balancers.rb +3 -0
- data/lib/fog/rackspace/models/databases/database.rb +32 -0
- data/lib/fog/rackspace/models/databases/databases.rb +31 -0
- data/lib/fog/rackspace/models/databases/flavor.rb +15 -0
- data/lib/fog/rackspace/models/databases/flavors.rb +25 -0
- data/lib/fog/rackspace/models/databases/instance.rb +104 -0
- data/lib/fog/rackspace/models/databases/instances.rb +25 -0
- data/lib/fog/rackspace/models/databases/user.rb +32 -0
- data/lib/fog/rackspace/models/databases/users.rb +31 -0
- data/lib/fog/rackspace/models/identity/credential.rb +13 -0
- data/lib/fog/rackspace/models/identity/credentials.rb +32 -0
- data/lib/fog/rackspace/models/identity/role.rb +14 -0
- data/lib/fog/rackspace/models/identity/roles.rb +32 -0
- data/lib/fog/rackspace/models/identity/tenant.rb +15 -0
- data/lib/fog/rackspace/models/identity/tenants.rb +28 -0
- data/lib/fog/rackspace/models/identity/user.rb +53 -0
- data/lib/fog/rackspace/models/identity/users.rb +36 -0
- data/lib/fog/rackspace/models/load_balancers/load_balancer.rb +17 -0
- data/lib/fog/rackspace/requests/databases/check_root_user.rb +15 -0
- data/lib/fog/rackspace/requests/databases/create_database.rb +24 -0
- data/lib/fog/rackspace/requests/databases/create_instance.rb +26 -0
- data/lib/fog/rackspace/requests/databases/create_user.rb +24 -0
- data/lib/fog/rackspace/requests/databases/delete_database.rb +15 -0
- data/lib/fog/rackspace/requests/databases/delete_instance.rb +15 -0
- data/lib/fog/rackspace/requests/databases/delete_user.rb +15 -0
- data/lib/fog/rackspace/requests/databases/enable_root_user.rb +15 -0
- data/lib/fog/rackspace/requests/databases/get_flavor.rb +15 -0
- data/lib/fog/rackspace/requests/databases/get_instance.rb +15 -0
- data/lib/fog/rackspace/requests/databases/list_databases.rb +15 -0
- data/lib/fog/rackspace/requests/databases/list_flavors.rb +15 -0
- data/lib/fog/rackspace/requests/databases/list_instances.rb +15 -0
- data/lib/fog/rackspace/requests/databases/list_users.rb +15 -0
- data/lib/fog/rackspace/requests/databases/resize_instance.rb +22 -0
- data/lib/fog/rackspace/requests/databases/resize_instance_volume.rb +24 -0
- data/lib/fog/rackspace/requests/databases/restart_instance.rb +20 -0
- data/lib/fog/rackspace/requests/identity/create_token.rb +25 -0
- data/lib/fog/rackspace/requests/identity/create_user.rb +25 -0
- data/lib/fog/rackspace/requests/identity/delete_user.rb +15 -0
- data/lib/fog/rackspace/requests/identity/get_credentials.rb +15 -0
- data/lib/fog/rackspace/requests/identity/get_user_by_id.rb +15 -0
- data/lib/fog/rackspace/requests/identity/get_user_by_name.rb +15 -0
- data/lib/fog/rackspace/requests/identity/list_credentials.rb +22 -0
- data/lib/fog/rackspace/requests/identity/list_tenants.rb +22 -0
- data/lib/fog/rackspace/requests/identity/list_user_roles.rb +22 -0
- data/lib/fog/rackspace/requests/identity/list_users.rb +22 -0
- data/lib/fog/rackspace/requests/identity/update_user.rb +24 -0
- data/lib/fog/rackspace/requests/load_balancers/get_ssl_termination.rb +15 -0
- data/lib/fog/rackspace/requests/load_balancers/remove_ssl_termination.rb +15 -0
- data/lib/fog/rackspace/requests/load_balancers/set_ssl_termination.rb +31 -0
- data/lib/fog/rackspace/storage.rb +1 -1
- data/lib/fog/vsphere/models/compute/server.rb +1 -0
- data/lib/fog/vsphere/requests/compute/vm_clone.rb +2 -2
- data/tests/aws/models/compute/address_tests.rb +2 -1
- data/tests/aws/models/compute/volume_tests.rb +1 -1
- data/tests/aws/models/dns/records_tests.rb +19 -1
- data/tests/aws/models/storage/directory_tests.rb +1 -1
- data/tests/aws/models/storage/url_tests.rb +7 -1
- data/tests/aws/requests/auto_scaling/auto_scaling_tests.rb +4 -2
- data/tests/aws/requests/compute/address_tests.rb +19 -1
- data/tests/aws/requests/elasticache/cache_cluster_tests.rb +4 -4
- data/tests/aws/requests/elb/helper.rb +13 -2
- data/tests/aws/requests/iam/access_key_tests.rb +1 -3
- data/tests/cloudstack/compute/models/security_group_rule_tests.rb +29 -0
- data/tests/cloudstack/compute/models/security_group_tests.rb +16 -0
- data/tests/cloudstack/compute/models/security_groups_tests.rb +19 -0
- data/tests/cloudstack/compute/models/server_tests.rb +18 -0
- data/tests/cloudstack/compute/models/volume_tests.rb +34 -0
- data/tests/cloudstack/compute/models/volumes_tests.rb +17 -0
- data/tests/compute/helper.rb +10 -3
- data/tests/core/current_machine_tests.rb +32 -0
- data/tests/helper.rb +1 -1
- data/tests/helpers/mock_helper.rb +3 -0
- data/tests/hp/requests/compute/address_tests.rb +2 -1
- data/tests/joyent/requests/compute/datasets_tests.rb +12 -3
- data/tests/local/models/file_tests.rb +43 -0
- data/tests/local/storage_tests.rb +40 -0
- data/tests/openstack/requests/compute/flavor_tests.rb +1 -1
- data/tests/openstack/requests/compute/server_tests.rb +3 -3
- data/tests/openstack/requests/compute/volume_tests.rb +1 -1
- data/tests/openstack/requests/identity/role_tests.rb +1 -1
- data/tests/rackspace/databases_tests.rb +26 -0
- data/tests/rackspace/models/databases/database_tests.rb +17 -0
- data/tests/rackspace/models/databases/databases_tests.rb +17 -0
- data/tests/rackspace/models/databases/flavors_tests.rb +20 -0
- data/tests/rackspace/models/databases/instance_tests.rb +43 -0
- data/tests/rackspace/models/databases/instances_tests.rb +14 -0
- data/tests/rackspace/models/databases/user_tests.rb +21 -0
- data/tests/rackspace/models/databases/users_tests.rb +21 -0
- data/tests/rackspace/models/identity/credentials_tests.rb +16 -0
- data/tests/rackspace/models/identity/roles_tests.rb +16 -0
- data/tests/rackspace/models/identity/tenants_tests.rb +21 -0
- data/tests/rackspace/models/identity/user_tests.rb +17 -0
- data/tests/rackspace/models/identity/users_tests.rb +17 -0
- data/tests/rackspace/models/load_balancers/load_balancer_tests.rb +20 -0
- data/tests/rackspace/requests/databases/database_tests.rb +36 -0
- data/tests/rackspace/requests/databases/flavor_tests.rb +16 -0
- data/tests/rackspace/requests/databases/helper.rb +84 -0
- data/tests/rackspace/requests/databases/instance_tests.rb +77 -0
- data/tests/rackspace/requests/databases/user_tests.rb +37 -0
- data/tests/rackspace/requests/identity/tenants_tests.rb +21 -0
- data/tests/rackspace/requests/identity/token_tests.rb +63 -0
- data/tests/rackspace/requests/identity/user_tests.rb +107 -0
- data/tests/rackspace/requests/load_balancers/helper.rb +70 -1
- data/tests/rackspace/requests/load_balancers/ssl_termination_tests.rb +38 -0
- data/tests/storage/models/file_tests.rb +1 -1
- metadata +129 -13
- data/spec/core/current_machine_spec.rb +0 -32
- data/spec/lib/fog/aws/parsers/sqs/receive_message_spec.rb +0 -58
- data/spec/spec_helper.rb +0 -8
@@ -27,7 +27,7 @@ Shindo.tests('Fog::Compute[:openstack] | flavor requests', ['openstack']) do
|
|
27
27
|
end
|
28
28
|
|
29
29
|
tests('#create_flavor(attributes)').formats({'flavor' => @flavor_format}) do
|
30
|
-
attributes = {:flavor_id => '100', :name => 'shindo test flavor', :disk => 10, :ram => 10, :vcpus => 10, :swap => 0, :rxtx_factor => 1.0, :ephemeral => 0}
|
30
|
+
attributes = {:flavor_id => '100', :name => 'shindo test flavor', :disk => 10, :ram => 10, :vcpus => 10, :swap => "0", :rxtx_factor => 1.0, :ephemeral => 0}
|
31
31
|
Fog::Compute[:openstack].create_flavor(attributes).body
|
32
32
|
end
|
33
33
|
|
@@ -60,8 +60,8 @@ Shindo.tests('Fog::Compute[:openstack] | server requests', ['openstack']) do
|
|
60
60
|
end
|
61
61
|
|
62
62
|
#CHANGE PASSWORD
|
63
|
-
tests("#
|
64
|
-
Fog::Compute[:openstack].
|
63
|
+
tests("#change_server_password(#{@server_id}, 'fogupdatedserver')").succeeds do
|
64
|
+
Fog::Compute[:openstack].change_server_password(@server_id, 'foggy')
|
65
65
|
end
|
66
66
|
Fog::Compute[:openstack].servers.get(@server_id).wait_for { ready? }
|
67
67
|
|
@@ -93,7 +93,7 @@ Shindo.tests('Fog::Compute[:openstack] | server requests', ['openstack']) do
|
|
93
93
|
|
94
94
|
#RESIZE CONFIRM
|
95
95
|
tests("#resize_confirm(#{@server_id}, '3')").succeeds do
|
96
|
-
Fog::Compute[:openstack].
|
96
|
+
Fog::Compute[:openstack].confirm_resize_server(@server_id)
|
97
97
|
end
|
98
98
|
Fog::Compute[:openstack].servers.get(@server_id).wait_for { ready? } if not Fog.mocking?
|
99
99
|
|
@@ -10,7 +10,7 @@ Shindo.tests('Fog::Compute[:openstack] | volume requests', ['openstack']) do
|
|
10
10
|
'status' => String,
|
11
11
|
'snapshotId' => String,
|
12
12
|
'availabilityZone' => String,
|
13
|
-
'
|
13
|
+
'attachments' => Array,
|
14
14
|
'volumeType' => NilClass,
|
15
15
|
'createdAt' => Time
|
16
16
|
}
|
@@ -32,7 +32,7 @@ Shindo.tests('Fog::Identity[:openstack] | role requests', ['openstack']) do
|
|
32
32
|
Fog::Identity[:openstack].delete_user_role(@tenant['id'], @user['id'], @role['id']).body
|
33
33
|
end
|
34
34
|
|
35
|
-
tests("#delete_role('#{@role['id']}')").
|
35
|
+
tests("#delete_role('#{@role['id']}')").succeeds do
|
36
36
|
Fog::Identity[:openstack].delete_role(@role['id']).body
|
37
37
|
end
|
38
38
|
|
@@ -0,0 +1,26 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Databases', ['rackspace']) do |variable|
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
@service = Fog::Rackspace::Databases.new
|
6
|
+
|
7
|
+
tests('#flavors').succeeds do
|
8
|
+
data = @service.flavors
|
9
|
+
returns(true) { data.is_a? Array }
|
10
|
+
end
|
11
|
+
|
12
|
+
tests('#instances').succeeds do
|
13
|
+
data = @service.instances
|
14
|
+
returns(true) { data.is_a? Array }
|
15
|
+
end
|
16
|
+
|
17
|
+
tests('#databases').succeeds do
|
18
|
+
data = @service.databases
|
19
|
+
returns(true) { data.is_a? Array }
|
20
|
+
end
|
21
|
+
|
22
|
+
tests('#users').succeeds do
|
23
|
+
data = @service.users
|
24
|
+
returns(true) { data.is_a? Array }
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Databases | database', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Databases.new
|
6
|
+
instance = service.instances.create({
|
7
|
+
:name => "fog_instance_#{Time.now.to_i.to_s}",
|
8
|
+
:flavor_id => 1,
|
9
|
+
:volume_size => 1
|
10
|
+
})
|
11
|
+
|
12
|
+
instance.wait_for { ready? }
|
13
|
+
|
14
|
+
model_tests(instance.databases, { :name => "db_#{Time.now.to_i.to_s}" }, false)
|
15
|
+
|
16
|
+
instance.destroy
|
17
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Databases | databases', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Databases.new
|
6
|
+
instance = service.instances.create({
|
7
|
+
:name => "fog_instance_#{Time.now.to_i.to_s}",
|
8
|
+
:flavor_id => 1,
|
9
|
+
:volume_size => 1
|
10
|
+
})
|
11
|
+
|
12
|
+
instance.wait_for { ready? }
|
13
|
+
|
14
|
+
collection_tests(instance.databases, { :name => "db_#{Time.now.to_i.to_s}" }, false)
|
15
|
+
|
16
|
+
instance.destroy
|
17
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Databases | flavors', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Databases.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(1)
|
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,43 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Databases | instance', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Databases.new
|
6
|
+
options = {
|
7
|
+
:name => "fog_instance_#{Time.now.to_i.to_s}",
|
8
|
+
:flavor_id => 1,
|
9
|
+
:volume_size => 1
|
10
|
+
}
|
11
|
+
|
12
|
+
model_tests(service.instances, options, false) do
|
13
|
+
@instance.wait_for { ready? }
|
14
|
+
tests('root_user_enabled before user is enabled').returns(false) do
|
15
|
+
@instance.root_user_enabled?
|
16
|
+
end
|
17
|
+
|
18
|
+
@instance.wait_for { ready? }
|
19
|
+
tests('enable_root_user sets root user and password').succeeds do
|
20
|
+
@instance.enable_root_user
|
21
|
+
returns(false) { @instance.root_user.nil? }
|
22
|
+
returns(false) { @instance.root_password.nil? }
|
23
|
+
end
|
24
|
+
|
25
|
+
@instance.wait_for { ready? }
|
26
|
+
tests('restarts instance').succeeds do
|
27
|
+
@instance.restart
|
28
|
+
returns('REBOOT') { @instance.state }
|
29
|
+
end
|
30
|
+
|
31
|
+
@instance.wait_for { ready? }
|
32
|
+
tests('resizes instance').succeeds do
|
33
|
+
@instance.resize(2)
|
34
|
+
returns('RESIZE') { @instance.state }
|
35
|
+
end
|
36
|
+
|
37
|
+
@instance.wait_for { ready? }
|
38
|
+
tests('restarts instance').succeeds do
|
39
|
+
@instance.resize_volume(2)
|
40
|
+
returns('RESIZE') { @instance.state }
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Databases | instances', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Databases.new
|
6
|
+
options = {
|
7
|
+
:name => "fog_instance_#{Time.now.to_i.to_s}",
|
8
|
+
:flavor_id => 1,
|
9
|
+
:volume_size => 1
|
10
|
+
}
|
11
|
+
collection_tests(service.instances, options, false) do
|
12
|
+
@instance.wait_for { ready? }
|
13
|
+
end
|
14
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Databases | user', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Databases.new
|
6
|
+
instance = service.instances.create({
|
7
|
+
:name => "fog_instance_#{Time.now.to_i.to_s}",
|
8
|
+
:flavor_id => 1,
|
9
|
+
:volume_size => 1
|
10
|
+
})
|
11
|
+
|
12
|
+
instance.wait_for { ready? }
|
13
|
+
|
14
|
+
options = {
|
15
|
+
:name => "user_#{Time.now.to_i.to_s}",
|
16
|
+
:password => "fog_user"
|
17
|
+
}
|
18
|
+
model_tests(instance.users, options, false)
|
19
|
+
|
20
|
+
instance.destroy
|
21
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Databases | users', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Databases.new
|
6
|
+
instance = service.instances.create({
|
7
|
+
:name => "fog_instance_#{Time.now.to_i.to_s}",
|
8
|
+
:flavor_id => 1,
|
9
|
+
:volume_size => 1
|
10
|
+
})
|
11
|
+
|
12
|
+
instance.wait_for { ready? }
|
13
|
+
|
14
|
+
options = {
|
15
|
+
:name => "user_#{Time.now.to_i.to_s}",
|
16
|
+
:password => "fog_user"
|
17
|
+
}
|
18
|
+
collection_tests(instance.users, options, false)
|
19
|
+
|
20
|
+
instance.destroy
|
21
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Identity | credentials', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Identity.new
|
6
|
+
user = service.users.all.first
|
7
|
+
|
8
|
+
tests("#all").succeeds do
|
9
|
+
user.credentials.all
|
10
|
+
end
|
11
|
+
|
12
|
+
tests("#get").succeeds do
|
13
|
+
credential = user.credentials.all.first
|
14
|
+
user.credentials.get(credential.identity)
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Identity | roles', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Identity.new
|
6
|
+
user = service.users.all.first
|
7
|
+
|
8
|
+
tests("#all").succeeds do
|
9
|
+
user.roles.all
|
10
|
+
end
|
11
|
+
|
12
|
+
tests("#get").succeeds do
|
13
|
+
role = user.roles.all.first
|
14
|
+
user.roles.get(role.identity)
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Identity | tenants', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Identity.new
|
6
|
+
username = "fog_user_#{Time.now.to_i.to_s}"
|
7
|
+
options = {
|
8
|
+
:username => username,
|
9
|
+
:email => 'email@example.com',
|
10
|
+
:enabled => true
|
11
|
+
}
|
12
|
+
|
13
|
+
tests("#all").succeeds do
|
14
|
+
service.tenants.all
|
15
|
+
end
|
16
|
+
|
17
|
+
tests("#get").succeeds do
|
18
|
+
tenant = service.tenants.all.first
|
19
|
+
service.tenants.get(tenant.identity)
|
20
|
+
end
|
21
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Identity | user', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Identity.new
|
6
|
+
options = {
|
7
|
+
:username => "fog_user_#{Time.now.to_i.to_s}",
|
8
|
+
:email => 'email@example.com',
|
9
|
+
:enabled => true
|
10
|
+
}
|
11
|
+
|
12
|
+
model_tests(service.users, options, false) do
|
13
|
+
tests('#save with existing user').succeeds do
|
14
|
+
@instance.save
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Identity | users', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Identity.new
|
6
|
+
username = "fog_user_#{Time.now.to_i.to_s}"
|
7
|
+
options = {
|
8
|
+
:username => username,
|
9
|
+
:email => 'email@example.com',
|
10
|
+
:enabled => true
|
11
|
+
}
|
12
|
+
collection_tests(service.users, options, false) do
|
13
|
+
tests('#get_by_name').succeeds do
|
14
|
+
service.users.get_by_name(username)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
@@ -124,6 +124,26 @@ Shindo.tests('Fog::Rackspace::LoadBalancers | load_balancer', ['rackspace']) do
|
|
124
124
|
@instance.reset_error_page
|
125
125
|
end
|
126
126
|
|
127
|
+
@instance.wait_for { ready? }
|
128
|
+
tests("#ssl_termination is nil").returns(nil) do
|
129
|
+
@instance.ssl_termination
|
130
|
+
end
|
131
|
+
|
132
|
+
@instance.wait_for { ready? }
|
133
|
+
tests("#enable_ssl_termination(443, PRIVATE_KEY, CERTIFICATE").succeeds do
|
134
|
+
@instance.enable_ssl_termination(443, PRIVATE_KEY, CERTIFICATE)
|
135
|
+
end
|
136
|
+
|
137
|
+
@instance.wait_for { ready? }
|
138
|
+
tests("#ssl_termination").succeeds do
|
139
|
+
@instance.ssl_termination
|
140
|
+
end
|
141
|
+
|
142
|
+
@instance.wait_for { ready? }
|
143
|
+
tests("#disable_ssl_termination").succeeds do
|
144
|
+
@instance.disable_ssl_termination
|
145
|
+
end
|
146
|
+
|
127
147
|
@instance.wait_for { ready? }
|
128
148
|
end
|
129
149
|
|
@@ -0,0 +1,36 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Database | database_tests', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Databases.new
|
6
|
+
instance_name = 'fog' + Time.now.to_i.to_s
|
7
|
+
instance_id = service.create_instance(instance_name, 1, 1).body['instance']['id']
|
8
|
+
|
9
|
+
until service.get_instance(instance_id).body["instance"]["status"] == 'ACTIVE'
|
10
|
+
sleep 10
|
11
|
+
end
|
12
|
+
|
13
|
+
tests('success') do
|
14
|
+
database_name = 'fogdb' + Time.now.to_i.to_s
|
15
|
+
|
16
|
+
tests("#create_database(#{instance_id}, #{database_name})").succeeds do
|
17
|
+
service.create_database(instance_id, database_name).body
|
18
|
+
end
|
19
|
+
|
20
|
+
tests("#list_databases{#{instance_id})").formats(LIST_DATABASES_FORMAT) do
|
21
|
+
service.list_databases(instance_id).body
|
22
|
+
end
|
23
|
+
|
24
|
+
tests("#delete_database(#{instance_id}, #{database_name})").succeeds do
|
25
|
+
service.delete_database(instance_id, database_name)
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
tests('failure') do
|
30
|
+
tests("#create_database(#{instance_id}, '') => Invalid Create Critera").raises(Fog::Rackspace::Databases::BadRequest) do
|
31
|
+
service.create_database(instance_id, '')
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
service.delete_instance(instance_id)
|
36
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Database | flavor_tests', ['rackspace']) do
|
2
|
+
|
3
|
+
pending if Fog.mocking?
|
4
|
+
|
5
|
+
service = Fog::Rackspace::Databases.new
|
6
|
+
|
7
|
+
tests('success') do
|
8
|
+
tests('#list_flavors_details').formats(LIST_FLAVORS_FORMAT) do
|
9
|
+
service.list_flavors().body
|
10
|
+
end
|
11
|
+
|
12
|
+
tests('#get_flavor(1)').formats(GET_FLAVOR_FORMAT) do
|
13
|
+
service.get_flavor(1).body
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,84 @@
|
|
1
|
+
LINKS_FORMAT = [{
|
2
|
+
'href' => String,
|
3
|
+
'rel' => String
|
4
|
+
}]
|
5
|
+
|
6
|
+
FLAVOR_FORMAT = {
|
7
|
+
'id' => Integer,
|
8
|
+
'name' => String,
|
9
|
+
'ram' => Integer,
|
10
|
+
'links' => LINKS_FORMAT
|
11
|
+
}
|
12
|
+
|
13
|
+
GET_FLAVOR_FORMAT = {
|
14
|
+
'flavor' => FLAVOR_FORMAT
|
15
|
+
}
|
16
|
+
|
17
|
+
LIST_FLAVORS_FORMAT = {
|
18
|
+
'flavors' => [FLAVOR_FORMAT]
|
19
|
+
}
|
20
|
+
|
21
|
+
INSTANCE_FORMAT = {
|
22
|
+
'id' => String,
|
23
|
+
'name' => String,
|
24
|
+
'status' => String,
|
25
|
+
'links' => LINKS_FORMAT,
|
26
|
+
'flavor' => {
|
27
|
+
'id' => String,
|
28
|
+
'links' => LINKS_FORMAT
|
29
|
+
},
|
30
|
+
'volume' => {
|
31
|
+
'size' => Integer
|
32
|
+
}
|
33
|
+
}
|
34
|
+
|
35
|
+
INSTANCE_DETAILS_FORMAT = INSTANCE_FORMAT.merge({
|
36
|
+
'created' => String,
|
37
|
+
'updated' => String,
|
38
|
+
'hostname' => String,
|
39
|
+
})
|
40
|
+
|
41
|
+
CREATE_INSTANCE_FORMAT = {
|
42
|
+
'instance' => INSTANCE_DETAILS_FORMAT
|
43
|
+
}
|
44
|
+
|
45
|
+
GET_INSTANCE_FORMAT = {
|
46
|
+
'instance' => INSTANCE_DETAILS_FORMAT.merge({
|
47
|
+
'volume' => {
|
48
|
+
'size' => Integer,
|
49
|
+
'used' => Float
|
50
|
+
}
|
51
|
+
})
|
52
|
+
}
|
53
|
+
|
54
|
+
LIST_INSTANCES_FORMAT = {
|
55
|
+
'instances' => [
|
56
|
+
INSTANCE_FORMAT
|
57
|
+
]
|
58
|
+
}
|
59
|
+
|
60
|
+
CHECK_ROOT_USER_FORMAT = {
|
61
|
+
'rootEnabled' => Fog::Boolean
|
62
|
+
}
|
63
|
+
|
64
|
+
ENABLE_ROOT_USER_FORMAT = {
|
65
|
+
'user' => {
|
66
|
+
'name' => String,
|
67
|
+
'password' => String
|
68
|
+
}
|
69
|
+
}
|
70
|
+
|
71
|
+
LIST_DATABASES_FORMAT = {
|
72
|
+
'databases' => [{
|
73
|
+
'name' => String
|
74
|
+
}]
|
75
|
+
}
|
76
|
+
|
77
|
+
LIST_USERS_FORMAT = {
|
78
|
+
'users' => [{
|
79
|
+
'name' => String,
|
80
|
+
'databases' => [{
|
81
|
+
'name' => String
|
82
|
+
}]
|
83
|
+
}]
|
84
|
+
}
|