Ensure shutdown timeout adjusted if graceful halt fails

This commit is contained in:
Darragh Bailey
2021-08-02 15:22:26 +01:00
parent dd6b17ff9a
commit 2ae1421421
4 changed files with 164 additions and 14 deletions

View File

@@ -66,7 +66,7 @@ describe VagrantPlugins::ProviderLibvirt::Action::ShutdownDomain do
context "when final state is not shutoff" do
before do
expect(domain).to receive(:state).and_return('running').exactly(4).times
expect(domain).to receive(:state).and_return('running').exactly(6).times
end
it "should provide a false result" do
@@ -77,8 +77,8 @@ describe VagrantPlugins::ProviderLibvirt::Action::ShutdownDomain do
context "when final state is shutoff" do
before do
expect(domain).to receive(:state).and_return('running').exactly(3).times
expect(domain).to receive(:state).and_return('shutoff')
expect(domain).to receive(:state).and_return('running').exactly(4).times
expect(domain).to receive(:state).and_return('shutoff').exactly(2).times
end
it "should provide a true result" do
@@ -86,6 +86,38 @@ describe VagrantPlugins::ProviderLibvirt::Action::ShutdownDomain do
expect(env[:result]).to be_truthy
end
end
context "when timeout exceeded" do
before do
expect(machine).to receive_message_chain('config.vm.graceful_halt_timeout').and_return(1)
expect(app).to receive(:call) { sleep 1.5 }
expect(domain).to receive(:state).and_return('running').exactly(2).times
expect(domain).to_not receive(:wait_for)
expect(domain).to_not receive(:shutdown)
end
it "should provide a false result" do
subject.call(env)
expect(env[:result]).to be_falsey
end
end
context "when timeout not exceeded" do
before do
expect(machine).to receive_message_chain('config.vm.graceful_halt_timeout').and_return(2)
expect(app).to receive(:call) { sleep 1 }
expect(domain).to receive(:state).and_return('running').exactly(6).times
expect(domain).to receive(:wait_for) do |time|
expect(time).to be < 1
expect(time).to be > 0
end
end
it "should wait for the reduced time" do
subject.call(env)
expect(env[:result]).to be_falsey
end
end
end
end
end

96
spec/unit/action_spec.rb Normal file
View File

@@ -0,0 +1,96 @@
# frozen_string_literal: true
require 'spec_helper'
require 'support/sharedcontext'
require 'vagrant/action/runner'
require 'vagrant-libvirt/action'
describe VagrantPlugins::ProviderLibvirt::Action do
subject { described_class }
include_context 'libvirt'
include_context 'unit'
let(:libvirt_domain) { double('libvirt_domain') }
let(:runner) { Vagrant::Action::Runner.new(env) }
let(:state) { double('state') }
before do
allow_any_instance_of(VagrantPlugins::ProviderLibvirt::Driver)
.to receive(:connection).and_return(connection)
allow(machine).to receive(:id).and_return('test-machine-id')
allow(machine).to receive(:state).and_return(state)
allow(logger).to receive(:info)
allow(logger).to receive(:debug)
allow(logger).to receive(:error)
end
def allow_action_env_result(action, *responses)
results = responses.dup
allow_any_instance_of(action).to receive(:call) do |cls, env|
app = cls.instance_variable_get(:@app)
env[:result] = results[0]
if results.length > 1
results.shift
end
app.call(env)
end
end
describe '#action_halt' do
context 'not created' do
before do
expect(state).to receive(:id).and_return(:not_created)
end
it 'should execute without error' do
expect(ui).to receive(:info).with('Domain is not created. Please run `vagrant up` first.')
expect { runner.run(subject.action_halt) }.not_to raise_error
end
end
context 'running' do
before do
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsCreated, true)
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsSuspended, false)
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsRunning, true)
end
context 'when shutdown domain works' do
before do
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::ShutdownDomain, true)
allow_action_env_result(Vagrant::Action::Builtin::GracefulHalt, true)
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsRunning, true, false)
end
it 'should skip calling HaltDomain' do
expect(ui).to_not receive(:info).with('Domain is not created. Please run `vagrant up` first.')
expect_any_instance_of(VagrantPlugins::ProviderLibvirt::Action::HaltDomain).to_not receive(:call)
expect { runner.run(subject.action_halt) }.not_to raise_error
end
end
context 'when shutdown domain fails' do
before do
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::ShutdownDomain, false)
allow_action_env_result(Vagrant::Action::Builtin::GracefulHalt, false)
end
it 'should call halt' do
expect_any_instance_of(VagrantPlugins::ProviderLibvirt::Action::HaltDomain).to receive(:call)
expect { runner.run(subject.action_halt) }.not_to raise_error
end
end
end
end
end