lib/fog/google/requests/compute/insert_disk.rb in fog-1.19.0 vs lib/fog/google/requests/compute/insert_disk.rb in fog-1.20.0
- old
+ new
@@ -4,47 +4,59 @@
class Mock
def insert_disk(disk_name, zone_name, image_name=nil, options={})
# check that image and zone exist
- image_project = nil
- unless image_name.nil?
- ([ @project ] + Fog::Compute::Google::Images::GLOBAL_PROJECTS).each do |project|
- image_project = project
- break if data(project)[:images][options['image']]
- end
- get_image(image_name, image_project) # ok if image exists, will fail otherwise
+ image = nil
+ if image_name
+ image = images.get(image_name)
+ raise ArgumentError.new("Invalid image specified: #{image_name}") unless image
end
get_zone(zone_name)
id = Fog::Mock.random_numbers(19).to_s
- self.data[:disks][disk_name] = {
+ object = {
"kind" => "compute#disk",
"id" => id,
"creationTimestamp" => Time.now.iso8601,
"zone" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}",
"status" => "READY",
"name" => disk_name,
"sizeGb" => options['sizeGb'] || "10",
"selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/disks/#{disk_name}"
}
+ if image
+ object.merge({
+ "sourceImage" => image.self_link,
+ "sourceImageId" => image.id
+ })
+ end
+ self.data[:disks][disk_name] = object
+ if image
+ object.merge!({
+ "sourceImage" => image.self_link,
+ "sourceImageId" => image.id
+ })
+ end
+ self.data[:disks][disk_name] = object
+
operation = self.random_operation
self.data[:operations][operation] = {
"kind" => "compute#operation",
"id" => Fog::Mock.random_numbers(19).to_s,
"name" => operation,
- "zone" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}",
+ "zone" => object["zone"],
"operationType" => "insert",
- "targetLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/disks/#{disk_name}",
+ "targetLink" => object["selfLink"],
"targetId" => id,
"status" => Fog::Compute::Google::Operation::PENDING_STATE,
"user" => "123456789012-qwertyuiopasdfghjkl1234567890qwe@developer.gserviceaccount.com",
"progress" => 0,
"insertTime" => Time.now.iso8601,
"startTime" => Time.now.iso8601,
- "selfLink" => "https://www.googleapis.com/compute/#{api_version}/projects/#{@project}/zones/#{zone_name}/operations/#{operation}"
+ "selfLink" => "#{object["zone"]}/operations/#{operation}"
}
build_response(:body => self.data[:operations][operation])
end
@@ -58,29 +70,35 @@
'project' => @project,
'zone' => zone_name
}
if image_name
+ # New disk from image
image = images.get(image_name)
- raise ArgumentError.new('Invalid image specified') unless image
+ raise ArgumentError.new("Invalid image specified: #{image_name}") unless image
@image_url = @api_url + image.resource_url
parameters['sourceImage'] = @image_url
end
body_object = { 'name' => disk_name }
- # These must be present if image_name is not specified
+ # According to Google docs, if image name is not present, only one of
+ # sizeGb or sourceSnapshot need to be present, one will create blank
+ # disk of desired size, other will create disk from snapshot
if image_name.nil?
- unless opts.has_key?('sourceSnapshot') and opts.has_key?('sizeGb')
- raise ArgumentError.new('Must specify image OR snapshot and '\
+ if opts.has_key?('sourceSnapshot')
+ # New disk from snapshot
+ snap = snapshots.get(opts.delete('sourceSnapshot'))
+ raise ArgumentError.new('Invalid source snapshot') unless snap
+ body_object['sourceSnapshot'] = @api_url + snap.resource_url
+ elsif opts.has_key?('sizeGb')
+ # New blank disk
+ body_object['sizeGb'] = opts.delete('sizeGb')
+ else
+ raise ArgumentError.new('Must specify image OR snapshot OR '\
'disk size when creating a disk.')
end
- body_object['sizeGb'] = opts.delete('sizeGb')
-
- snap = snapshots.get(opts.delete('sourceSnapshot'))
- raise ArgumentError.new('Invalid source snapshot') unless snap
- body_object['sourceSnapshot'] = @api_url + snap.resource_url
end
# Merge in any remaining options (only 'description' should remain)
body_object.merge!(opts)