Skip to content

Commit

Permalink
Rescue migration error and update status
Browse files Browse the repository at this point in the history
  • Loading branch information
bzwei committed Dec 21, 2017
1 parent 95be471 commit 377f422
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 4 deletions.
14 changes: 10 additions & 4 deletions app/models/vm_migrate_task.rb
Original file line number Diff line number Diff line change
Expand Up @@ -62,10 +62,16 @@ def do_request
end

_log.warn("Calling VM #{vc_method} for #{vm.id}:#{vm.name}")
if vc_method == :migrate
vm.migrate(host, respool)
else
vm.relocate(host, respool, datastore, nil, disk_transform)

begin
if vc_method == :migrate
vm.migrate(host, respool)
else
vm.relocate(host, respool, datastore, nil, disk_transform)
end
rescue => err
update_and_notify_parent(:state => 'finished', :status => 'error', :message => "Failed. Reason[#{err.message}]")
return
end

if AUTOMATE_DRIVES
Expand Down
18 changes: 18 additions & 0 deletions spec/models/vm_migrate_task_spec.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
describe VmMigrateTask do
describe '.do_request' do
let(:vm) { Vm.new }
before { subject.vm = vm }

it 'migrates the vm and updates the status' do
expect(vm).to receive(:migrate)
expect(subject).to receive(:update_and_notify_parent).with(hash_including(:state => 'migrated'))
subject.do_request
end

it 'catches migrate error and update the status' do
expect(vm).to receive(:migrate).and_raise("Bad things happened")
expect(subject).to receive(:update_and_notify_parent).with(hash_including(:state => 'finished', :status => 'error', :message => 'Failed. Reason[Bad things happened]'))
subject.do_request
end
end
end

0 comments on commit 377f422

Please sign in to comment.