lib/fog/rackspace/requests/compute_v2/delete_attachment.rb in fog-maestrodev-1.8.0.20130114204828 vs lib/fog/rackspace/requests/compute_v2/delete_attachment.rb in fog-maestrodev-1.14.0.20130806165225

- old
+ new

@@ -1,14 +1,39 @@ module Fog module Compute class RackspaceV2 class Real + + # Deletes a specified volume attachment from a specified server instance. + # @param [String] server_id id of server containing volume to delete + # @param [String] volume_id id of volume on server to delete + # @return [Excon::Response] response + # @raise [Fog::Compute::RackspaceV2::NotFound] - HTTP 404 + # @raise [Fog::Compute::RackspaceV2::BadRequest] - HTTP 400 + # @raise [Fog::Compute::RackspaceV2::InternalServerError] - HTTP 500 + # @raise [Fog::Compute::RackspaceV2::ServiceError] + # @see http://docs.rackspace.com/servers/api/v2/cs-devguide/content/Delete_Volume_Attachment.html def delete_attachment(server_id, volume_id) request( :expects => [202], :method => 'DELETE', :path => "servers/#{server_id}/os-volume_attachments/#{volume_id}" ) + end + end + + class Mock + def delete_attachment(server_id, volume_id) + volume = self.data[:volumes][volume_id] + server = self.data[:servers][server_id] + if volume.nil? || server.nil? + raise Fog::Compute::RackspaceV2::NotFound + else + self.data[:volume_attachments].delete_if { |v| v["serverId"] == server_id && v["volumeId"] == volume_id } + volume["attachments"].delete_if { |v| v["serverId"] == server_id && v["volumeId"] == volume_id } + + response(:status => 204) + end end end end end end