fog 0.3.31 → 0.3.32
Sign up to get free protection for your applications and to get access to all the features.
- data/.document +3 -0
- data/.gitignore +10 -0
- data/Gemfile.lock +1 -4
- data/README.rdoc +29 -37
- data/Rakefile +5 -25
- data/bin/fog +1 -3
- data/examples/dns_methods.rb +389 -0
- data/examples/storage.rb +103 -0
- data/fog.gemspec +4 -778
- data/lib/fog.rb +5 -66
- data/lib/fog/aws.rb +3 -0
- data/lib/fog/aws/bin.rb +7 -2
- data/lib/fog/aws/cdn.rb +2 -2
- data/lib/fog/aws/compute.rb +2 -2
- data/lib/fog/aws/dns.rb +101 -0
- data/lib/fog/aws/elb.rb +2 -2
- data/lib/fog/aws/iam.rb +2 -2
- data/lib/fog/aws/models/compute/image.rb +1 -0
- data/lib/fog/aws/models/compute/server.rb +1 -1
- data/lib/fog/aws/models/compute/servers.rb +1 -13
- data/lib/fog/aws/parsers/compute/describe_images.rb +36 -34
- data/lib/fog/aws/parsers/dns/change_resource_record_sets.rb +26 -0
- data/lib/fog/aws/parsers/dns/create_hosted_zone.rb +55 -0
- data/lib/fog/aws/parsers/dns/delete_hosted_zone.rb +25 -0
- data/lib/fog/aws/parsers/dns/get_change.rb +26 -0
- data/lib/fog/aws/parsers/dns/get_hosted_zone.rb +43 -0
- data/lib/fog/aws/parsers/dns/list_hosted_zones.rb +35 -0
- data/lib/fog/aws/parsers/dns/list_resource_record_sets.rb +46 -0
- data/lib/fog/aws/requests/compute/describe_images.rb +1 -0
- data/lib/fog/aws/requests/dns/change_resource_record_sets.rb +90 -0
- data/lib/fog/aws/requests/dns/create_hosted_zone.rb +68 -0
- data/lib/fog/aws/requests/dns/delete_hosted_zone.rb +48 -0
- data/lib/fog/aws/requests/dns/get_change.rb +47 -0
- data/lib/fog/aws/requests/dns/get_hosted_zone.rb +51 -0
- data/lib/fog/aws/requests/dns/list_hosted_zones.rb +63 -0
- data/lib/fog/aws/requests/dns/list_resource_record_sets.rb +68 -0
- data/lib/fog/aws/requests/storage/get_object_url.rb +2 -2
- data/lib/fog/aws/requests/storage/put_object_url.rb +2 -2
- data/lib/fog/aws/requests/storage/sync_clock.rb +28 -0
- data/lib/fog/aws/simpledb.rb +2 -2
- data/lib/fog/aws/storage.rb +5 -3
- data/lib/fog/bluebox.rb +2 -0
- data/lib/fog/bluebox/compute.rb +2 -2
- data/lib/fog/brightbox.rb +2 -0
- data/lib/fog/brightbox/compute.rb +2 -2
- data/lib/fog/core.rb +21 -1
- data/lib/fog/core/bin.rb +3 -1
- data/lib/fog/core/compute.rb +1 -0
- data/lib/fog/core/credentials.rb +72 -50
- data/lib/fog/core/deprecation.rb +11 -5
- data/lib/fog/core/mock.rb +34 -0
- data/lib/fog/core/model.rb +9 -1
- data/lib/fog/core/service.rb +40 -26
- data/lib/fog/core/storage.rb +1 -0
- data/lib/fog/core/time.rb +21 -0
- data/lib/fog/core/wait_for.rb +17 -0
- data/lib/fog/go_grid.rb +2 -0
- data/lib/fog/go_grid/compute.rb +2 -2
- data/lib/fog/google.rb +2 -0
- data/lib/fog/google/requests/storage/get_bucket.rb +6 -5
- data/lib/fog/google/requests/storage/get_object_url.rb +4 -4
- data/lib/fog/google/requests/storage/put_object_url.rb +4 -4
- data/lib/fog/google/storage.rb +4 -3
- data/lib/fog/linode.rb +3 -0
- data/lib/fog/linode/bin.rb +5 -3
- data/lib/fog/linode/compute.rb +6 -2
- data/lib/fog/linode/dns.rb +80 -0
- data/lib/fog/linode/requests/dns/domain_create.rb +52 -0
- data/lib/fog/linode/requests/dns/domain_delete.rb +35 -0
- data/lib/fog/linode/requests/dns/domain_list.rb +50 -0
- data/lib/fog/linode/requests/dns/domain_resource_create.rb +53 -0
- data/lib/fog/linode/requests/dns/domain_resource_delete.rb +36 -0
- data/lib/fog/linode/requests/dns/domain_resource_list.rb +48 -0
- data/lib/fog/linode/requests/dns/domain_resource_update.rb +54 -0
- data/lib/fog/linode/requests/dns/domain_update.rb +48 -0
- data/lib/fog/local.rb +2 -0
- data/lib/fog/local/storage.rb +3 -3
- data/lib/fog/new_servers.rb +2 -0
- data/lib/fog/new_servers/compute.rb +2 -2
- data/lib/fog/rackspace.rb +2 -0
- data/lib/fog/rackspace/cdn.rb +2 -2
- data/lib/fog/rackspace/compute.rb +2 -2
- data/lib/fog/rackspace/storage.rb +2 -2
- data/lib/fog/slicehost.rb +3 -0
- data/lib/fog/slicehost/bin.rb +2 -0
- data/lib/fog/slicehost/compute.rb +2 -2
- data/lib/fog/slicehost/dns.rb +84 -0
- data/lib/fog/slicehost/parsers/dns/create_record.rb +26 -0
- data/lib/fog/slicehost/parsers/dns/create_zone.rb +26 -0
- data/lib/fog/slicehost/parsers/dns/get_record.rb +26 -0
- data/lib/fog/slicehost/parsers/dns/get_records.rb +30 -0
- data/lib/fog/slicehost/parsers/dns/get_zone.rb +26 -0
- data/lib/fog/slicehost/parsers/dns/get_zones.rb +30 -0
- data/lib/fog/slicehost/requests/compute/create_slice.rb +2 -2
- data/lib/fog/slicehost/requests/compute/delete_slice.rb +3 -17
- data/lib/fog/slicehost/requests/dns/create_record.rb +61 -0
- data/lib/fog/slicehost/requests/dns/create_zone.rb +54 -0
- data/lib/fog/slicehost/requests/dns/delete_record.rb +31 -0
- data/lib/fog/slicehost/requests/dns/delete_zone.rb +31 -0
- data/lib/fog/slicehost/requests/dns/get_record.rb +40 -0
- data/lib/fog/slicehost/requests/dns/get_records.rb +41 -0
- data/lib/fog/slicehost/requests/dns/get_zone.rb +40 -0
- data/lib/fog/slicehost/requests/dns/get_zones.rb +38 -0
- data/lib/fog/terremark.rb +2 -0
- data/lib/fog/terremark/ecloud.rb +2 -4
- data/lib/fog/vcloud.rb +4 -2
- data/lib/fog/vcloud/bin.rb +3 -1
- data/lib/fog/vcloud/mock_data_classes.rb +77 -11
- data/lib/fog/vcloud/terremark/ecloud.rb +22 -7
- data/lib/fog/vcloud/terremark/ecloud/models/backup_internet_service.rb +60 -0
- data/lib/fog/vcloud/terremark/ecloud/models/backup_internet_services.rb +36 -0
- data/lib/fog/vcloud/terremark/ecloud/models/internet_service.rb +28 -13
- data/lib/fog/vcloud/terremark/ecloud/models/internet_services.rb +2 -2
- data/lib/fog/vcloud/terremark/ecloud/models/ip.rb +1 -1
- data/lib/fog/vcloud/terremark/ecloud/models/network.rb +4 -1
- data/lib/fog/vcloud/terremark/ecloud/models/server.rb +5 -5
- data/lib/fog/vcloud/terremark/ecloud/models/vdc.rb +6 -2
- data/lib/fog/vcloud/terremark/ecloud/requests/add_backup_internet_service.rb +111 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/add_internet_service.rb +2 -4
- data/lib/fog/vcloud/terremark/ecloud/requests/add_node.rb +1 -3
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_internet_service.rb +39 -27
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_network.rb +1 -2
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_network_ip.rb +21 -6
- data/lib/fog/vcloud/terremark/ecloud/requests/delete_vapp.rb +2 -1
- data/lib/fog/vcloud/terremark/ecloud/requests/get_internet_services.rb +34 -17
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_extensions.rb +12 -10
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_ip.rb +15 -10
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_ips.rb +1 -12
- data/lib/fog/zerigo.rb +15 -0
- data/lib/fog/zerigo/bin.rb +25 -0
- data/lib/fog/zerigo/dns.rb +96 -0
- data/lib/fog/zerigo/parsers/dns/count_hosts.rb +24 -0
- data/lib/fog/zerigo/parsers/dns/count_zones.rb +24 -0
- data/lib/fog/zerigo/parsers/dns/create_host.rb +26 -0
- data/lib/fog/zerigo/parsers/dns/create_zone.rb +26 -0
- data/lib/fog/zerigo/parsers/dns/find_hosts.rb +30 -0
- data/lib/fog/zerigo/parsers/dns/get_host.rb +26 -0
- data/lib/fog/zerigo/parsers/dns/get_zone.rb +56 -0
- data/lib/fog/zerigo/parsers/dns/get_zone_stats.rb +26 -0
- data/lib/fog/zerigo/parsers/dns/list_hosts.rb +30 -0
- data/lib/fog/zerigo/parsers/dns/list_zones.rb +30 -0
- data/lib/fog/zerigo/requests/dns/count_hosts.rb +36 -0
- data/lib/fog/zerigo/requests/dns/count_zones.rb +36 -0
- data/lib/fog/zerigo/requests/dns/create_host.rb +70 -0
- data/lib/fog/zerigo/requests/dns/create_zone.rb +97 -0
- data/lib/fog/zerigo/requests/dns/delete_host.rb +32 -0
- data/lib/fog/zerigo/requests/dns/delete_zone.rb +33 -0
- data/lib/fog/zerigo/requests/dns/find_hosts.rb +63 -0
- data/lib/fog/zerigo/requests/dns/get_host.rb +47 -0
- data/lib/fog/zerigo/requests/dns/get_zone.rb +57 -0
- data/lib/fog/zerigo/requests/dns/get_zone_stats.rb +44 -0
- data/lib/fog/zerigo/requests/dns/list_hosts.rb +48 -0
- data/lib/fog/zerigo/requests/dns/list_zones.rb +53 -0
- data/lib/fog/zerigo/requests/dns/update_host.rb +60 -0
- data/lib/fog/zerigo/requests/dns/update_zone.rb +78 -0
- data/spec/spec_helper.rb +0 -5
- data/spec/vcloud/spec_helper.rb +3 -2
- data/spec/vcloud/terremark/ecloud/models/backup_internet_service_spec.rb +49 -0
- data/spec/vcloud/terremark/ecloud/models/backup_internet_services_spec.rb +29 -0
- data/spec/vcloud/terremark/ecloud/models/internet_service_spec.rb +32 -13
- data/spec/vcloud/terremark/ecloud/models/network_spec.rb +7 -4
- data/spec/vcloud/terremark/ecloud/models/server_spec.rb +20 -0
- data/spec/vcloud/terremark/ecloud/requests/add_backup_internet_service_spec.rb +60 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_internet_service_spec.rb +3 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_network_ip_spec.rb +55 -0
- data/spec/vcloud/terremark/ecloud/requests/delete_vapp_spec.rb +9 -0
- data/spec/vcloud/terremark/ecloud/requests/get_internet_services_spec.rb +60 -14
- data/spec/vcloud/terremark/ecloud/requests/get_network_ip_spec.rb +2 -0
- data/spec/vcloud/terremark/ecloud/requests/get_network_ips_spec.rb +3 -3
- data/tests/aws/requests/compute/image_tests.rb +15 -14
- data/tests/aws/requests/dns/dns_tests.rb +276 -0
- data/tests/brightbox/requests/compute/account_tests.rb +20 -9
- data/tests/brightbox/requests/compute/api_client_tests.rb +12 -4
- data/tests/brightbox/requests/compute/cloud_ip_tests.rb +20 -6
- data/tests/brightbox/requests/compute/image_tests.rb +9 -4
- data/tests/brightbox/requests/compute/interface_tests.rb +8 -2
- data/tests/brightbox/requests/compute/server_tests.rb +17 -5
- data/tests/brightbox/requests/compute/server_type_tests.rb +8 -4
- data/tests/brightbox/requests/compute/user_tests.rb +13 -5
- data/tests/brightbox/requests/compute/zone_tests.rb +8 -4
- data/tests/core/attribute_tests.rb +45 -0
- data/tests/helper.rb +0 -2
- data/tests/linode/requests/dns/dns_tests.rb +262 -0
- data/tests/rackspace/requests/compute/address_tests.rb +1 -1
- data/tests/rackspace/requests/compute/image_tests.rb +1 -1
- data/tests/slicehost/requests/dns_tests/dns_tests.rb +279 -0
- data/tests/zerigo/helper.rb +0 -0
- data/tests/zerigo/requests/dns/dns_tests.rb +374 -0
- metadata +280 -36
- data/spec/compact_progress_bar_formatter.rb +0 -195
- data/spec/core/attributes_spec.rb +0 -52
- data/spec/lorem.txt +0 -1
@@ -0,0 +1,78 @@
|
|
1
|
+
module Fog
|
2
|
+
module Zerigo
|
3
|
+
class DNS
|
4
|
+
class Real
|
5
|
+
|
6
|
+
# Update the parameters of a zone
|
7
|
+
# ==== Parameters
|
8
|
+
#
|
9
|
+
# * zone_id<~Integer>
|
10
|
+
# * options<~Hash> - optional paramaters
|
11
|
+
# * default_ttl<~Integer>
|
12
|
+
# * ns_type<~String>
|
13
|
+
# * ns1<~String> - required if ns_type == sec
|
14
|
+
# * nx_ttl<~Integer> -
|
15
|
+
# * slave_nameservers<~String> - required if ns_type == pri
|
16
|
+
# * axfr_ips<~String> - comma-separated list of IPs or IP blocks allowed to perform AXFRs
|
17
|
+
# * custom_nameservers<~String> - comma-separated list of custom nameservers
|
18
|
+
# * custom_ns<~String> - indicates if vanity (custom) nameservers are enabled for this domain
|
19
|
+
# * hostmaster<~String> - email of the DNS administrator or hostmaster
|
20
|
+
# * notes<~String> - notes about the domain
|
21
|
+
# * restrict_axfr<~String> - indicates if AXFR transfers should be restricted to IPs in axfr-ips
|
22
|
+
# * tag_list<~String> - List of all tags associated with this domain
|
23
|
+
#
|
24
|
+
# ==== Returns
|
25
|
+
# * response<~Excon::Response>:
|
26
|
+
# * 'status'<~Integer> - 200 for success
|
27
|
+
def update_zone( zone_id, options = {})
|
28
|
+
|
29
|
+
optional_tags= ''
|
30
|
+
options.each { |option, value|
|
31
|
+
case option
|
32
|
+
when :default_ttl
|
33
|
+
optional_tags+= "<default-ttl>#{value}</default-ttl>"
|
34
|
+
when :ns_type
|
35
|
+
optional_tags+= "<ns-type>#{value}</ns-type>"
|
36
|
+
when :ns1
|
37
|
+
optional_tags+= "<ns1>#{value}</ns1>"
|
38
|
+
when :nx_ttl
|
39
|
+
optional_tags+= "<nx-ttl type='interger'>#{value}</nx-ttl>"
|
40
|
+
when :slave_nameservers
|
41
|
+
optional_tags+= "<slave-nameservers>#{value}</slave-nameservers>"
|
42
|
+
when :axfr_ips
|
43
|
+
optional_tags+= "<axfr-ips>#{value}</axfr-ips>"
|
44
|
+
when :custom_nameservers
|
45
|
+
optional_tags+= "<custom-nameservers>#{value}</custom-nameservers>"
|
46
|
+
when :custom_ns
|
47
|
+
optional_tags+= "<custom-ns>#{value}</custom-ns>"
|
48
|
+
when :hostmaster
|
49
|
+
optional_tags+= "<hostmaster>#{value}</hostmaster>"
|
50
|
+
when :notes
|
51
|
+
optional_tags+= "<notes>#{value}</notes>"
|
52
|
+
when :restrict_axfr
|
53
|
+
optional_tags+= "<restrict-axfr>#{value}</restrict-axfr>"
|
54
|
+
when :tag_list
|
55
|
+
optional_tags+= "<tag-list>#{value}</tag-list>"
|
56
|
+
end
|
57
|
+
}
|
58
|
+
|
59
|
+
request(
|
60
|
+
:body => %Q{<?xml version="1.0" encoding="UTF-8"?><zone>#{optional_tags}</zone>},
|
61
|
+
:expects => 200,
|
62
|
+
:method => 'PUT',
|
63
|
+
:path => "/api/1.1/zones/#{zone_id}.xml"
|
64
|
+
)
|
65
|
+
end
|
66
|
+
|
67
|
+
end
|
68
|
+
|
69
|
+
class Mock
|
70
|
+
|
71
|
+
def update_zone(zone_id, options = {})
|
72
|
+
Fog::Mock.not_implemented
|
73
|
+
end
|
74
|
+
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|
78
|
+
end
|
data/spec/spec_helper.rb
CHANGED
@@ -1,7 +1,6 @@
|
|
1
1
|
require 'spec'
|
2
2
|
require 'open-uri'
|
3
3
|
require 'fog'
|
4
|
-
Fog.bin = true
|
5
4
|
require 'fog/core/bin'
|
6
5
|
require 'fog/vcloud/bin'
|
7
6
|
|
@@ -36,7 +35,3 @@ end
|
|
36
35
|
unless defined?(GENTOO_AMI)
|
37
36
|
GENTOO_AMI = 'ami-5ee70037'
|
38
37
|
end
|
39
|
-
|
40
|
-
def lorem_file
|
41
|
-
File.open(File.dirname(__FILE__) + '/lorem.txt', 'r')
|
42
|
-
end
|
data/spec/vcloud/spec_helper.rb
CHANGED
@@ -233,6 +233,7 @@ def setup_ecloud_mock_data
|
|
233
233
|
@mock_public_ip = @mock_public_ip_collection.items.first
|
234
234
|
@mock_service_collection = @mock_public_ip.internet_service_collection
|
235
235
|
@mock_service = @mock_service_collection.items.first
|
236
|
+
@mock_backup_service = @mock_vdc_service_collection.backup_internet_services.first
|
236
237
|
@mock_node_collection = @mock_service.node_collection
|
237
238
|
@mock_node = @mock_node_collection.items.first
|
238
239
|
@mock_catalog = @mock_vdc.catalog
|
@@ -273,13 +274,13 @@ Spec::Runner.configure do |config|
|
|
273
274
|
Fog::Vcloud::Mock.data_reset
|
274
275
|
Fog::Vcloud::Terremark::Ecloud::Mock.data_reset
|
275
276
|
setup_ecloud_mock_data
|
276
|
-
@vcloud = Fog::Vcloud::Terremark::Ecloud.new(:username => "foo", :password => "bar", :versions_uri => "http://fakey.com/api/versions"
|
277
|
+
@vcloud = Fog::Vcloud::Terremark::Ecloud.new(:username => "foo", :password => "bar", :versions_uri => "http://fakey.com/api/versions")
|
277
278
|
end
|
278
279
|
config.before(:each, :type => :mock_tmrk_ecloud_model) do
|
279
280
|
Fog::Vcloud::Mock.data_reset
|
280
281
|
Fog::Vcloud::Terremark::Ecloud::Mock.data_reset
|
281
282
|
setup_ecloud_mock_data
|
282
|
-
@vcloud = Fog::Vcloud::Terremark::Ecloud.new(:username => "foo", :password => "bar", :versions_uri => "http://fakey.com/api/versions"
|
283
|
+
@vcloud = Fog::Vcloud::Terremark::Ecloud.new(:username => "foo", :password => "bar", :versions_uri => "http://fakey.com/api/versions")
|
283
284
|
end
|
284
285
|
end
|
285
286
|
|
@@ -0,0 +1,49 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__),'..','..','..','spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
describe "Fog::Vcloud::Terremark::Ecloud::BackupInternetService", :type => :mock_tmrk_ecloud_model do
|
5
|
+
subject { @vcloud.vdcs[0].backup_internet_services[0] }
|
6
|
+
|
7
|
+
describe :class do
|
8
|
+
subject { Fog::Vcloud::Terremark::Ecloud::BackupInternetService }
|
9
|
+
|
10
|
+
it { should have_identity :href }
|
11
|
+
it { should have_only_these_attributes [:href, :name, :id, :protocol, :enabled, :description, :timeout, :redirect_url, :monitor] }
|
12
|
+
end
|
13
|
+
|
14
|
+
context "with no uri" do
|
15
|
+
|
16
|
+
subject { Fog::Vcloud::Terremark::Ecloud::BackupInternetService.new() }
|
17
|
+
it { should have_all_attributes_be_nil }
|
18
|
+
|
19
|
+
end
|
20
|
+
|
21
|
+
context "as a collection member" do
|
22
|
+
subject { @vcloud.vdcs[0].backup_internet_services[0].reload }
|
23
|
+
|
24
|
+
let(:composed_service_data) { @vcloud.vdcs[0].backup_internet_services[0].send(:_compose_service_data) }
|
25
|
+
|
26
|
+
it { should be_an_instance_of Fog::Vcloud::Terremark::Ecloud::BackupInternetService }
|
27
|
+
|
28
|
+
its(:href) { should == @mock_backup_service.href }
|
29
|
+
its(:identity) { should == @mock_backup_service.href }
|
30
|
+
its(:name) { should == @mock_backup_service.name }
|
31
|
+
its(:id) { should == @mock_backup_service.object_id.to_s }
|
32
|
+
its(:protocol) { should == @mock_backup_service.protocol }
|
33
|
+
its(:enabled) { should == @mock_backup_service.enabled.to_s }
|
34
|
+
its(:description) { should == @mock_backup_service.description }
|
35
|
+
its(:timeout) { should == @mock_backup_service.timeout.to_s }
|
36
|
+
its(:redirect_url) { should == (@mock_backup_service.redirect_url || "") }
|
37
|
+
its(:monitor) { should == nil }
|
38
|
+
|
39
|
+
specify { composed_service_data[:href].should == subject.href.to_s }
|
40
|
+
specify { composed_service_data[:name].should == subject.name }
|
41
|
+
specify { composed_service_data[:id].should == subject.id.to_s }
|
42
|
+
specify { composed_service_data[:protocol].should == subject.protocol }
|
43
|
+
specify { composed_service_data[:enabled].should == subject.enabled.to_s }
|
44
|
+
specify { composed_service_data[:description].should == subject.description }
|
45
|
+
specify { composed_service_data[:timeout].should == subject.timeout.to_s }
|
46
|
+
end
|
47
|
+
end
|
48
|
+
else
|
49
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__),'..','..','..','spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
describe "Fog::Vcloud::Terremark::Ecloud::InternetServices", :type => :mock_tmrk_ecloud_model do
|
5
|
+
context "as an attribute of a VDC" do
|
6
|
+
subject { @vcloud.vdcs[0] }
|
7
|
+
|
8
|
+
it { should respond_to :backup_internet_services }
|
9
|
+
|
10
|
+
describe :class do
|
11
|
+
subject { @vcloud.vdcs[0].backup_internet_services.class }
|
12
|
+
its(:model) { should == Fog::Vcloud::Terremark::Ecloud::BackupInternetService }
|
13
|
+
end
|
14
|
+
|
15
|
+
describe :backup_internet_services do
|
16
|
+
subject { @vcloud.vdcs[0].backup_internet_services }
|
17
|
+
|
18
|
+
it { should respond_to :create }
|
19
|
+
|
20
|
+
it { should be_an_instance_of Fog::Vcloud::Terremark::Ecloud::BackupInternetServices }
|
21
|
+
|
22
|
+
its(:length) { should == 1 }
|
23
|
+
|
24
|
+
it { should have_members_of_the_right_model }
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
else
|
29
|
+
end
|
@@ -8,7 +8,7 @@ if Fog.mocking?
|
|
8
8
|
subject { Fog::Vcloud::Terremark::Ecloud::InternetService }
|
9
9
|
|
10
10
|
it { should have_identity :href }
|
11
|
-
it { should have_only_these_attributes [:href, :name, :id, :protocol, :port, :enabled, :description, :public_ip, :timeout, :redirect_url, :monitor] }
|
11
|
+
it { should have_only_these_attributes [:href, :name, :id, :protocol, :port, :enabled, :description, :public_ip, :timeout, :redirect_url, :monitor, :backup_service_data] }
|
12
12
|
end
|
13
13
|
|
14
14
|
context "with no uri" do
|
@@ -31,18 +31,19 @@ if Fog.mocking?
|
|
31
31
|
|
32
32
|
it { should be_an_instance_of Fog::Vcloud::Terremark::Ecloud::InternetService }
|
33
33
|
|
34
|
-
its(:href)
|
35
|
-
its(:identity)
|
36
|
-
its(:name)
|
37
|
-
its(:id)
|
38
|
-
its(:protocol)
|
39
|
-
its(:port)
|
40
|
-
its(:enabled)
|
41
|
-
its(:description)
|
42
|
-
its(:public_ip)
|
43
|
-
its(:timeout)
|
44
|
-
its(:redirect_url)
|
45
|
-
its(:monitor)
|
34
|
+
its(:href) { should == @mock_service.href }
|
35
|
+
its(:identity) { should == @mock_service.href }
|
36
|
+
its(:name) { should == @mock_service.name }
|
37
|
+
its(:id) { should == @mock_service.object_id.to_s }
|
38
|
+
its(:protocol) { should == @mock_service.protocol }
|
39
|
+
its(:port) { should == @mock_service.port.to_s }
|
40
|
+
its(:enabled) { should == @mock_service.enabled.to_s }
|
41
|
+
its(:description) { should == @mock_service.description }
|
42
|
+
its(:public_ip) { should == public_ip }
|
43
|
+
its(:timeout) { should == @mock_service.timeout.to_s }
|
44
|
+
its(:redirect_url) { should == @mock_service.redirect_url }
|
45
|
+
its(:monitor) { should == nil }
|
46
|
+
its(:backup_service_uri) { should be_nil }
|
46
47
|
|
47
48
|
specify { composed_public_ip_data[:href].should == public_ip[:Href].to_s }
|
48
49
|
specify { composed_public_ip_data[:name].should == public_ip[:Name] }
|
@@ -56,6 +57,24 @@ if Fog.mocking?
|
|
56
57
|
specify { composed_service_data[:enabled].should == subject.enabled.to_s }
|
57
58
|
specify { composed_service_data[:description].should == subject.description }
|
58
59
|
specify { composed_service_data[:timeout].should == subject.timeout.to_s }
|
60
|
+
|
61
|
+
context "with a backup internet service" do
|
62
|
+
before { @mock_service[:backup_service] = @mock_backup_service }
|
63
|
+
|
64
|
+
its(:backup_service_uri) { should == @mock_backup_service.href }
|
65
|
+
end
|
66
|
+
|
67
|
+
describe "#backup_service_uri=" do
|
68
|
+
specify do
|
69
|
+
expect { subject.backup_service_uri = @mock_backup_service.href }.
|
70
|
+
to change { subject.backup_service_uri }.from(nil).to(@mock_backup_service.href)
|
71
|
+
end
|
72
|
+
|
73
|
+
specify do
|
74
|
+
expect { subject.backup_service_uri = @mock_backup_service.href }.
|
75
|
+
to change { subject.send(:_compose_service_data)[:backup_service_uri] }.from(nil).to(@mock_backup_service.href)
|
76
|
+
end
|
77
|
+
end
|
59
78
|
end
|
60
79
|
end
|
61
80
|
else
|
@@ -8,7 +8,7 @@ if Fog.mocking?
|
|
8
8
|
subject { Fog::Vcloud::Terremark::Ecloud::Network }
|
9
9
|
|
10
10
|
it { should have_identity :href }
|
11
|
-
it { should have_only_these_attributes [:href, :name, :features, :links, :type, :gateway, :broadcast, :address, :rnat, :extension_href] }
|
11
|
+
it { should have_only_these_attributes [:href, :name, :features, :links, :type, :gateway, :broadcast, :address, :rnat, :extension_href, :network_type, :vlan, :friendly_name] }
|
12
12
|
end
|
13
13
|
|
14
14
|
context "with no uri" do
|
@@ -32,13 +32,16 @@ if Fog.mocking?
|
|
32
32
|
its(:address) { should == @mock_network.address }
|
33
33
|
its(:rnat) { should == @mock_network.rnat }
|
34
34
|
its(:extension_href) { should == @mock_network.extensions.href }
|
35
|
+
its(:network_type) { should == @mock_network.extensions.type }
|
36
|
+
its(:vlan) { should == @mock_network.extensions.vlan }
|
37
|
+
its(:friendly_name) { should == @mock_network.extensions.friendly_name }
|
35
38
|
|
36
39
|
it { should have(1).features }
|
37
40
|
|
38
41
|
describe :features do
|
39
|
-
let(:feature) { subject.features
|
40
|
-
specify { feature.should be_an_instance_of
|
41
|
-
specify { feature
|
42
|
+
let(:feature) { subject.features.first }
|
43
|
+
specify { feature.should be_an_instance_of Array }
|
44
|
+
specify { feature.last.should == @mock_network.features[0][:value] }
|
42
45
|
end
|
43
46
|
|
44
47
|
it { should have(2).links }
|
@@ -26,6 +26,26 @@ if Fog.mocking?
|
|
26
26
|
its(:cpus) { should == { :count => @mock_vm.cpus, :units => nil } }
|
27
27
|
its(:memory) { should == { :amount => @mock_vm.memory, :units => nil } }
|
28
28
|
its(:disks) { should == @mock_vm.to_configure_vapp_hash[:disks] }
|
29
|
+
|
30
|
+
describe "question methods" do
|
31
|
+
describe "#ready?" do
|
32
|
+
before { subject.power_off }
|
33
|
+
|
34
|
+
it { should be_ready }
|
35
|
+
end
|
36
|
+
|
37
|
+
describe "#on?" do
|
38
|
+
before { subject.power_on }
|
39
|
+
|
40
|
+
it { should be_on }
|
41
|
+
end
|
42
|
+
|
43
|
+
describe "#off?" do
|
44
|
+
before { subject.power_off }
|
45
|
+
|
46
|
+
it { should be_off }
|
47
|
+
end
|
48
|
+
end
|
29
49
|
end
|
30
50
|
|
31
51
|
context "as a new server without all info" do
|
@@ -0,0 +1,60 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), '..', '..', '..', 'spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
describe "Fog::Vcloud, initialized w/ the TMRK Ecloud module", :type => :mock_tmrk_ecloud_request do
|
5
|
+
subject { @vcloud }
|
6
|
+
|
7
|
+
it { should respond_to :add_backup_internet_service }
|
8
|
+
|
9
|
+
describe "#add_backup_internet_service" do
|
10
|
+
before do
|
11
|
+
@new_backup_service_data = {
|
12
|
+
:name => "Test Service",
|
13
|
+
:protocol => "HTTP",
|
14
|
+
:enabled => "true",
|
15
|
+
:description => "this is a test",
|
16
|
+
:redirect_url => ""
|
17
|
+
}
|
18
|
+
end
|
19
|
+
|
20
|
+
context "with a valid vdc uri" do
|
21
|
+
subject { @vcloud.add_backup_internet_service(@mock_vdc.internet_service_collection.href, @new_backup_service_data ) }
|
22
|
+
|
23
|
+
it "has the right number of Internet Services after" do
|
24
|
+
expect { subject }.to change { @vcloud.get_internet_services(@mock_vdc.internet_service_collection.href).body[:InternetService].size }.by(1)
|
25
|
+
end
|
26
|
+
|
27
|
+
it_should_behave_like "all responses"
|
28
|
+
|
29
|
+
let(:body) { subject.body }
|
30
|
+
|
31
|
+
its(:body) { should be_an_instance_of Hash }
|
32
|
+
specify { body[:Href].should_not be_empty }
|
33
|
+
specify { body[:Name].should == @new_backup_service_data[:name] }
|
34
|
+
specify { body[:Protocol].should == @new_backup_service_data[:protocol] }
|
35
|
+
specify { body[:Enabled].should == @new_backup_service_data[:enabled] }
|
36
|
+
specify { body[:Description].should == @new_backup_service_data[:description] }
|
37
|
+
specify { body[:RedirectURL].should == @new_backup_service_data[:redirect_url] }
|
38
|
+
specify { body[:Monitor].should == nil }
|
39
|
+
# so broken
|
40
|
+
specify { body[:IsBackupService].should == "false" }
|
41
|
+
|
42
|
+
it "should update the mock object properly" do
|
43
|
+
subject
|
44
|
+
|
45
|
+
backup_internet_service = @vcloud.mock_data.backup_internet_service_from_href(body[:Href])
|
46
|
+
backup_internet_service.object_id.to_s.should == body[:Id]
|
47
|
+
backup_internet_service.node_collection.items.should be_empty
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
context "with a vdc uri that doesn't exist" do
|
52
|
+
subject { lambda { @vcloud.add_backup_internet_service(URI.parse('https://www.fakey.c/piv8vc99'), @new_backup_service_data ) } }
|
53
|
+
|
54
|
+
it_should_behave_like "a request for a resource that doesn't exist"
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
else
|
59
|
+
end
|
60
|
+
|
@@ -26,6 +26,7 @@ if Fog.mocking?
|
|
26
26
|
@service_data[:description] = "TEST BOOM"
|
27
27
|
@service_data[:redirect_url] = "http://google.com"
|
28
28
|
@service_data[:port] = "80"
|
29
|
+
@service_data[:backup_service_uri] = @mock_backup_service.href
|
29
30
|
end
|
30
31
|
|
31
32
|
it "should change data" do
|
@@ -36,12 +37,14 @@ if Fog.mocking?
|
|
36
37
|
result.body[:Description].should == @service_data[:description]
|
37
38
|
result.body[:RedirectURL].should == @service_data[:redirect_url]
|
38
39
|
result.body[:Port].should == @service_data[:port]
|
40
|
+
result.body[:BackupService][:Href].should == @service_data[:backup_service_uri]
|
39
41
|
|
40
42
|
new_result = @vcloud.get_internet_services(@mock_public_ip.internet_service_collection.href).body[:InternetService].first
|
41
43
|
|
42
44
|
new_result[:Description].should == @service_data[:description]
|
43
45
|
new_result[:RedirectURL].should == @service_data[:redirect_url]
|
44
46
|
new_result[:Port].should == @service_data[:port]
|
47
|
+
new_result[:BackupService][:Href].should == @service_data[:backup_service_uri]
|
45
48
|
end
|
46
49
|
end
|
47
50
|
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
require File.join(File.dirname(__FILE__), '..', '..', '..', 'spec_helper')
|
2
|
+
|
3
|
+
if Fog.mocking?
|
4
|
+
describe "Fog::Vcloud, initialized w/ the TMRK Ecloud module", :type => :mock_tmrk_ecloud_request do
|
5
|
+
subject { @vcloud }
|
6
|
+
|
7
|
+
it { should respond_to :configure_network_ip }
|
8
|
+
|
9
|
+
describe "#configure_network_ip" do
|
10
|
+
let(:original_network_ip) { @vcloud.get_network_ip(@mock_network_ip.href).body }
|
11
|
+
let(:network_ip_data) do
|
12
|
+
{
|
13
|
+
:id => original_network_ip[:Id],
|
14
|
+
:href => original_network_ip[:Href],
|
15
|
+
:name => original_network_ip[:Name],
|
16
|
+
:status => original_network_ip[:Status],
|
17
|
+
:server => original_network_ip[:Server],
|
18
|
+
:rnat => "1.2.3.4"
|
19
|
+
}
|
20
|
+
end
|
21
|
+
|
22
|
+
context "with a valid network ip uri" do
|
23
|
+
|
24
|
+
subject { @vcloud.configure_network_ip(@mock_network_ip.href, network_ip_data) }
|
25
|
+
|
26
|
+
it_should_behave_like "all responses"
|
27
|
+
|
28
|
+
describe "#body" do
|
29
|
+
subject { @vcloud.configure_network_ip(@mock_network_ip.href, network_ip_data).body }
|
30
|
+
|
31
|
+
#Stuff that shouldn't change
|
32
|
+
its(:Href) { should == @mock_network_ip.href }
|
33
|
+
its(:Id) { should == @mock_network_ip.object_id.to_s }
|
34
|
+
its(:Name) { should == @mock_network_ip.ip }
|
35
|
+
its(:Status) { should == @mock_network_ip.status }
|
36
|
+
|
37
|
+
#Stuff that should change
|
38
|
+
it "should change the rnat" do
|
39
|
+
expect { subject }.to change { @vcloud.get_network_ip(@mock_network_ip.href).body[:RnatAddress] }.
|
40
|
+
from(@mock_network.rnat).
|
41
|
+
to(network_ip_data[:rnat])
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
end
|
46
|
+
|
47
|
+
context "with a nodes uri that doesn't exist" do
|
48
|
+
subject { lambda { @vcloud.configure_network_ip(URI.parse('https://www.fakey.c/piv8vc99'), network_ip_data) } }
|
49
|
+
|
50
|
+
it_should_behave_like "a request for a resource that doesn't exist"
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
else
|
55
|
+
end
|