gapinc-fog 1.12.1.2.1 → 1.14.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +1 -0
- data/.travis.yml +16 -1
- data/Gemfile.1.8.7 +10 -0
- data/README.md +23 -2
- data/Rakefile +2 -2
- data/changelog.txt +276 -0
- data/fog.gemspec +4 -6
- data/lib/fog/atmos/models/storage/file.rb +2 -2
- data/lib/fog/aws/elb.rb +3 -0
- data/lib/fog/aws/elb/policy_types.rb +441 -430
- data/lib/fog/aws/models/auto_scaling/activities.rb +11 -3
- data/lib/fog/aws/models/auto_scaling/groups.rb +6 -3
- data/lib/fog/aws/models/auto_scaling/policies.rb +7 -3
- data/lib/fog/aws/models/compute/volume.rb +1 -1
- data/lib/fog/aws/models/elb/backend_server_description.rb +11 -0
- data/lib/fog/aws/models/elb/backend_server_descriptions.rb +22 -0
- data/lib/fog/aws/models/elb/load_balancer.rb +15 -2
- data/lib/fog/aws/models/elb/policies.rb +28 -13
- data/lib/fog/aws/models/elb/policy.rb +20 -10
- data/lib/fog/aws/models/rds/instance_option.rb +21 -0
- data/lib/fog/aws/models/rds/instance_options.rb +30 -0
- data/lib/fog/aws/models/rds/log_file.rb +26 -0
- data/lib/fog/aws/models/rds/log_files.rb +50 -0
- data/lib/fog/aws/models/rds/server.rb +1 -0
- data/lib/fog/aws/models/rds/snapshots.rb +20 -13
- data/lib/fog/aws/parsers/auto_scaling/describe_policies.rb +5 -5
- data/lib/fog/aws/parsers/elb/describe_load_balancers.rb +44 -13
- data/lib/fog/aws/parsers/rds/db_parser.rb +28 -6
- data/lib/fog/aws/parsers/rds/describe_db_log_files.rb +44 -0
- data/lib/fog/aws/parsers/rds/describe_orderable_db_instance_options.rb +47 -0
- data/lib/fog/aws/parsers/rds/download_db_logfile_portion.rb +26 -0
- data/lib/fog/aws/parsers/storage/complete_multipart_upload.rb +1 -1
- data/lib/fog/aws/parsers/sts/assume_role.rb +30 -0
- data/lib/fog/aws/rds.rb +13 -0
- data/lib/fog/aws/requests/auto_scaling/describe_auto_scaling_groups.rb +9 -1
- data/lib/fog/aws/requests/auto_scaling/describe_policies.rb +15 -1
- data/lib/fog/aws/requests/elb/create_app_cookie_stickiness_policy.rb +0 -2
- data/lib/fog/aws/requests/elb/create_lb_cookie_stickiness_policy.rb +0 -2
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +7 -0
- data/lib/fog/aws/requests/elb/create_load_balancer_policy.rb +11 -8
- data/lib/fog/aws/requests/elb/describe_load_balancers.rb +21 -1
- data/lib/fog/aws/requests/elb/set_load_balancer_policies_for_backend_server.rb +67 -0
- data/lib/fog/aws/requests/rds/describe_db_log_files.rb +67 -0
- data/lib/fog/aws/requests/rds/describe_orderable_db_instance_options.rb +76 -0
- data/lib/fog/aws/requests/rds/download_db_logfile_portion.rb +63 -0
- data/lib/fog/aws/requests/ses/send_raw_email.rb +1 -1
- data/lib/fog/aws/requests/ses/verify_domain_identity.rb +1 -1
- data/lib/fog/aws/requests/storage/complete_multipart_upload.rb +6 -2
- data/lib/fog/aws/requests/storage/get_object.rb +1 -1
- data/lib/fog/aws/requests/sts/assume_role.rb +46 -0
- data/lib/fog/aws/ses.rb +25 -9
- data/lib/fog/aws/sts.rb +22 -6
- data/lib/fog/bin/openstack.rb +5 -0
- data/lib/fog/bin/rackspace.rb +4 -0
- data/lib/fog/brightbox/models/compute/collaboration.rb +10 -2
- data/lib/fog/brightbox/models/compute/collaborations.rb +26 -2
- data/lib/fog/brightbox/models/compute/user_collaboration.rb +16 -1
- data/lib/fog/brightbox/models/compute/user_collaborations.rb +10 -2
- data/lib/fog/cloudstack/models/compute/servers.rb +1 -1
- data/lib/fog/compute/models/server.rb +16 -10
- data/lib/fog/core.rb +1 -0
- data/lib/fog/core/collection.rb +18 -0
- data/lib/fog/core/mock.rb +16 -0
- data/lib/fog/digitalocean/compute.rb +32 -3
- data/lib/fog/digitalocean/models/compute/server.rb +43 -14
- data/lib/fog/digitalocean/models/compute/servers.rb +27 -4
- data/lib/fog/digitalocean/models/compute/ssh_keys.rb +2 -3
- data/lib/fog/digitalocean/requests/compute/create_server.rb +9 -7
- data/lib/fog/digitalocean/requests/compute/destroy_server.rb +3 -0
- data/lib/fog/digitalocean/requests/compute/list_images.rb +6 -6
- data/lib/fog/dnsimple/dns.rb +4 -1
- data/lib/fog/dnsimple/models/dns/record.rb +3 -3
- data/lib/fog/dnsimple/requests/dns/create_domain.rb +36 -0
- data/lib/fog/dnsimple/requests/dns/create_record.rb +27 -0
- data/lib/fog/dnsimple/requests/dns/delete_domain.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/delete_record.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/get_domain.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/get_record.rb +24 -0
- data/lib/fog/dnsimple/requests/dns/list_domains.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/list_records.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/update_record.rb +20 -0
- data/lib/fog/glesys/models/compute/server.rb +6 -0
- data/lib/fog/google/README.md +28 -0
- data/lib/fog/google/Rakefile +17 -0
- data/lib/fog/google/examples/bootstrap.rb +9 -0
- data/lib/fog/google/examples/create.rb +37 -0
- data/lib/fog/google/examples/eric-fail.rb +19 -0
- data/lib/fog/google/examples/get_list_images.rb +27 -0
- data/lib/fog/google/examples/launch_micro_instance.rb +21 -0
- data/lib/fog/google/examples/metadata.rb +18 -0
- data/lib/fog/google/models/compute/disks.rb +16 -6
- data/lib/fog/google/models/compute/flavors.rb +2 -1
- data/lib/fog/google/models/compute/image.rb +16 -17
- data/lib/fog/google/models/compute/images.rb +38 -5
- data/lib/fog/google/models/compute/server.rb +2 -2
- data/lib/fog/google/models/compute/servers.rb +8 -5
- data/lib/fog/google/models/storage/file.rb +7 -1
- data/lib/fog/google/parsers/storage/access_control_list.rb +2 -2
- data/lib/fog/google/requests/compute/insert_server.rb +1 -2
- data/lib/fog/google/requests/compute/list_images.rb +3 -2
- data/lib/fog/google/requests/storage/get_object.rb +1 -1
- data/lib/fog/hp/requests/storage/get_object.rb +1 -1
- data/lib/fog/ibm/requests/compute/create_instance.rb +20 -15
- data/lib/fog/internet_archive/requests/storage/get_object.rb +1 -1
- data/lib/fog/metering.rb +25 -0
- data/lib/fog/openstack.rb +2 -1
- data/lib/fog/openstack/metering.rb +215 -0
- data/lib/fog/openstack/models/compute/server.rb +5 -2
- data/lib/fog/openstack/models/metering/resource.rb +24 -0
- data/lib/fog/openstack/models/metering/resources.rb +25 -0
- data/lib/fog/openstack/models/volume/volume.rb +3 -1
- data/lib/fog/openstack/models/volume/volumes.rb +2 -1
- data/lib/fog/openstack/network.rb +24 -1
- data/lib/fog/openstack/requests/compute/create_server.rb +19 -1
- data/lib/fog/openstack/requests/compute/get_host_details.rb +2 -1
- data/lib/fog/openstack/requests/metering/get_resource.rb +32 -0
- data/lib/fog/openstack/requests/metering/get_samples.rb +55 -0
- data/lib/fog/openstack/requests/metering/get_statistics.rb +56 -0
- data/lib/fog/openstack/requests/metering/list_meters.rb +50 -0
- data/lib/fog/openstack/requests/metering/list_resources.rb +32 -0
- data/lib/fog/openstack/requests/network/delete_quota.rb +26 -0
- data/lib/fog/openstack/requests/network/get_quota.rb +31 -0
- data/lib/fog/openstack/requests/network/get_quotas.rb +31 -0
- data/lib/fog/openstack/requests/network/update_quota.rb +33 -0
- data/lib/fog/openstack/requests/storage/put_object.rb +8 -5
- data/lib/fog/openstack/requests/volume/create_volume.rb +4 -2
- data/lib/fog/rackspace.rb +24 -4
- data/lib/fog/rackspace/block_storage.rb +8 -4
- data/lib/fog/rackspace/cdn.rb +21 -4
- data/lib/fog/rackspace/compute_v2.rb +15 -4
- data/lib/fog/rackspace/errors.rb +12 -5
- data/lib/fog/rackspace/mock_data.rb +18 -7
- data/lib/fog/rackspace/models/compute_v2/key_pair.rb +56 -0
- data/lib/fog/rackspace/models/compute_v2/key_pairs.rb +43 -0
- data/lib/fog/rackspace/models/compute_v2/server.rb +7 -2
- data/lib/fog/rackspace/models/compute_v2/servers.rb +2 -1
- data/lib/fog/rackspace/models/identity/service_catalog.rb +34 -16
- data/lib/fog/rackspace/models/monitoring/agent_token.rb +40 -0
- data/lib/fog/rackspace/models/monitoring/agent_tokens.rb +28 -0
- data/lib/fog/rackspace/models/monitoring/alarm.rb +51 -0
- data/lib/fog/rackspace/models/monitoring/alarm_example.rb +26 -0
- data/lib/fog/rackspace/models/monitoring/alarm_examples.rb +31 -0
- data/lib/fog/rackspace/models/monitoring/alarms.rb +40 -0
- data/lib/fog/rackspace/models/monitoring/base.rb +36 -0
- data/lib/fog/rackspace/models/monitoring/check.rb +75 -0
- data/lib/fog/rackspace/models/monitoring/check_type.rb +15 -0
- data/lib/fog/rackspace/models/monitoring/check_types.rb +23 -0
- data/lib/fog/rackspace/models/monitoring/checks.rb +40 -0
- data/lib/fog/rackspace/models/monitoring/data_point.rb +18 -0
- data/lib/fog/rackspace/models/monitoring/data_points.rb +49 -0
- data/lib/fog/rackspace/models/monitoring/entities.rb +48 -0
- data/lib/fog/rackspace/models/monitoring/entity.rb +64 -0
- data/lib/fog/rackspace/models/monitoring/metric.rb +25 -0
- data/lib/fog/rackspace/models/monitoring/metrics.rb +27 -0
- data/lib/fog/rackspace/monitoring.rb +149 -0
- data/lib/fog/rackspace/requests/compute_v2/create_keypair.rb +53 -0
- data/lib/fog/rackspace/requests/compute_v2/create_server.rb +10 -8
- data/lib/fog/rackspace/requests/compute_v2/delete_keypair.rb +36 -0
- data/lib/fog/rackspace/requests/compute_v2/get_keypair.rb +41 -0
- data/lib/fog/rackspace/requests/compute_v2/list_keypairs.rb +37 -0
- data/lib/fog/rackspace/requests/monitoring/create_agent_token.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/create_alarm.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/create_check.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/create_entity.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/delete_agent_token.rb +17 -0
- data/lib/fog/rackspace/requests/monitoring/delete_alarm.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/delete_check.rb +17 -0
- data/lib/fog/rackspace/requests/monitoring/delete_entity.rb +17 -0
- data/lib/fog/rackspace/requests/monitoring/evaluate_alarm_example.rb +21 -0
- data/lib/fog/rackspace/requests/monitoring/get_agent_token.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/get_alarm.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/get_alarm_example.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/get_check.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/get_entity.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/list_agent_tokens.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/list_alarm_examples.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_alarms.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_check_types.rb +17 -0
- data/lib/fog/rackspace/requests/monitoring/list_checks.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_data_points.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_entities.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/list_metrics.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_notification_plans.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_overview.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/update_alarm.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/update_check.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/update_entity.rb +18 -0
- data/lib/fog/rackspace/requests/storage/delete_multiple_objects.rb +75 -0
- data/lib/fog/rackspace/requests/storage/delete_static_large_object.rb +50 -0
- data/lib/fog/rackspace/requests/storage/put_dynamic_obj_manifest.rb +44 -0
- data/lib/fog/rackspace/requests/storage/put_object.rb +1 -1
- data/lib/fog/rackspace/requests/storage/put_object_manifest.rb +3 -30
- data/lib/fog/rackspace/requests/storage/put_static_obj_manifest.rb +60 -0
- data/lib/fog/rackspace/storage.rb +24 -16
- data/lib/fog/riakcs/provisioning.rb +2 -1
- data/lib/fog/riakcs/usage.rb +2 -1
- data/lib/fog/vcloud/compute.rb +1 -1
- data/lib/fog/vcloud/requests/compute/configure_vm.rb +2 -2
- data/lib/fog/version.rb +1 -1
- data/lib/fog/vsphere/compute.rb +131 -0
- data/lib/fog/vsphere/models/compute/server.rb +5 -1
- data/lib/fog/vsphere/requests/compute/get_datacenter.rb +3 -1
- data/lib/fog/vsphere/requests/compute/get_virtual_machine.rb +20 -38
- data/lib/fog/vsphere/requests/compute/list_datacenters.rb +1 -0
- data/lib/fog/vsphere/requests/compute/list_virtual_machines.rb +8 -114
- data/lib/fog/vsphere/requests/compute/vm_clone.rb +18 -9
- data/lib/fog/vsphere/requests/compute/vm_power_off.rb +2 -0
- data/lib/fog/xenserver/compute.rb +14 -12
- data/lib/fog/xenserver/models/compute/console.rb +27 -0
- data/lib/fog/xenserver/models/compute/consoles.rb +25 -0
- data/lib/fog/xenserver/models/compute/server.rb +6 -2
- data/lib/fog/xenserver/models/compute/servers.rb +5 -0
- data/lib/fog/xenserver/requests/compute/create_server.rb +4 -0
- data/lib/fog/xml/sax_parser_connection.rb +3 -0
- data/lib/tasks/changelog_task.rb +2 -0
- data/tests/aws/models/compute/volume_tests.rb +1 -1
- data/tests/aws/models/elb/model_tests.rb +28 -1
- data/tests/aws/models/rds/instance_option_tests.rb +14 -0
- data/tests/aws/parsers/elb/describe_load_balancers.rb +65 -0
- data/tests/aws/requests/elb/helper.rb +2 -1
- data/tests/aws/requests/elb/listener_tests.rb +1 -1
- data/tests/aws/requests/elb/load_balancer_tests.rb +5 -1
- data/tests/aws/requests/elb/policy_tests.rb +85 -6
- data/tests/aws/requests/iam/helper.rb +4 -1
- data/tests/aws/requests/iam/server_certificate_tests.rb +2 -2
- data/tests/aws/requests/rds/helper.rb +35 -0
- data/tests/aws/requests/rds/instance_option_tests.rb +21 -0
- data/tests/aws/requests/rds/log_file_tests.rb +19 -0
- data/tests/aws/requests/sts/assume_role_tests.rb +19 -0
- data/tests/core/mocking_tests.rb +15 -0
- data/tests/digitalocean/helper.rb +23 -16
- data/tests/digitalocean/models/compute/flavor_tests.rb +2 -2
- data/tests/digitalocean/models/compute/image_tests.rb +2 -2
- data/tests/digitalocean/models/compute/region_tests.rb +2 -2
- data/tests/digitalocean/models/compute/server_tests.rb +11 -3
- data/tests/digitalocean/models/compute/servers_tests.rb +14 -28
- data/tests/digitalocean/models/compute/ssh_key_tests.rb +7 -3
- data/tests/digitalocean/models/compute/ssh_keys_tests.rb +5 -1
- data/tests/digitalocean/requests/compute/create_server_tests.rb +3 -6
- data/tests/digitalocean/requests/compute/destroy_server_tests.rb +1 -2
- data/tests/digitalocean/requests/compute/get_server_details_tests.rb +1 -1
- data/tests/digitalocean/requests/compute/get_ssh_key_tests.rb +4 -1
- data/tests/digitalocean/requests/compute/list_ssh_keys_tests.rb +5 -2
- data/tests/dnsimple/requests/dns/dns_tests.rb +30 -26
- data/tests/helper.rb +2 -2
- data/tests/helpers/collection_helper.rb +4 -4
- data/tests/helpers/mock_helper.rb +2 -0
- data/tests/openstack/requests/metering/meter_tests.rb +52 -0
- data/tests/openstack/requests/metering/resource_tests.rb +19 -0
- data/tests/openstack/requests/network/quota_tests.rb +65 -0
- data/tests/openstack/requests/storage/object_tests.rb +27 -2
- data/tests/rackspace/block_storage_tests.rb +2 -1
- data/tests/rackspace/cdn_tests.rb +9 -0
- data/tests/rackspace/compute_v2_tests.rb +16 -15
- data/tests/rackspace/databases_tests.rb +1 -1
- data/tests/rackspace/load_balancer_tests.rb +1 -1
- data/tests/rackspace/models/compute_v2/keypairs_tests.rb +47 -0
- data/tests/rackspace/models/identity/service_catalog_tests.rb +54 -29
- data/tests/rackspace/models/monitoring/agent_token_tests.rb +9 -0
- data/tests/rackspace/models/monitoring/agent_tokens_tests.rb +9 -0
- data/tests/rackspace/models/monitoring/alarm_example_tests.rb +18 -0
- data/tests/rackspace/models/monitoring/alarm_examples_tests.rb +19 -0
- data/tests/rackspace/models/monitoring/alarm_tests.rb +56 -0
- data/tests/rackspace/models/monitoring/alarms_tests.rb +25 -0
- data/tests/rackspace/models/monitoring/check_tests.rb +50 -0
- data/tests/rackspace/models/monitoring/check_types_tests.rb +14 -0
- data/tests/rackspace/models/monitoring/checks_tests.rb +16 -0
- data/tests/rackspace/models/monitoring/data_points_tests.rb +19 -0
- data/tests/rackspace/models/monitoring/entities_tests.rb +14 -0
- data/tests/rackspace/models/monitoring/entity_tests.rb +26 -0
- data/tests/rackspace/models/monitoring/metric_tests.rb +19 -0
- data/tests/rackspace/models/monitoring/metrics_tests.rb +17 -0
- data/tests/rackspace/monitoring_tests.rb +72 -0
- data/tests/rackspace/requests/compute_v2/keypair_tests.rb +55 -0
- data/tests/rackspace/requests/monitoring/agent_tests.rb +34 -0
- data/tests/rackspace/requests/monitoring/alarm_example_tests.rb +30 -0
- data/tests/rackspace/requests/monitoring/alarm_tests.rb +56 -0
- data/tests/rackspace/requests/monitoring/check_tests.rb +40 -0
- data/tests/rackspace/requests/monitoring/entity_tests.rb +37 -0
- data/tests/rackspace/requests/monitoring/helper.rb +78 -0
- data/tests/rackspace/requests/monitoring/list_tests.rb +60 -0
- data/tests/rackspace/requests/storage/large_object_tests.rb +303 -59
- data/tests/rackspace/requests/storage/object_tests.rb +73 -18
- data/tests/vsphere/models/compute/server_tests.rb +1 -1
- data/tests/vsphere/requests/compute/list_virtual_machines_tests.rb +2 -2
- data/tests/vsphere/requests/compute/vm_clone_tests.rb +14 -8
- data/tests/xenserver/compute_tests.rb +5 -5
- data/tests/xenserver/models/compute/console_test.rb +35 -0
- data/tests/xenserver/models/compute/consoles_test.rb +19 -0
- data/tests/xenserver/models/compute/server_tests.rb +25 -18
- data/tests/xenserver/models/compute/servers_tests.rb +1 -0
- metadata +177 -14
@@ -86,7 +86,7 @@ Shindo.tests('Fog::Rackspace::Databases', ['rackspace']) do |variable|
|
|
86
86
|
end
|
87
87
|
tests('specify old contstant style service endoint').succeeds do
|
88
88
|
@service = Fog::Rackspace::Databases.new :rackspace_endpoint => Fog::Rackspace::Databases::ORD_ENDPOINT
|
89
|
-
returns(true) { (@service.instance_variable_get("@uri").
|
89
|
+
returns(true) { (@service.instance_variable_get("@uri").to_s =~ /#{Fog::Rackspace::Databases::ORD_ENDPOINT}/ ) != nil }
|
90
90
|
@service.flavors
|
91
91
|
end
|
92
92
|
tests('specify region').succeeds do
|
@@ -85,7 +85,7 @@ Shindo.tests('Fog::Rackspace::LoadBalancers', ['rackspace']) do
|
|
85
85
|
end
|
86
86
|
tests('specify old contstant style service endoint').succeeds do
|
87
87
|
@service = Fog::Rackspace::LoadBalancers.new :rackspace_lb_endpoint => Fog::Rackspace::LoadBalancers::ORD_ENDPOINT
|
88
|
-
returns(true) { (@service.instance_variable_get("@uri").
|
88
|
+
returns(true) { (@service.instance_variable_get("@uri").to_s =~ /#{Fog::Rackspace::LoadBalancers::ORD_ENDPOINT}/ ) != nil }
|
89
89
|
@service.list_load_balancers
|
90
90
|
end
|
91
91
|
tests('specify region').succeeds do
|
@@ -0,0 +1,47 @@
|
|
1
|
+
Shindo.tests('Fog::Compute::RackspaceV2 | key_pairs', ['rackspace']) do
|
2
|
+
service = Fog::Compute::RackspaceV2.new
|
3
|
+
|
4
|
+
name = Fog::Mock.random_letters(32)
|
5
|
+
key = nil
|
6
|
+
|
7
|
+
tests("API access") do
|
8
|
+
begin
|
9
|
+
tests("create").succeeds do
|
10
|
+
key = service.key_pairs.create({:name => name})
|
11
|
+
end
|
12
|
+
|
13
|
+
tests("list all").succeeds do
|
14
|
+
service.key_pairs.all
|
15
|
+
end
|
16
|
+
|
17
|
+
tests("get").succeeds do
|
18
|
+
service.key_pairs.get(name)
|
19
|
+
end
|
20
|
+
|
21
|
+
tests("delete").succeeds do
|
22
|
+
key = nil if service.key_pairs.destroy(name)
|
23
|
+
key == nil
|
24
|
+
end
|
25
|
+
|
26
|
+
tests("get unknown").returns(nil) do
|
27
|
+
service.key_pairs.get(Fog::Mock.random_letters(32))
|
28
|
+
end
|
29
|
+
|
30
|
+
tests("delete unknown").raises(Fog::Compute::RackspaceV2::NotFound) do
|
31
|
+
service.key_pairs.destroy(Fog::Mock.random_letters(32))
|
32
|
+
end
|
33
|
+
|
34
|
+
tests("create again after delete").succeeds do
|
35
|
+
key = service.key_pairs.create({:name => name})
|
36
|
+
end
|
37
|
+
|
38
|
+
tests("create already existing").raises(Fog::Compute::RackspaceV2::ServiceError) do
|
39
|
+
service.key_pairs.create({:name => name})
|
40
|
+
end
|
41
|
+
|
42
|
+
ensure
|
43
|
+
key.destroy if key
|
44
|
+
end
|
45
|
+
|
46
|
+
end
|
47
|
+
end
|
@@ -3,35 +3,60 @@ require 'fog/rackspace/models/identity/service_catalog'
|
|
3
3
|
Shindo.tests('Fog::Rackspace::ServiceCatalog | users', ['rackspace']) do
|
4
4
|
|
5
5
|
tests('#from_response') do
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
"publicURL"=>"https://dfw.servers.api.rackspacecloud.com/v2/777"}, {"region"=>"ORD", "versionId"=>"2", "tenantId"=>"777",
|
24
|
-
"versionList"=>"https://ord.servers.api.rackspacecloud.com/", "versionInfo"=>"https://ord.servers.api.rackspacecloud.com/v2",
|
25
|
-
"publicURL"=>"https://ord.servers.api.rackspacecloud.com/v2/777"}], "name"=>"cloudServersOpenStack"}, {"type"=>"rax:monitor", "endpoints"=>[{"tenantId"=>"777",
|
26
|
-
"publicURL"=>"https://monitoring.api.rackspacecloud.com/v1.0/777"}], "name"=>"cloudMonitoring"}, {"type"=>"rax:object-cdn", "endpoints"=>[{"region"=>"DFW",
|
27
|
-
"tenantId"=>"Mosso777", "publicURL"=>"https://cdn1.clouddrive.com/v1/Mosso777"},
|
28
|
-
{"region"=>"ORD", "tenantId"=>"Mosso777",
|
29
|
-
"publicURL"=>"https://cdn2.clouddrive.com/v1/Mosso777"}], "name"=>"cloudFilesCDN"}], "user"=>{"roles"=>[{"description"=>"User Admin
|
30
|
-
Role.", "name"=>"identity:user-admin", "id"=>"3"}], "name"=>"joe-racker", "RAX-AUTH:defaultRegion"=>"", "id"=>"TK421"}}}
|
6
|
+
tests('missing serviceCatalog node') do
|
7
|
+
before_hash = {"access"=>{"token"=>{"expires"=>"2013-02-20T10:31:00.000-06:00", "tenant"=>{"name"=>"777", "id"=>"777"}, "id"=>"6ca10877-7c50-4a5c-b58f-004d835c39c3"}}}
|
8
|
+
after_hash = {}
|
9
|
+
service_catalog = Fog::Rackspace::Identity::ServiceCatalog.from_response(nil, before_hash)
|
10
|
+
returns(after_hash) { service_catalog.catalog }
|
11
|
+
end
|
12
|
+
|
13
|
+
tests('missing serviceCatalog node') do
|
14
|
+
before_hash = {"access"=>{"token"=>{"expires"=>"2013-02-20T10:31:00.000-06:00", "tenant"=>{"name"=>"777", "id"=>"777"}, "id"=>"6ca10877-7c50-4a5c-b58f-004d835c39c3"}, "serviceCatalog"=>[{"type"=>"volume", "name"=>"cloudBlockStorage", "endpoints" =>[{"region"=>"DFW", "tenantId"=>"777" }]}, {"type"=>"rax:load-balancer","name"=>"cloudLoadBalancers", "endpoints"=>[{"region"=>"ORD", "tenantId"=>"777", "publicURL"=>"https://ord.loadbalancers.api.rackspacecloud.com/v1.0/777"}] }] }}
|
15
|
+
|
16
|
+
after_hash = {:cloudBlockStorage=>nil, :cloudLoadBalancers=>"https://ord.loadbalancers.api.rackspacecloud.com/v1.0/777"}
|
17
|
+
service_catalog = Fog::Rackspace::Identity::ServiceCatalog.from_response(nil, before_hash)
|
18
|
+
returns(after_hash) { service_catalog.catalog }
|
19
|
+
end
|
20
|
+
|
21
|
+
tests('missing region') do
|
22
|
+
before_hash = {"access"=>{"token"=>{"expires"=>"2013-02-20T10:31:00.000-06:00", "tenant"=>{"name"=>"777", "id"=>"777"}, "id"=>"6ca10877-7c50-4a5c-b58f-004d835c39c3"}, "serviceCatalog"=> [{"type"=>"rax:load-balancer","name"=>"cloudLoadBalancers", "endpoints"=>[{"region"=>"ORD", "tenantId"=>"777", "publicURL"=>"https://ord.loadbalancers.api.rackspacecloud.com/v1.0/777"}, {"tenantId"=>"777", "publicURL"=>"https://ord.loadbalancers.api.rackspacecloud.com/v1.0/777"}] }] }}
|
31
23
|
|
32
|
-
|
33
|
-
|
34
|
-
|
24
|
+
after_hash = {:cloudLoadBalancers=>{:ord=>"https://ord.loadbalancers.api.rackspacecloud.com/v1.0/777", :global=>"https://ord.loadbalancers.api.rackspacecloud.com/v1.0/777"}}
|
25
|
+
service_catalog = Fog::Rackspace::Identity::ServiceCatalog.from_response(nil, before_hash)
|
26
|
+
returns(after_hash) { service_catalog.catalog }
|
27
|
+
end
|
28
|
+
|
29
|
+
tests('successful') do
|
30
|
+
before_hash = {"access"=>{"token"=>{"expires"=>"2013-02-20T10:31:00.000-06:00", "tenant"=>{"name"=>"777", "id"=>"777"}, "id"=>"6ca10877-7c50-4a5c-b58f-004d835c39c3"},
|
31
|
+
"serviceCatalog"=>[{"type"=>"volume", "endpoints"=>[{"region"=>"DFW", "tenantId"=>"777", "publicURL"=>"https://dfw.blockstorage.api.rackspacecloud.com/v1/777"},
|
32
|
+
{"region"=>"ORD", "tenantId"=>"777", "publicURL"=>"https://ord.blockstorage.api.rackspacecloud.com/v1/777"}], "name"=>"cloudBlockStorage"},
|
33
|
+
{"type"=>"rax:load-balancer", "endpoints"=>[{"region"=>"ORD", "tenantId"=>"777", "publicURL"=>"https://ord.loadbalancers.api.rackspacecloud.com/v1.0/777"},
|
34
|
+
{"region"=>"DFW", "tenantId"=>"777", "publicURL"=>"https://dfw.loadbalancers.api.rackspacecloud.com/v1.0/777"}], "name"=>"cloudLoadBalancers"},
|
35
|
+
{"type"=>"object-store", "endpoints"=>[{"internalURL"=>"https://snet-storage101.dfw1.clouddrive.com/v1/Mosso777", "region"=>"DFW",
|
36
|
+
"tenantId"=>"Mosso777",
|
37
|
+
"publicURL"=>"https://storage101.dfw1.clouddrive.com/v1/Mosso777"},
|
38
|
+
{"internalURL"=>"https://snet-storage101.ord1.clouddrive.com/v1/Mosso777", "region"=>"ORD",
|
39
|
+
"tenantId"=>"Mosso777",
|
40
|
+
"publicURL"=>"https://storage101.ord1.clouddrive.com/v1/Mosso777"}], "name"=>"cloudFiles"}, {"type"=>"rax:database",
|
41
|
+
"endpoints"=>[{"region"=>"DFW", "tenantId"=>"777", "publicURL"=>"https://dfw.databases.api.rackspacecloud.com/v1.0/777"}, {"region"=>"ORD", "tenantId"=>"777",
|
42
|
+
"publicURL"=>"https://ord.databases.api.rackspacecloud.com/v1.0/777"}], "name"=>"cloudDatabases"}, {"type"=>"rax:dns", "endpoints"=>[{"tenantId"=>"777",
|
43
|
+
"publicURL"=>"https://dns.api.rackspacecloud.com/v1.0/777"}], "name"=>"cloudDNS"}, {"type"=>"compute", "endpoints"=>[{"versionId"=>"1.0", "tenantId"=>"777",
|
44
|
+
"versionList"=>"https://servers.api.rackspacecloud.com/", "versionInfo"=>"https://servers.api.rackspacecloud.com/v1.0",
|
45
|
+
"publicURL"=>"https://servers.api.rackspacecloud.com/v1.0/777"}], "name"=>"cloudServers"}, {"type"=>"compute", "endpoints"=>[{"region"=>"DFW", "versionId"=>"2",
|
46
|
+
"tenantId"=>"777", "versionList"=>"https://dfw.servers.api.rackspacecloud.com/", "versionInfo"=>"https://dfw.servers.api.rackspacecloud.com/v2",
|
47
|
+
"publicURL"=>"https://dfw.servers.api.rackspacecloud.com/v2/777"}, {"region"=>"ORD", "versionId"=>"2", "tenantId"=>"777",
|
48
|
+
"versionList"=>"https://ord.servers.api.rackspacecloud.com/", "versionInfo"=>"https://ord.servers.api.rackspacecloud.com/v2",
|
49
|
+
"publicURL"=>"https://ord.servers.api.rackspacecloud.com/v2/777"}], "name"=>"cloudServersOpenStack"}, {"type"=>"rax:monitor", "endpoints"=>[{"tenantId"=>"777",
|
50
|
+
"publicURL"=>"https://monitoring.api.rackspacecloud.com/v1.0/777"}], "name"=>"cloudMonitoring"}, {"type"=>"rax:object-cdn", "endpoints"=>[{"region"=>"DFW",
|
51
|
+
"tenantId"=>"Mosso777", "publicURL"=>"https://cdn1.clouddrive.com/v1/Mosso777"},
|
52
|
+
{"region"=>"ORD", "tenantId"=>"Mosso777",
|
53
|
+
"publicURL"=>"https://cdn2.clouddrive.com/v1/Mosso777"}], "name"=>"cloudFilesCDN"}], "user"=>{"roles"=>[{"description"=>"User Admin
|
54
|
+
Role.", "name"=>"identity:user-admin", "id"=>"3"}], "name"=>"joe-racker", "RAX-AUTH:defaultRegion"=>"", "id"=>"TK421"}}}
|
55
|
+
|
56
|
+
after_hash = {:cloudServers=>"https://servers.api.rackspacecloud.com/v1.0/777", :cloudServersOpenStack=>{:dfw=>"https://dfw.servers.api.rackspacecloud.com/v2/777", :ord=>"https://ord.servers.api.rackspacecloud.com/v2/777"}, :cloudFiles=>{:dfw=>"https://storage101.dfw1.clouddrive.com/v1/Mosso777", :ord=>"https://storage101.ord1.clouddrive.com/v1/Mosso777"}, :cloudBlockStorage=>{:dfw=>"https://dfw.blockstorage.api.rackspacecloud.com/v1/777", :ord=>"https://ord.blockstorage.api.rackspacecloud.com/v1/777"}, :cloudMonitoring=>"https://monitoring.api.rackspacecloud.com/v1.0/777", :cloudLoadBalancers=>{:dfw=>"https://dfw.loadbalancers.api.rackspacecloud.com/v1.0/777", :ord=>"https://ord.loadbalancers.api.rackspacecloud.com/v1.0/777"}, :cloudFilesCDN=>{:dfw=>"https://cdn1.clouddrive.com/v1/Mosso777", :ord=>"https://cdn2.clouddrive.com/v1/Mosso777"}, :cloudDatabases=>{:dfw=>"https://dfw.databases.api.rackspacecloud.com/v1.0/777", :ord=>"https://ord.databases.api.rackspacecloud.com/v1.0/777"}, :cloudDNS=>"https://dns.api.rackspacecloud.com/v1.0/777"}
|
57
|
+
@service_catalog = Fog::Rackspace::Identity::ServiceCatalog.from_response(nil, before_hash)
|
58
|
+
returns(after_hash) { @service_catalog.catalog }
|
59
|
+
end
|
35
60
|
end
|
36
61
|
|
37
62
|
tests('services') do
|
@@ -75,7 +100,7 @@ Shindo.tests('Fog::Rackspace::ServiceCatalog | users', ['rackspace']) do
|
|
75
100
|
returns("http:///fake-endpoint.com") { service.service_catalog.get_endpoint :fakeService }
|
76
101
|
service_catalog.reload
|
77
102
|
raises(RuntimeError) { service_catalog.get_endpoint :fakeService }
|
78
|
-
raises(RuntimeError) { service.service_catalog.get_endpoint :fakeService }
|
103
|
+
raises(RuntimeError) { service.service_catalog.get_endpoint :fakeService }
|
79
104
|
|
80
105
|
end
|
81
106
|
end
|
@@ -0,0 +1,9 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | agent token', ['rackspace','rackspace_monitoring']) do
|
2
|
+
service = Fog::Rackspace::Monitoring.new
|
3
|
+
|
4
|
+
options = { :label => "fog_#{Time.now.to_i.to_s}" }
|
5
|
+
model_tests(service.agent_tokens, options, false) do
|
6
|
+
|
7
|
+
end
|
8
|
+
|
9
|
+
end
|
@@ -0,0 +1,9 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | agent tokens', ['rackspace','rackspace_monitoring']) do
|
2
|
+
service = Fog::Rackspace::Monitoring.new
|
3
|
+
|
4
|
+
options = { :label => "fog_#{Time.now.to_i.to_s}" }
|
5
|
+
collection_tests(service.agent_tokens, options, false) do
|
6
|
+
|
7
|
+
end
|
8
|
+
|
9
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | alarm_example', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
|
4
|
+
service = Fog::Rackspace::Monitoring.new
|
5
|
+
alarm_example_id = 'remote.http_body_match_1'
|
6
|
+
alarm = service.alarm_examples.get(alarm_example_id)
|
7
|
+
|
8
|
+
tests('#bound?') do
|
9
|
+
tests('should return false if not bound') do
|
10
|
+
returns(false) {alarm.bound?}
|
11
|
+
end
|
12
|
+
tests('should return true if bound') do
|
13
|
+
values = {'string' => '12345'}
|
14
|
+
alarm = service.alarm_examples.evaluate(alarm_example_id,values)
|
15
|
+
returns(true) {alarm.bound?}
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | alarm_examples', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
|
4
|
+
service = Fog::Rackspace::Monitoring.new
|
5
|
+
alarm_example_id = 'remote.http_body_match_1'
|
6
|
+
|
7
|
+
tests('success') do
|
8
|
+
tests('all').succeeds do
|
9
|
+
service.alarm_examples.all
|
10
|
+
end
|
11
|
+
tests('get').succeeds do
|
12
|
+
service.alarm_examples.get(alarm_example_id)
|
13
|
+
end
|
14
|
+
tests('evaluate').succeeds do
|
15
|
+
values = {'string'=> '12345'}
|
16
|
+
service.alarm_examples.evaluate(alarm_example_id,values)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,56 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | alarm', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
service = Fog::Rackspace::Monitoring.new
|
4
|
+
|
5
|
+
tests('#alarm=') do
|
6
|
+
tests('should assign alarm id if object is a string') do
|
7
|
+
alarm = Fog::Rackspace::Monitoring::Alarm.new
|
8
|
+
id = "123123"
|
9
|
+
alarm.id = "123123"
|
10
|
+
returns(Fog::Rackspace::Monitoring::Alarm) { alarm.class }
|
11
|
+
returns(id) { alarm.id }
|
12
|
+
end
|
13
|
+
tests('should set check if object is a check') do
|
14
|
+
entity_id = "555"
|
15
|
+
entity = Fog::Rackspace::Monitoring::Entity.new(:id => entity_id)
|
16
|
+
check_id = "54321"
|
17
|
+
check = Fog::Rackspace::Monitoring::Check.new(:id => check_id)
|
18
|
+
check.entity = entity
|
19
|
+
alarm = Fog::Rackspace::Monitoring::Alarm.new
|
20
|
+
alarm.check_id = check.id
|
21
|
+
|
22
|
+
returns(Fog::Rackspace::Monitoring::Alarm) { alarm.class }
|
23
|
+
returns(check_id) { alarm.check_id }
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
begin
|
28
|
+
@entity = service.entities.create :label => "fog_#{Time.now.to_i.to_s}"
|
29
|
+
@check = service.checks.create(CHECK_CREATE_OPTIONS.merge(
|
30
|
+
:label => "fog_#{Time.now.to_i.to_s}",
|
31
|
+
:entity => @entity) )
|
32
|
+
np = "npTechnicalContactsEmail"
|
33
|
+
options = CHECK_CREATE_OPTIONS.merge(
|
34
|
+
:label => "fog_#{Time.now.to_i.to_s}",
|
35
|
+
:entity => @entity,
|
36
|
+
:entity_id => @entity.id,
|
37
|
+
:check => @check,
|
38
|
+
:check_id => @check.id,
|
39
|
+
:notification_plan_id => np
|
40
|
+
)
|
41
|
+
collection = service.alarms(:entity => @entity)
|
42
|
+
model_tests(collection, options, false) do
|
43
|
+
tests('#update').succeeds do
|
44
|
+
new_label = "new_label_#{Time.now.to_i.to_s}"
|
45
|
+
@instance.label = new_label
|
46
|
+
@instance.save
|
47
|
+
@instance.label = nil # blank out label just to make sure
|
48
|
+
@instance.reload
|
49
|
+
returns(new_label) { @instance.label}
|
50
|
+
end
|
51
|
+
|
52
|
+
end
|
53
|
+
ensure
|
54
|
+
@entity.destroy if @entity
|
55
|
+
end
|
56
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | alarms', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
service = Fog::Rackspace::Monitoring.new
|
4
|
+
|
5
|
+
begin
|
6
|
+
@entity = service.entities.create :label => "fog_#{Time.now.to_i.to_s}"
|
7
|
+
@check = service.checks.create(CHECK_CREATE_OPTIONS.merge(
|
8
|
+
:label => "fog_#{Time.now.to_i.to_s}",
|
9
|
+
:entity => @entity) )
|
10
|
+
np = "npTechnicalContactsEmail"
|
11
|
+
options = CHECK_CREATE_OPTIONS.merge(
|
12
|
+
:label => "fog_#{Time.now.to_i.to_s}",
|
13
|
+
:entity => @entity,
|
14
|
+
:entity_id => @entity.id,
|
15
|
+
:check => @check,
|
16
|
+
:check_id => @check.id,
|
17
|
+
:notification_plan_id => np
|
18
|
+
)
|
19
|
+
collection = service.alarms(:entity => @entity)
|
20
|
+
collection_tests(collection, options, false) do
|
21
|
+
end
|
22
|
+
ensure
|
23
|
+
@entity.destroy if @entity
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | check', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
service = Fog::Rackspace::Monitoring.new
|
4
|
+
|
5
|
+
|
6
|
+
tests('#entity=') do
|
7
|
+
tests('should create new entity if object is a string') do
|
8
|
+
check = Fog::Rackspace::Monitoring::Check.new
|
9
|
+
id = "123123"
|
10
|
+
check.entity = "123123"
|
11
|
+
returns(Fog::Rackspace::Monitoring::Entity) { check.entity.class }
|
12
|
+
returns(id) { check.entity.id }
|
13
|
+
end
|
14
|
+
tests('should set entity if object is an entity') do
|
15
|
+
id = "555"
|
16
|
+
entity = Fog::Rackspace::Monitoring::Entity.new(:id => id)
|
17
|
+
check = Fog::Rackspace::Monitoring::Check.new
|
18
|
+
check.entity = entity
|
19
|
+
returns(Fog::Rackspace::Monitoring::Entity) { check.entity.class }
|
20
|
+
returns(id) { check.entity.id }
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
begin
|
25
|
+
@entity = service.entities.create :label => "fog_#{Time.now.to_i.to_s}"
|
26
|
+
|
27
|
+
options = CHECK_CREATE_OPTIONS.merge(:label => "fog_#{Time.now.to_i.to_s}", :entity => @entity)
|
28
|
+
collection = service.checks(:entity => @entity)
|
29
|
+
model_tests(collection, options, false) do
|
30
|
+
tests('#update').succeeds do
|
31
|
+
new_label = "new_label_#{Time.now.to_i.to_s}"
|
32
|
+
@instance.label = new_label
|
33
|
+
timeout = 2
|
34
|
+
@instance.timeout = 2
|
35
|
+
@instance.save
|
36
|
+
@instance.timeout = -1 # blank out timeout just to make sure
|
37
|
+
@instance.label = nil # blank out label just to make sure
|
38
|
+
@instance.reload
|
39
|
+
returns(timeout) { @instance.timeout }
|
40
|
+
returns(new_label) { @instance.label}
|
41
|
+
end
|
42
|
+
|
43
|
+
tests('#metrics').succeeds do
|
44
|
+
@instance.metrics
|
45
|
+
end
|
46
|
+
end
|
47
|
+
ensure
|
48
|
+
@entity.destroy if @entity
|
49
|
+
end
|
50
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | check_types', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
service = Fog::Rackspace::Monitoring.new
|
4
|
+
|
5
|
+
@check_types = service.check_types
|
6
|
+
|
7
|
+
tests('#all').succeeds do
|
8
|
+
@check_types.all
|
9
|
+
end
|
10
|
+
tests('#new').succeeds do
|
11
|
+
@check_types.new
|
12
|
+
end
|
13
|
+
|
14
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | checks', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
service = Fog::Rackspace::Monitoring.new
|
4
|
+
|
5
|
+
begin
|
6
|
+
@entity = service.entities.create :label => "fog_#{Time.now.to_i.to_s}"
|
7
|
+
|
8
|
+
options = CHECK_CREATE_OPTIONS.merge(:label => "fog_#{Time.now.to_i.to_s}", :entity => @entity)
|
9
|
+
collection = service.checks(:entity => @entity)
|
10
|
+
collection_tests(collection, options, false) do
|
11
|
+
|
12
|
+
end
|
13
|
+
ensure
|
14
|
+
@entity.destroy if @entity
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | datapoints', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
service = Fog::Rackspace::Monitoring.new
|
4
|
+
|
5
|
+
begin
|
6
|
+
label = "fog_#{Time.now.to_i.to_s}"
|
7
|
+
@entity = service.entities.create :label => label
|
8
|
+
@check = service.checks.create CHECK_CREATE_OPTIONS.merge(:label => label, :entity => @entity)
|
9
|
+
sleep(@check.period + 30) unless Fog.mocking?
|
10
|
+
@metric = service.metrics(:check => @check).first
|
11
|
+
|
12
|
+
tests('#datapoints').succeeds do
|
13
|
+
service.data_points(:metric => @metric).fetch({ :from => ((Time.now.to_i * 1000) - (3600 * 1000)) })
|
14
|
+
end
|
15
|
+
ensure
|
16
|
+
@check.destroy rescue nil if @check
|
17
|
+
@entity.destroy rescue nil if @entity
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | entities', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
service = Fog::Rackspace::Monitoring.new
|
4
|
+
|
5
|
+
options = { :label => "fog_#{Time.now.to_i.to_s}", :ip_addresses => {:default => "127.0.0.1"} }
|
6
|
+
collection_tests(service.entities, options, false) do
|
7
|
+
|
8
|
+
end
|
9
|
+
|
10
|
+
tests('overview').succeeds do
|
11
|
+
service.entities.overview
|
12
|
+
end
|
13
|
+
|
14
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | entity', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
service = Fog::Rackspace::Monitoring.new
|
4
|
+
|
5
|
+
options = { :label => "fog_#{Time.now.to_i.to_s}", :ip_addresses => {:default => "127.0.0.1"} }
|
6
|
+
model_tests(service.entities, options, false) do
|
7
|
+
|
8
|
+
tests('#update').succeeds do
|
9
|
+
new_label = "new_label_#{Time.now.to_i.to_s}"
|
10
|
+
@instance.label = new_label
|
11
|
+
@instance.save
|
12
|
+
@instance.label = nil # blank out label just to make sure
|
13
|
+
@instance.reload
|
14
|
+
returns(new_label) { @instance.label }
|
15
|
+
end
|
16
|
+
|
17
|
+
tests('#checks').succeeds do
|
18
|
+
@instance.checks
|
19
|
+
end
|
20
|
+
|
21
|
+
tests('#alarms').succeeds do
|
22
|
+
@instance.alarms
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
end
|