mirror of
https://github.com/vagrant-libvirt/vagrant-libvirt.git
synced 2025-02-25 18:55:27 -06:00
97 lines
3.0 KiB
Ruby
97 lines
3.0 KiB
Ruby
# 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
|