`vagrant halt` acceptance tests

This commit is contained in:
Mitchell Hashimoto 2011-11-22 19:34:25 -08:00
parent 3efb69f8e5
commit 1ed1650fb6
2 changed files with 64 additions and 0 deletions

View File

@ -0,0 +1,54 @@
require File.expand_path("../base", __FILE__)
require "support/shared/command_examples"
describe "vagrant halt" do
include_context "acceptance"
it_behaves_like "a command that requires a Vagrantfile", ["vagrant", "halt"]
it "succeeds and ignores if the VM is not created" do
require_box("default")
assert_execute("vagrant", "box", "add", "base", box_path("default"))
assert_execute("vagrant", "init")
result = assert_execute("vagrant", "halt")
result.stdout.should match_output(:vm_not_created_warning)
end
it "is able to halt a running virtual machine" do
require_box("default")
assert_execute("vagrant", "box", "add", "base", box_path("default"))
assert_execute("vagrant", "init")
assert_execute("vagrant", "up")
# Halt the VM and assert that it worked properly (seemingly)
result = assert_execute("vagrant", "halt")
result.stdout.should match_output(:vm_halt_graceful)
# Assert that the VM no longer is created
result = assert_execute("vagrant", "status")
result.stdout.should match_output(:status, "default", "powered off")
end
it "is able to force halt a running virtual machine" do
require_box("default")
assert_execute("vagrant", "box", "add", "base", box_path("default"))
assert_execute("vagrant", "init")
assert_execute("vagrant", "up")
# Halt the VM and assert that it worked properly (seemingly)
result = assert_execute("vagrant", "halt", "--force")
result.stdout.should match_output(:vm_halt_force)
# Assert that the VM no longer is created
result = assert_execute("vagrant", "status")
result.stdout.should match_output(:status, "default", "powered off")
end
# TODO:
# halt behavior on suspend machine
# halt behavior if machine is already powered off
# VM can come back up after a halt
end

View File

@ -68,5 +68,15 @@ module Acceptance
def up_fetching_box(name, vm=DEFAULT_VM) def up_fetching_box(name, vm=DEFAULT_VM)
@text =~ /^\[#{vm}\] Box #{name} was not found. Fetching box from specified URL...$/ @text =~ /^\[#{vm}\] Box #{name} was not found. Fetching box from specified URL...$/
end end
# Check that the output shows that the VM was shut down gracefully
def vm_halt_graceful
@text =~ /Attempting graceful shutdown of/
end
# Output shows a forceful VM shutdown.
def vm_halt_force
@text =~ /Forcing shutdown of VM...$/
end
end end
end end