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
@@ -0,0 +1,19 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | metrics', ['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
|
+
@metric.datapoints
|
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,17 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | metrics', ['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
|
+
|
10
|
+
tests('#list_metrics').succeeds do
|
11
|
+
service.metrics(:check => @check).all
|
12
|
+
end
|
13
|
+
ensure
|
14
|
+
@check.destroy rescue nil if @check
|
15
|
+
@entity.destroy rescue nil if @entity
|
16
|
+
end
|
17
|
+
end
|
@@ -0,0 +1,72 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring', ['rackspace','rackspace_monitoring']) do
|
2
|
+
|
3
|
+
def assert_method(url, method)
|
4
|
+
@service.instance_variable_set "@rackspace_auth_url", url
|
5
|
+
returns(method) { @service.send :authentication_method }
|
6
|
+
end
|
7
|
+
|
8
|
+
tests('#authentication_method') do
|
9
|
+
@service = Fog::Rackspace::Monitoring.new
|
10
|
+
|
11
|
+
assert_method nil, :authenticate_v2
|
12
|
+
|
13
|
+
assert_method 'auth.api.rackspacecloud.com', :authenticate_v1 # chef's default auth endpoint
|
14
|
+
|
15
|
+
assert_method 'https://identity.api.rackspacecloud.com', :authenticate_v1
|
16
|
+
assert_method 'https://identity.api.rackspacecloud.com/v1', :authenticate_v1
|
17
|
+
assert_method 'https://identity.api.rackspacecloud.com/v1.1', :authenticate_v1
|
18
|
+
assert_method 'https://identity.api.rackspacecloud.com/v2.0', :authenticate_v2
|
19
|
+
|
20
|
+
assert_method 'https://lon.identity.api.rackspacecloud.com', :authenticate_v1
|
21
|
+
assert_method 'https://lon.identity.api.rackspacecloud.com/v1', :authenticate_v1
|
22
|
+
assert_method 'https://lon.identity.api.rackspacecloud.com/v1.1', :authenticate_v1
|
23
|
+
assert_method 'https://lon.identity.api.rackspacecloud.com/v2.0', :authenticate_v2
|
24
|
+
end
|
25
|
+
|
26
|
+
|
27
|
+
tests('current authentation') do
|
28
|
+
pending if Fog.mocking?
|
29
|
+
|
30
|
+
tests('variables populated').succeeds do
|
31
|
+
@service = Fog::Rackspace::Monitoring.new :rackspace_auth_url => 'https://identity.api.rackspacecloud.com/v2.0', :connection_options => {:ssl_verify_peer => true}
|
32
|
+
returns(true, "auth token populated") { !@service.send(:auth_token).nil? }
|
33
|
+
returns(false, "path populated") { @service.instance_variable_get("@uri").host.nil? }
|
34
|
+
identity_service = @service.instance_variable_get("@identity_service")
|
35
|
+
returns(false, "identity service was used") { identity_service.nil? }
|
36
|
+
returns(true, "connection_options are passed") { identity_service.instance_variable_get("@connection_options").has_key?(:ssl_verify_peer) }
|
37
|
+
@service.list_entities
|
38
|
+
end
|
39
|
+
tests('custom endpoint') do
|
40
|
+
@service = Fog::Rackspace::Monitoring.new :rackspace_auth_url => 'https://identity.api.rackspacecloud.com/v2.0',
|
41
|
+
:rackspace_monitoring_url => 'https://my-custom-endpoint.com'
|
42
|
+
returns(true, "auth token populated") { !@service.send(:auth_token).nil? }
|
43
|
+
returns(true, "uses custom endpoint") { (@service.instance_variable_get("@uri").host =~ /my-custom-endpoint\.com/) != nil }
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
tests('default auth') do
|
48
|
+
pending if Fog.mocking?
|
49
|
+
|
50
|
+
tests('no params').succeeds do
|
51
|
+
@service = Fog::Rackspace::Monitoring.new
|
52
|
+
returns(true, "auth token populated") { !@service.send(:auth_token).nil? }
|
53
|
+
returns(true) { (@service.instance_variable_get("@uri").host =~ /monitoring.api.rackspacecloud.com/) != nil }
|
54
|
+
@service.list_entities
|
55
|
+
end
|
56
|
+
tests('custom endpoint') do
|
57
|
+
@service = Fog::Rackspace::Monitoring.new :rackspace_monitoring_url => 'https://my-custom-endpoint.com'
|
58
|
+
returns(true, "auth token populated") { !@service.send(:auth_token).nil? }
|
59
|
+
returns(true, "uses custom endpoint") { (@service.instance_variable_get("@uri").host =~ /my-custom-endpoint\.com/) != nil }
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
tests('reauthentication') do
|
64
|
+
pending if Fog.mocking?
|
65
|
+
|
66
|
+
@service = Fog::Rackspace::Monitoring.new
|
67
|
+
returns(true, "auth token populated") { !@service.send(:auth_token).nil? }
|
68
|
+
@service.instance_variable_set("@auth_token", "bad_token")
|
69
|
+
returns(true) { [200, 203].include? @service.list_entities.status }
|
70
|
+
end
|
71
|
+
|
72
|
+
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
Shindo.tests('Fog::Compute::RackspaceV2 | keypair_tests', ['rackspace']) do
|
2
|
+
|
3
|
+
keypair_format = {
|
4
|
+
'name' => String,
|
5
|
+
'public_key' => String,
|
6
|
+
'fingerprint' => String,
|
7
|
+
}
|
8
|
+
|
9
|
+
create_keypair_format = {
|
10
|
+
'keypair' => keypair_format.merge({
|
11
|
+
'user_id' => String,
|
12
|
+
'private_key' => String
|
13
|
+
})
|
14
|
+
}
|
15
|
+
|
16
|
+
list_keypair_format = {
|
17
|
+
'keypairs' => [ 'keypair' => keypair_format ]
|
18
|
+
}
|
19
|
+
|
20
|
+
get_keypair_format = {
|
21
|
+
'keypair' => keypair_format
|
22
|
+
}
|
23
|
+
|
24
|
+
service = Fog::Compute.new(:provider => 'Rackspace', :version => 'V2')
|
25
|
+
keypair_name = Fog::Mock.random_letters(32)
|
26
|
+
|
27
|
+
tests('success') do
|
28
|
+
tests('#create_keypair').formats(create_keypair_format) do
|
29
|
+
service.create_keypair(keypair_name).body
|
30
|
+
end
|
31
|
+
|
32
|
+
tests('#list_keypairs').formats(list_keypair_format) do
|
33
|
+
service.list_keypairs.body
|
34
|
+
end
|
35
|
+
|
36
|
+
tests('#get_keypair').formats(get_keypair_format) do
|
37
|
+
service.get_keypair(keypair_name).body
|
38
|
+
end
|
39
|
+
|
40
|
+
tests('#delete_keypair') do
|
41
|
+
service.delete_keypair(keypair_name).body
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
unknown_keypair_name = Fog::Mock.random_letters(32)
|
46
|
+
tests('failure') do
|
47
|
+
tests('#get_unknown_keypair').raises(Fog::Compute::RackspaceV2::NotFound) do
|
48
|
+
service.get_keypair(unknown_keypair_name).body
|
49
|
+
end
|
50
|
+
|
51
|
+
tests('#delete_unknown_keypair').raises(Fog::Compute::RackspaceV2::NotFound) do
|
52
|
+
service.delete_keypair(unknown_keypair_name).body
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | agent_tests', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
|
4
|
+
account = Fog::Rackspace::Monitoring.new
|
5
|
+
agent_token = nil
|
6
|
+
options = { "label" => "Bar" }
|
7
|
+
tests('success') do
|
8
|
+
tests('#create new agent token').formats(DATA_FORMAT) do
|
9
|
+
response = account.create_agent_token(options).data
|
10
|
+
agent_token = response[:headers]["X-Object-ID"]
|
11
|
+
response
|
12
|
+
end
|
13
|
+
tests('#list agent tokens').formats(LIST_HEADERS_FORMAT) do
|
14
|
+
account.list_agent_tokens().data[:headers]
|
15
|
+
end
|
16
|
+
tests('#get agent token').formats(LIST_HEADERS_FORMAT) do
|
17
|
+
account.get_agent_token(agent_token).data[:headers]
|
18
|
+
end
|
19
|
+
tests('#delete agent token').formats(DELETE_HEADERS_FORMAT) do
|
20
|
+
account.delete_agent_token(agent_token).data[:headers]
|
21
|
+
end
|
22
|
+
end
|
23
|
+
tests('failure') do
|
24
|
+
tests('#fail to create agent token(-1)').raises(TypeError) do
|
25
|
+
account.create_agent_token(-1)
|
26
|
+
end
|
27
|
+
tests('#fail to get agent token(-1)').raises(TypeError) do
|
28
|
+
account.create_agent_token(-1)
|
29
|
+
end
|
30
|
+
tests('#fail to delete agent token(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
31
|
+
account.delete_agent_token(-1)
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | alarm_example_tests', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
|
4
|
+
account = Fog::Rackspace::Monitoring.new
|
5
|
+
example_id = "remote.http_body_match_1"
|
6
|
+
tests('success') do
|
7
|
+
tests('#list alarm examples').formats(LIST_HEADERS_FORMAT) do
|
8
|
+
account.list_alarm_examples().data[:headers]
|
9
|
+
end
|
10
|
+
tests('#get alarm example').formats(LIST_HEADERS_FORMAT) do
|
11
|
+
account.get_alarm_example(example_id).data[:headers]
|
12
|
+
end
|
13
|
+
tests('#evaluate alarm example').formats(LIST_HEADERS_FORMAT) do
|
14
|
+
options = { :string => "Foo"}
|
15
|
+
account.evaluate_alarm_example(example_id,options).data[:headers]
|
16
|
+
end
|
17
|
+
end
|
18
|
+
tests('failure') do
|
19
|
+
tests('#fail to list alarm examples(-1)').raises(ArgumentError) do
|
20
|
+
account.list_alarm_examples(-1).data[:headers]
|
21
|
+
end
|
22
|
+
tests('#fail to get alarm example(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
23
|
+
account.get_alarm_example(-1).data[:headers]
|
24
|
+
end
|
25
|
+
tests('#fail to evaluate alarm example').raises(Fog::Rackspace::Monitoring::BadRequest) do
|
26
|
+
options = { }
|
27
|
+
account.evaluate_alarm_example(example_id,options).data[:headers]
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,56 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | alarm_tests', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
|
4
|
+
account = Fog::Rackspace::Monitoring.new
|
5
|
+
entity_id = account.create_entity(:label => "Foo").data[:headers]["X-Object-ID"]
|
6
|
+
check_id = account.create_check(entity_id, CHECK_CREATE_OPTIONS).data[:headers]["X-Object-ID"]
|
7
|
+
alarm_id = nil
|
8
|
+
np = "npTechnicalContactsEmail"
|
9
|
+
tests('success') do
|
10
|
+
tests('#create new alarm').formats(DATA_FORMAT) do
|
11
|
+
alarm_criteria = "if (metric['code'] == '404') { return new AlarmStatus(CRITICAL, 'Page not found');}"
|
12
|
+
options = {
|
13
|
+
:check_id => check_id,
|
14
|
+
:notification_plan_id => np,
|
15
|
+
:criteria => alarm_criteria
|
16
|
+
}
|
17
|
+
response = account.create_alarm(entity_id,options).data
|
18
|
+
alarm_id = response[:headers]["X-Object-ID"]
|
19
|
+
response
|
20
|
+
end
|
21
|
+
tests('#update alarm').formats(DATA_FORMAT) do
|
22
|
+
options = { :label => "Bar"}
|
23
|
+
account.update_alarm(entity_id,alarm_id,options).data
|
24
|
+
end
|
25
|
+
tests('#list alarms').formats(LIST_HEADERS_FORMAT) do
|
26
|
+
account.list_alarms(entity_id).data[:headers]
|
27
|
+
end
|
28
|
+
tests('#get alarm').formats(LIST_HEADERS_FORMAT) do
|
29
|
+
account.get_alarm(entity_id,alarm_id).data[:headers]
|
30
|
+
end
|
31
|
+
tests('#delete alarm').formats(DELETE_DATA_FORMAT) do
|
32
|
+
account.delete_alarm(entity_id,alarm_id).data
|
33
|
+
end
|
34
|
+
end
|
35
|
+
tests('failure') do
|
36
|
+
tests('#fail to create new alarm(-1)').raises(Fog::Rackspace::Monitoring::BadRequest) do
|
37
|
+
account.create_alarm(entity_id, {:type => ""})
|
38
|
+
end
|
39
|
+
# Commenting out update because incorrect update throws a 502
|
40
|
+
#tests('#fail to update invalid alarm(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
41
|
+
#options = { :testing => "Bar" }
|
42
|
+
#response = account.update_alarm(-1,-1,options)
|
43
|
+
#end
|
44
|
+
tests('#fail to list alarms').raises(Fog::Rackspace::Monitoring::NotFound) do
|
45
|
+
account.list_alarms(-1)
|
46
|
+
end
|
47
|
+
tests('#fail to get alarm').raises(Fog::Rackspace::Monitoring::NotFound) do
|
48
|
+
account.get_alarm(-1,-1)
|
49
|
+
end
|
50
|
+
tests('#fail to delete alarm(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
51
|
+
account.delete_alarm(-1,-1)
|
52
|
+
end
|
53
|
+
end
|
54
|
+
account.delete_check(entity_id,check_id)
|
55
|
+
account.delete_entity(entity_id)
|
56
|
+
end
|
@@ -0,0 +1,40 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | check_tests', ['rackspace', 'rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
|
4
|
+
account = Fog::Rackspace::Monitoring.new
|
5
|
+
entity_id = account.create_entity(:label => "Foo").data[:headers]["X-Object-ID"]
|
6
|
+
check_id = nil
|
7
|
+
tests('success') do
|
8
|
+
tests('#create new check').formats(DATA_FORMAT) do
|
9
|
+
response = account.create_check(entity_id, CHECK_CREATE_OPTIONS).data
|
10
|
+
check_id = response[:headers]['X-Object-ID']
|
11
|
+
response
|
12
|
+
end
|
13
|
+
tests('#get check').formats(LIST_HEADERS_FORMAT) do
|
14
|
+
account.get_check(entity_id,check_id).data[:headers]
|
15
|
+
end
|
16
|
+
tests('#update check').formats(DATA_FORMAT) do
|
17
|
+
options = { :label => "Bar"}
|
18
|
+
account.update_check(entity_id,check_id,options).data
|
19
|
+
end
|
20
|
+
tests('#delete check').formats(DELETE_DATA_FORMAT) do
|
21
|
+
account.delete_check(entity_id,check_id).data
|
22
|
+
end
|
23
|
+
end
|
24
|
+
tests('failure') do
|
25
|
+
tests('#create new check(-1)').raises(Fog::Rackspace::Monitoring::BadRequest) do
|
26
|
+
account.create_check(entity_id, {:type => ""})
|
27
|
+
end
|
28
|
+
tests('#get check(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
29
|
+
account.get_check(-1, -1)
|
30
|
+
end
|
31
|
+
tests('#update invalid check(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
32
|
+
options = { :testing => "Bar" }
|
33
|
+
response = account.update_check(-1,-1,options)
|
34
|
+
end
|
35
|
+
tests('#delete check(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
36
|
+
account.delete_check(-1,-1)
|
37
|
+
end
|
38
|
+
end
|
39
|
+
account.delete_entity(entity_id)
|
40
|
+
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
Shindo.tests('Fog::Rackspace::Monitoring | entity_tests', ['rackspace','rackspace_monitoring']) do
|
2
|
+
pending if Fog.mocking?
|
3
|
+
account = Fog::Rackspace::Monitoring.new
|
4
|
+
entity_id = nil
|
5
|
+
tests('success') do
|
6
|
+
tests('#create new entity').formats(DATA_FORMAT) do
|
7
|
+
response = account.create_entity(:label => "Foo").data
|
8
|
+
entity_id = response[:headers]["X-Object-ID"]
|
9
|
+
response
|
10
|
+
end
|
11
|
+
tests('#get entity').formats(LIST_HEADERS_FORMAT) do
|
12
|
+
account.get_entity(entity_id).data[:headers]
|
13
|
+
end
|
14
|
+
tests('#update entity').formats(DATA_FORMAT) do
|
15
|
+
options = { :testing => "Bar"}
|
16
|
+
account.update_entity(entity_id,options).data
|
17
|
+
end
|
18
|
+
tests('#delete entity').formats(DELETE_DATA_FORMAT) do
|
19
|
+
account.delete_entity(entity_id).data
|
20
|
+
end
|
21
|
+
end
|
22
|
+
tests('failure') do
|
23
|
+
tests('#create new entity(-1)').raises(Fog::Rackspace::Monitoring::BadRequest) do
|
24
|
+
account.create_entity(:label => "")
|
25
|
+
end
|
26
|
+
tests('#get entity(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
27
|
+
account.get_entity(-1)
|
28
|
+
end
|
29
|
+
tests('#update invalid entity(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
30
|
+
options = { :testing => "Bar" }
|
31
|
+
response = account.update_entity(-1,options)
|
32
|
+
end
|
33
|
+
tests('#delete entity(-1)').raises(Fog::Rackspace::Monitoring::NotFound) do
|
34
|
+
account.delete_entity(-1)
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
@@ -0,0 +1,78 @@
|
|
1
|
+
MINIMAL_HEADERS_FORMAT = {
|
2
|
+
'X-RateLimit-Window' => String,
|
3
|
+
'X-RateLimit-Limit' => String,
|
4
|
+
'X-RateLimit-Type' => String,
|
5
|
+
'Content-Type' => String,
|
6
|
+
'Date' => String,
|
7
|
+
}
|
8
|
+
DELETE_HEADERS_FORMAT = MINIMAL_HEADERS_FORMAT.merge({
|
9
|
+
'Content-Length' => String
|
10
|
+
})
|
11
|
+
HEADERS_FORMAT = MINIMAL_HEADERS_FORMAT.merge({
|
12
|
+
'Content-Length' => String,
|
13
|
+
'X-Object-ID' => String,
|
14
|
+
'Location' => String
|
15
|
+
})
|
16
|
+
LIST_HEADERS_FORMAT = MINIMAL_HEADERS_FORMAT.merge({
|
17
|
+
'X-RateLimit-Remaining' => String,
|
18
|
+
'X-Response-Id' => String,
|
19
|
+
'Transfer-Encoding' => String,
|
20
|
+
'X-LB' => String,
|
21
|
+
'Vary' => String
|
22
|
+
})
|
23
|
+
|
24
|
+
DATA_FORMAT = {
|
25
|
+
:status => Integer,
|
26
|
+
:body => String,
|
27
|
+
:headers => HEADERS_FORMAT,
|
28
|
+
:remote_ip => String
|
29
|
+
}
|
30
|
+
DELETE_DATA_FORMAT = {
|
31
|
+
:status => Integer,
|
32
|
+
:body => String,
|
33
|
+
:headers => DELETE_HEADERS_FORMAT,
|
34
|
+
:remote_ip => String
|
35
|
+
}
|
36
|
+
|
37
|
+
CHECK_CREATE_OPTIONS = {
|
38
|
+
:details => {
|
39
|
+
:url => 'http://www.rackspace.com',
|
40
|
+
:method => 'GET',
|
41
|
+
},
|
42
|
+
:type => 'remote.http',
|
43
|
+
:monitoring_zones_poll => ['mzdfw'],
|
44
|
+
:target_hostname => 'rackspace.com',
|
45
|
+
:timeout => 30,
|
46
|
+
:period => 100
|
47
|
+
}
|
48
|
+
|
49
|
+
OVERVIEW_FORMAT = {
|
50
|
+
:status => Integer,
|
51
|
+
:body=> {
|
52
|
+
:values => [
|
53
|
+
{
|
54
|
+
:entity => {
|
55
|
+
:id => String,
|
56
|
+
:label => String,
|
57
|
+
:ip_addresses => { },
|
58
|
+
:metadata => String
|
59
|
+
},
|
60
|
+
:checks => [
|
61
|
+
],
|
62
|
+
:alarms => [
|
63
|
+
],
|
64
|
+
:latest_alarm_states => [
|
65
|
+
]
|
66
|
+
}
|
67
|
+
],
|
68
|
+
:metadata => {
|
69
|
+
:count => Integer,
|
70
|
+
:limit => Integer,
|
71
|
+
:marker => String,
|
72
|
+
:next_marker => String,
|
73
|
+
:next_href => String
|
74
|
+
}
|
75
|
+
},
|
76
|
+
:headers => LIST_HEADERS_FORMAT,
|
77
|
+
:remote_ip => String
|
78
|
+
}
|