Sha256: de102fc532e3080561775631b4f2bb048fe8312fcb9a8e1fd3db41913c155f36

Contents?: true

Size: 1.93 KB

Versions: 24

Compression:

Stored size: 1.93 KB

Contents

Shindo.tests("Fog::Compute[:opennebula] | vm_create and destroy request", 'opennebula') do

  compute = Fog::Compute[:opennebula]

  name_base = Time.now.to_i
  f = compute.flavors.get_by_name("fogtest")
  tests("Get 'fogtest' flavor/template") do
    test("Got template with name 'fogtest'") {f.kind_of? Array}
    raise ArgumentError, "Could not get a template with the name 'fogtest'! This is required for live tests!" unless f
  end

  f = f.first
  newvm = compute.servers.new
  newvm.flavor = f
  newvm.name = 'fogtest-'+name_base.to_s
  vm = newvm.save

  tests("Start VM") do
    test("response should be a kind of Hash") { vm.kind_of?  Fog::Compute::OpenNebula::Server}
    test("id should be a one-id (Fixnum)") { vm.id.is_a?  Fixnum}
    vm.wait_for { (vm.state == 'RUNNING') } 
    test("VM should be in RUNNING state") { vm.state == 'RUNNING' }
    sleep(30) # waiting for 30 seconds to let VM finish booting
  end

  tests("Create snapshot of the disk and shutdown VM") do
    img_id = compute.vm_disk_snapshot(vm.id, 0, 'fogtest-'+name_base.to_s)
    test("Image ID of created snapshot should be a kind of Fixnum") { img_id.is_a? Fixnum }
    (1..5).each do # wait maximum 5 seconds
      sleep(1) # The delay is needed for some reason between issueing disk-snapshot and shutdown
      images = compute.image_pool( { :mine => true, :id => img_id } )
      test("Got Image with ID=#{img_id}") { images.kind_of? Array }
      if images[0].state == 4 # LOCKED, it is normal we must shutdown VM for image to go into READY state
        break
      end
    end
    compute.servers.shutdown(vm.id)
    image_state = 4
    (1..25).each do # Waiting for up to 50 seconds for Image to become READY
      sleep(2)
      images = compute.image_pool( { :mine => true, :id => img_id } )
      image_state = images[0].state
      if image_state == 1
        break
      end
    end
    test("New image with ID=#{img_id} should be in state READY.") { image_state == 1 }
  end
end

Version data entries

24 entries across 22 versions & 4 rubygems

Version Path
fog-1.33.0 tests/opennebula/requests/compute/vm_disk_snapshot_test.rb
fog-1.32.0 tests/opennebula/requests/compute/vm_disk_snapshot_test.rb
fog-1.31.0 tests/opennebula/requests/compute/vm_disk_snapshot_test.rb
fog-1.30.0 tests/opennebula/requests/compute/vm_disk_snapshot_test.rb