Return exit status of 1 on invalid command

Makes "vagrant destroyjj" and similar return an exit code of 1, so that
"vagrant destroyjj && vagrant up" works as expected.
This commit is contained in:
Michael Stillwell 2013-01-27 19:52:43 +00:00
parent 776a1e446b
commit 7941748db7
2 changed files with 32 additions and 1 deletions

View File

@ -38,7 +38,7 @@ module Vagrant
if !command_class || !@sub_command if !command_class || !@sub_command
help help
return 0 return 1
end end
@logger.debug("Invoking command class: #{command_class} #{@sub_args.inspect}") @logger.debug("Invoking command class: #{command_class} #{@sub_args.inspect}")

View File

@ -0,0 +1,31 @@
describe Vagrant::CLI do
describe "parsing options" do
let(:klass) do
Class.new(described_class)
end
let(:environment) do
ui = double("UI::Silent")
ui.stub(:info => "bar")
env = double("Vagrant::Environment")
env.stub(:ui => ui)
env.stub(:root_path => "foo")
env.stub(:machine_names => [])
env
end
it "returns a non-zero exit status if an invalid command is given" do
result = klass.new(["destroypp"], environment).execute
result.should_not == 0
end
it "returns an exit status of zero if a valid command is given" do
result = klass.new(["destroy"], environment).execute
result.should == 0
end
end
end