Merge pull request #7701 from chrisroberts/guests/bsds
guests/bsds: shutdown fixes and dragonfly detection
This commit is contained in:
commit
0f79d80c8d
|
@ -2,7 +2,7 @@ module VagrantPlugins
|
||||||
module GuestBSD
|
module GuestBSD
|
||||||
class Guest < Vagrant.plugin("2", :guest)
|
class Guest < Vagrant.plugin("2", :guest)
|
||||||
def detect?(machine)
|
def detect?(machine)
|
||||||
machine.communicate.test("uname -s | grep -i 'Darwin|BSD'")
|
machine.communicate.test("uname -s | grep -i 'BSD'")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
module VagrantPlugins
|
||||||
|
module GuestDragonFlyBSD
|
||||||
|
class Guest < Vagrant.plugin("2", :guest)
|
||||||
|
def detect?(machine)
|
||||||
|
machine.communicate.test("uname -s | grep -i 'DragonFly'")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,15 @@
|
||||||
|
require "vagrant"
|
||||||
|
|
||||||
|
module VagrantPlugins
|
||||||
|
module GuestDragonFlyBSD
|
||||||
|
class Plugin < Vagrant.plugin("2")
|
||||||
|
name "DragonFly BSD guest"
|
||||||
|
description "DragonFly BSD guest support."
|
||||||
|
|
||||||
|
guest(:dragonflybsd, :bsd) do
|
||||||
|
require_relative "guest"
|
||||||
|
Guest
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,19 @@
|
||||||
|
module VagrantPlugins
|
||||||
|
module GuestOpenBSD
|
||||||
|
module Cap
|
||||||
|
class Halt
|
||||||
|
def self.halt(machine)
|
||||||
|
begin
|
||||||
|
# Versions of OpenBSD prior to 5.7 require the -h option to be
|
||||||
|
# provided with the -p option. Later options allow the -h to
|
||||||
|
# be optional.
|
||||||
|
machine.communicate.sudo("/sbin/shutdown -p -h now", shell: "sh")
|
||||||
|
rescue IOError, Vagrant::Errors::SSHDisconnected
|
||||||
|
# Do nothing, because it probably means the machine shut down
|
||||||
|
# and SSH connection was lost.
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -21,6 +21,11 @@ module VagrantPlugins
|
||||||
Cap::ConfigureNetworks
|
Cap::ConfigureNetworks
|
||||||
end
|
end
|
||||||
|
|
||||||
|
guest_capability(:openbsd, :halt) do
|
||||||
|
require_relative "cap/halt"
|
||||||
|
Cap::Halt
|
||||||
|
end
|
||||||
|
|
||||||
guest_capability(:openbsd, :rsync_install) do
|
guest_capability(:openbsd, :rsync_install) do
|
||||||
require_relative "cap/rsync"
|
require_relative "cap/rsync"
|
||||||
Cap::RSync
|
Cap::RSync
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
require_relative "../../../../base"
|
||||||
|
|
||||||
|
describe "VagrantPlugins::GuestOpenBSD::Cap::Halt" do
|
||||||
|
let(:caps) do
|
||||||
|
VagrantPlugins::GuestOpenBSD::Plugin
|
||||||
|
.components
|
||||||
|
.guest_capabilities[:openbsd]
|
||||||
|
end
|
||||||
|
|
||||||
|
let(:machine) { double("machine") }
|
||||||
|
let(:comm) { VagrantTests::DummyCommunicator::Communicator.new(machine) }
|
||||||
|
|
||||||
|
before do
|
||||||
|
allow(machine).to receive(:communicate).and_return(comm)
|
||||||
|
end
|
||||||
|
|
||||||
|
after do
|
||||||
|
comm.verify_expectations!
|
||||||
|
end
|
||||||
|
|
||||||
|
describe ".halt" do
|
||||||
|
let(:cap) { caps.get(:halt) }
|
||||||
|
|
||||||
|
it "runs the shutdown command" do
|
||||||
|
comm.expect_command("/sbin/shutdown -p -h now")
|
||||||
|
cap.halt(machine)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "ignores an IOError" do
|
||||||
|
comm.stub_command("/sbin/shutdown -p -h now", raise: IOError)
|
||||||
|
expect {
|
||||||
|
cap.halt(machine)
|
||||||
|
}.to_not raise_error
|
||||||
|
end
|
||||||
|
|
||||||
|
it "ignores an Vagrant::Errors::SSHDisconnected" do
|
||||||
|
comm.stub_command("/sbin/shutdown -p -h now", raise: Vagrant::Errors::SSHDisconnected)
|
||||||
|
expect {
|
||||||
|
cap.halt(machine)
|
||||||
|
}.to_not raise_error
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue