2014-04-22 18:03:37 +00:00
|
|
|
require File.expand_path("../../../../base", __FILE__)
|
|
|
|
|
|
|
|
require Vagrant.source_root.join("plugins/communicators/winrm/shell")
|
|
|
|
|
|
|
|
describe VagrantPlugins::CommunicatorWinRM::WinRMShell do
|
|
|
|
include_context "unit"
|
|
|
|
|
|
|
|
let(:session) { double("winrm_session") }
|
|
|
|
|
|
|
|
subject do
|
2014-04-23 23:12:27 +00:00
|
|
|
described_class.new('localhost', 'username', 'password').tap do |comm|
|
|
|
|
allow(comm).to receive(:new_session).and_return(session)
|
|
|
|
end
|
2014-04-22 18:03:37 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
describe ".powershell" do
|
|
|
|
it "should call winrm powershell" do
|
2014-04-24 01:05:53 +00:00
|
|
|
expect(session).to receive(:powershell).with(/^dir.+/).and_return({ exitcode: 0 })
|
2014-04-22 18:03:37 +00:00
|
|
|
expect(subject.powershell("dir")[:exitcode]).to eq(0)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should raise auth error when exception message contains 401" do
|
2014-04-24 01:05:53 +00:00
|
|
|
expect(session).to receive(:powershell).with(/^dir.+/).and_raise(
|
2014-04-22 18:03:37 +00:00
|
|
|
StandardError.new("Oh no! a 401 SOAP error!"))
|
|
|
|
expect { subject.powershell("dir") }.to raise_error(
|
|
|
|
VagrantPlugins::CommunicatorWinRM::Errors::AuthError)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should raise an execution error when an exception occurs" do
|
2014-04-24 01:05:53 +00:00
|
|
|
expect(session).to receive(:powershell).with(/^dir.+/).and_raise(
|
2014-04-22 18:03:37 +00:00
|
|
|
StandardError.new("Oh no! a 500 SOAP error!"))
|
|
|
|
expect { subject.powershell("dir") }.to raise_error(
|
|
|
|
VagrantPlugins::CommunicatorWinRM::Errors::ExecutionError)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe ".cmd" do
|
|
|
|
it "should call winrm cmd" do
|
2014-04-23 23:16:08 +00:00
|
|
|
expect(session).to receive(:cmd).with("dir").and_return({ exitcode: 0 })
|
2014-04-22 18:03:37 +00:00
|
|
|
expect(subject.cmd("dir")[:exitcode]).to eq(0)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe ".endpoint" do
|
|
|
|
it "should create winrm endpoint address" do
|
|
|
|
expect(subject.send(:endpoint)).to eq("http://localhost:5985/wsman")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe ".endpoint_options" do
|
|
|
|
it "should create endpoint options" do
|
|
|
|
expect(subject.send(:endpoint_options)).to eq(
|
2014-04-23 23:16:08 +00:00
|
|
|
{ user: "username", pass: "password", host: "localhost", port: 5985,
|
2014-07-22 22:28:50 +00:00
|
|
|
operation_timeout: 60, basic_auth_only: true, no_ssl_peer_verification: false })
|
2014-04-22 18:03:37 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|