2013-01-11 16:06:58 -05:00
|
|
|
Shindo.tests('Fog::Compute::RackspaceV2 | attachment_tests', ['rackspace']) do
|
2013-01-17 05:33:17 -05:00
|
|
|
compute_service = Fog::Compute::RackspaceV2.new
|
|
|
|
block_storage_service = Fog::Rackspace::BlockStorage.new
|
|
|
|
image_id = Fog.credentials[:rackspace_image_id] || compute_service.images.first.id
|
|
|
|
flavor_id = Fog.credentials[:rackspace_flavor_id] || compute_service.flavors.first.id
|
|
|
|
timeout = Fog.mocking? ? 1 : 10
|
2012-09-10 13:23:36 -04:00
|
|
|
|
2013-01-11 16:06:58 -05:00
|
|
|
attachment_format = {
|
2012-09-10 13:23:36 -04:00
|
|
|
'volumeAttachment' => {
|
|
|
|
'id' => String,
|
|
|
|
'serverId' => String,
|
|
|
|
'volumeId' => String,
|
|
|
|
'device' => Fog::Nullable::String
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-01-11 16:06:58 -05:00
|
|
|
list_attachments_format = {
|
|
|
|
'volumeAttachments' => [attachment_format['volumeAttachment']]
|
2012-09-10 13:23:36 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
name = 'fog' + Time.now.to_i.to_s
|
2013-01-11 16:06:58 -05:00
|
|
|
image_id = image_id
|
|
|
|
flavor_id = flavor_id
|
2012-09-10 13:23:36 -04:00
|
|
|
server_id = compute_service.create_server(name, image_id, flavor_id, 1, 1).body['server']['id']
|
2013-01-11 16:06:58 -05:00
|
|
|
volume_id = block_storage_service.create_volume(100).body['volume']['id']
|
2012-09-10 13:23:36 -04:00
|
|
|
device_id = '/dev/xvde'
|
|
|
|
|
|
|
|
|
|
|
|
tests('success') do
|
|
|
|
until compute_service.get_server(server_id).body['server']['status'] == 'ACTIVE'
|
2013-01-11 16:06:58 -05:00
|
|
|
sleep timeout
|
2012-09-10 13:23:36 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
until block_storage_service.get_volume(volume_id).body['volume']['status'] == 'available'
|
2013-01-11 16:06:58 -05:00
|
|
|
sleep timeout
|
2012-09-10 13:23:36 -04:00
|
|
|
end
|
|
|
|
|
2013-01-11 16:06:58 -05:00
|
|
|
tests("#attach_volume(#{server_id}, #{volume_id}, #{device_id})").formats(attachment_format) do
|
2012-09-10 13:23:36 -04:00
|
|
|
compute_service.attach_volume(server_id, volume_id, device_id).body
|
|
|
|
end
|
|
|
|
|
2013-01-11 16:06:58 -05:00
|
|
|
tests("#list_attachments(#{server_id})").formats(list_attachments_format) do
|
2012-09-10 13:23:36 -04:00
|
|
|
compute_service.list_attachments(server_id).body
|
|
|
|
end
|
|
|
|
|
|
|
|
until block_storage_service.get_volume(volume_id).body['volume']['status'] == 'in-use'
|
2013-01-11 16:06:58 -05:00
|
|
|
sleep timeout
|
2012-09-10 13:23:36 -04:00
|
|
|
end
|
|
|
|
|
2013-01-11 16:06:58 -05:00
|
|
|
tests("#get_attachment(#{server_id}, #{volume_id})").formats(attachment_format) do
|
2012-09-14 11:25:32 -04:00
|
|
|
compute_service.get_attachment(server_id, volume_id).body
|
|
|
|
end
|
|
|
|
|
2012-09-10 13:23:36 -04:00
|
|
|
tests("#delete_attachment(#{server_id}, #{volume_id})").succeeds do
|
|
|
|
compute_service.delete_attachment(server_id, volume_id)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
tests('failure') do
|
|
|
|
tests("#attach_volume('', #{volume_id}, #{device_id})").raises(Fog::Compute::RackspaceV2::NotFound) do
|
|
|
|
compute_service.attach_volume('', volume_id, device_id)
|
|
|
|
end
|
|
|
|
|
|
|
|
tests("#delete_attachment('', #{volume_id})").raises(Fog::Compute::RackspaceV2::NotFound) do
|
|
|
|
compute_service.delete_attachment('', volume_id)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|