2021-08-02 15:22:26 +01:00
|
|
|
# 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
|
2021-10-12 09:45:49 +01:00
|
|
|
|
|
|
|
|
describe '#action_ssh' do
|
|
|
|
|
context 'when not created' do
|
|
|
|
|
before do
|
|
|
|
|
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsCreated, false)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'should cause an error' do
|
|
|
|
|
expect{ machine.action(:ssh, ssh_opts: {})}.to raise_error(Vagrant::Errors::VMNotCreatedError)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when created' do
|
|
|
|
|
before do
|
|
|
|
|
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsCreated, true)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when not running' do
|
|
|
|
|
before do
|
|
|
|
|
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsRunning, false)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'should cause an error' do
|
|
|
|
|
expect{ machine.action(:ssh, ssh_opts: {})}.to raise_error(Vagrant::Errors::VMNotRunningError)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when running' do
|
|
|
|
|
before do
|
|
|
|
|
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsRunning, true)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'should call SSHExec' do
|
|
|
|
|
expect_any_instance_of(Vagrant::Action::Builtin::SSHExec).to receive(:call).and_return(0)
|
|
|
|
|
expect(machine.action(:ssh, ssh_opts: {})).to match(hash_including({:action_name => :machine_action_ssh}))
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
describe '#action_ssh_run' do
|
|
|
|
|
context 'when not created' do
|
|
|
|
|
before do
|
|
|
|
|
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsCreated, false)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'should cause an error' do
|
|
|
|
|
expect{ machine.action(:ssh_run, ssh_opts: {})}.to raise_error(Vagrant::Errors::VMNotCreatedError)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when created' do
|
|
|
|
|
before do
|
|
|
|
|
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsCreated, true)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when not running' do
|
|
|
|
|
before do
|
|
|
|
|
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsRunning, false)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'should cause an error' do
|
|
|
|
|
expect{ machine.action(:ssh_run, ssh_opts: {})}.to raise_error(Vagrant::Errors::VMNotRunningError)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when running' do
|
|
|
|
|
before do
|
|
|
|
|
allow_action_env_result(VagrantPlugins::ProviderLibvirt::Action::IsRunning, true)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it 'should call SSHRun' do
|
|
|
|
|
expect_any_instance_of(Vagrant::Action::Builtin::SSHRun).to receive(:call).and_return(0)
|
|
|
|
|
expect(machine.action(:ssh_run, ssh_opts: {})).to match(hash_including({:action_name => :machine_action_ssh_run}))
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
2021-08-02 15:22:26 +01:00
|
|
|
end
|