Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
23 changes: 17 additions & 6 deletions libcloud/compute/drivers/cloudstack.py
Original file line number Diff line number Diff line change
Expand Up @@ -2111,17 +2111,28 @@ def ex_list_projects(self):

return projects

def create_volume(self, size, name, location=None, snapshot=None):
def create_volume(self, size, name, location=None, snapshot=None,
ex_volume_type=None):
"""
Creates a data volume
Defaults to the first location
"""
for diskOffering in self.ex_list_disk_offerings():
if diskOffering.size == size or diskOffering.customizable:
break
if ex_volume_type is None:
for diskOffering in self.ex_list_disk_offerings():
if diskOffering.size == size or diskOffering.customizable:
break
else:
raise LibcloudError(
'Disk offering with size=%s not found' % size)
else:
raise LibcloudError(
'Disk offering with size=%s not found' % size)
for diskOffering in self.ex_list_disk_offerings():
if diskOffering.name == ex_volume_type:
if not diskOffering.customizable:
size = diskOffering.size
break
else:
raise LibcloudError(
'Volume type with name=%s not found' % ex_volume_type)

if location is None:
location = self.list_locations()[0]
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{ "createvolumeresponse" : {"id":"60338035-92fb-4d27-98d4-b60ad4b38b87","jobid":"createvolumejob"} }
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{ "listdiskofferingsresponse" : { "count":1 ,"diskoffering" : [ {"id":"6345e3b7-227e-4209-8f8c-1f94219696e6","name":"Disk offer 1","displaytext":"Disk offer 1 display name","disksize":10,"created":"2012-04-24T16:35:55+0200","iscustomized":false} ] } }
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{ "listzonesresponse" : { "zone" : [ {"id":1,"name":"Sydney","networktype":"Advanced","securitygroupsenabled":false} ] } }
24 changes: 24 additions & 0 deletions libcloud/test/compute/test_cloudstack.py
Original file line number Diff line number Diff line change
Expand Up @@ -544,6 +544,30 @@ def test_create_volume_with_custom_disk_size_offering(self):

self.assertEqual(volumeName, volume.name)

def test_create_volume_no_matching_volume_type(self):
"""If the ex_disk_type does not exit, then an exception should be
thrown."""

location = self.driver.list_locations()[0]

self.assertRaises(
LibcloudError,
self.driver.create_volume,
'vol-0', location, 11, ex_volume_type='FooVolumeType')

def test_create_volume_with_defined_volume_type(self):
CloudStackMockHttp.fixture_tag = 'withvolumetype'

volumeName = 'vol-0'
volLocation = self.driver.list_locations()[0]
diskOffering = self.driver.ex_list_disk_offerings()[0]
volumeType = diskOffering.name

volume = self.driver.create_volume(10, volumeName, location=volLocation,
ex_volume_type=volumeType)

self.assertEqual(volumeName, volume.name)

def test_attach_volume(self):
node = self.driver.list_nodes()[0]
volumeName = 'vol-0'
Expand Down