Merge pull request #3592 from mitchellh/reboot-capability-should-fix-symlinks

guests/windows: reboot capability should fix symlinks
This commit is contained in:
Mitchell Hashimoto 2014-04-30 17:46:46 -07:00
commit cadd7f602c
5 changed files with 15 additions and 35 deletions

View File

@ -12,6 +12,10 @@ module VagrantPlugins
while machine.communicate.execute(script, error_check: false) != 0
sleep 10
end
# This re-establishes our symbolic links if they were
# created between now and a reboot
machine.communicate.execute("net use", error_check: false)
end
end
end

View File

@ -62,14 +62,6 @@ module VagrantPlugins
@machine.guest.capability(:wait_for_reboot)
end
if windows?
# This re-establishes our symbolic links if they were
# created between now and a reboot
@machine.communicate.execute(
"& net use a-non-existant-share",
error_check: false)
end
command = build_command(:client)
@config.attempts.times do |attempt|

View File

@ -138,14 +138,6 @@ module VagrantPlugins
@machine.guest.capability(:wait_for_reboot)
end
if windows?
# This re-establishes our symbolic links if they were
# created between now and a reboot
@machine.communicate.execute(
"& net use a-non-existant-share",
error_check: false)
end
command = build_command(:solo)
@config.attempts.times do |attempt|

View File

@ -101,14 +101,6 @@ module VagrantPlugins
end
def run_puppet_apply
if windows?
# This re-establishes our symbolic links if they were
# created between now and a reboot
@machine.communicate.execute(
"& net use a-non-existant-share",
error_check: false)
end
default_module_path = "/etc/puppet/modules"
if windows?
default_module_path = "/ProgramData/PuppetLabs/puppet/etc/modules"

View File

@ -9,7 +9,7 @@ describe "VagrantPlugins::GuestWindows::Cap::Reboot" do
let(:vm) { double("vm") }
let(:config) { double("config") }
let(:machine) { double("machine") }
let(:communicator) { double(:execute) }
let(:communicator) { double("communicator") }
before do
allow(machine).to receive(:communicate).and_return(communicator)
@ -18,37 +18,37 @@ describe "VagrantPlugins::GuestWindows::Cap::Reboot" do
end
describe "winrm communicator" do
before do
allow(vm).to receive(:communicator).and_return(:winrm)
end
describe ".wait_for_reboot" do
it "runs reboot detect script" do
expect(communicator).to receive(:execute) do |cmd|
expect(cmd).to include("SM_SHUTTINGDOWN")
end.and_return(0)
expect(communicator).to receive(:execute).with(/# Function/, { error_check: false }).and_return(0)
allow(communicator).to receive(:execute)
described_class.wait_for_reboot(machine)
end
it "fixes symlinks to network shares" do
allow(communicator).to receive(:execute).and_return(0)
expect(communicator).to receive(:execute).with('net use', { error_check: false })
described_class.wait_for_reboot(machine)
end
end
end
describe "ssh communicator" do
before do
allow(vm).to receive(:communicator).and_return(:ssh)
end
describe ".wait_for_reboot" do
it "runs reboot detect script" do
it "does not execute Windows reboot detect script" do
expect(communicator).to_not receive(:execute)
described_class.wait_for_reboot(machine)
end
end
end
end