1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00
fog--fog/tests/glesys/requests/compute/server_tests.rb

88 lines
2.8 KiB
Ruby
Raw Normal View History

2011-09-08 16:41:21 -04:00
Shindo.tests('Fog::Compute[:glesys] | server requests', ['glesys']) do
2011-08-17 11:53:20 -04:00
@serverid = nil
@hostname = "fog-#{Time.now.to_i}"
2011-08-17 11:53:20 -04:00
@create = ":hostname => #@hostname, :rootpw => 'pw#{Time.now.to_i}', "+
":datacenter => 'Falkenberg', :platform => 'Xen', :template => 'Debian-6 x64', "+
":disksize => '10', :memorysize => '512', :cpucores => '1', :transfer => '500'"
tests('success') do
tests("#list_servers()").formats(Glesys::Compute::Formats::Servers::LIST) do
pending if Fog.mocking?
2011-09-08 16:41:21 -04:00
Fog::Compute[:glesys].list_servers.body['response']
2011-08-17 11:53:20 -04:00
end
tests("#create(#{@create})").formats(Glesys::Compute::Formats::Servers::CREATE) do
pending if Fog.mocking?
2011-09-08 16:41:21 -04:00
vm = Fog::Compute[:glesys].create(
2011-08-17 11:53:20 -04:00
:hostname => @hostname,
:rootpw => "pw#{Time.now.to_i}",
:datacenter => "Falkenberg",
:platform => "Xen",
:template => "Debian-6 x64",
:disksize => "10",
:memorysize => "512",
:cpucores => "1",
:transfer => "500"
)
2011-08-17 11:53:20 -04:00
@serverid = vm.body['response']['server']['serverid']
vm.body['response']
end
unless Fog.mocking?
2011-09-08 16:41:21 -04:00
Fog::Compute[:glesys].servers.get(@serverid).wait_for { ready? }
2011-08-17 11:53:20 -04:00
end
2011-08-17 11:53:20 -04:00
tests("#server_details(#{@serverid})").formats(Glesys::Compute::Formats::Servers::DETAILS) do
pending if Fog.mocking?
2011-09-08 16:41:21 -04:00
Fog::Compute[:glesys].server_details(@serverid).body['response']
2011-08-17 11:53:20 -04:00
end
tests("#server_status(#{@serverid})").formats(Glesys::Compute::Formats::Servers::STATUS) do
pending if Fog.mocking?
2011-09-08 16:41:21 -04:00
Fog::Compute[:glesys].server_status(@serverid).body['response']
2011-08-17 11:53:20 -04:00
end
tests("#stop(:serverid => #{@serverid})").formats(Glesys::Compute::Formats::Servers::STOP) do
2011-08-17 11:53:20 -04:00
pending if Fog.mocking?
2011-09-08 16:41:21 -04:00
Fog::Compute[:glesys].stop(:serverid => @serverid).body['response']
2011-08-17 11:53:20 -04:00
end
# Wait for stopped
unless Fog.mocking?
pending if Fog.mocking?
2011-09-08 16:41:21 -04:00
s = Fog::Compute[:glesys].servers.get(@serverid)
s.wait_for { s.state == 'stopped' }
2011-08-17 11:53:20 -04:00
end
tests("#start(:serverid => #{@serverid})").formats(Glesys::Compute::Formats::Servers::START) do
2011-08-17 11:53:20 -04:00
pending if Fog.mocking?
2011-09-08 16:41:21 -04:00
Fog::Compute[:glesys].start(:serverid => @serverid).body['response']
2011-08-17 11:53:20 -04:00
end
# Wait for started
unless Fog.mocking?
2011-09-08 16:41:21 -04:00
Fog::Compute[:glesys].servers.get(@serverid).wait_for { ready? }
2011-08-17 11:53:20 -04:00
end
tests("#destroy(:serverid => #{@serverid})").formats(Glesys::Compute::Formats::Servers::DESTROY) do
pending if Fog.mocking?
2011-09-08 16:41:21 -04:00
Fog::Compute[:glesys].destroy(:serverid => @serverid).body['response']
2011-08-17 11:53:20 -04:00
end
end
tests('failure') do
tests("#create(:hostname => 0)").raises(Excon::Errors::HTTPStatusError) do
pending if Fog.mocking?
2011-09-08 16:41:21 -04:00
Fog::Compute[:glesys].create(:hostname => 0)
2011-08-17 11:53:20 -04:00
end
end
end