Commands specify their option parsings in the `options_spec` method. Parent takes care of the rest.

This commit is contained in:
Mitchell Hashimoto 2010-04-13 15:34:26 -07:00
parent 26c12a9a17
commit b4d1ee6e83
3 changed files with 58 additions and 40 deletions

View File

@ -84,17 +84,31 @@ module Vagrant
self.class.puts_help self.class.puts_help
end end
# Parse options out of the command-line. This method uses `optparse` # This method is called by the base class to get the `optparse` configuration
# to parse command line options. A block is required and will yield # for the command.
# the `OptionParser` object along with a hash which can be used to def options_spec(opts)
# store options and which will be returned as a result of the function. opts.banner = "Usage: vagrant SUBCOMMAND"
def parse_options(args)
options = {}
@parser = OptionParser.new do |opts|
yield opts, options
end end
@parser.parse!(args) # Returns the `OptionParser` instance to be used with this subcommand,
# based on the specs defined in {#options_spec}.
def option_parser(reload=false)
@option_parser = nil if reload
@option_parser ||= OptionParser.new do |opts|
options_spec(opts)
end
end
# The options for the given command. This will just be an empty hash
# until {#parse_options} is called.
def options
@options ||= {}
end
# Parse options out of the command-line. This method uses `optparse`
# to parse command line options.
def parse_options(args)
option_parser.parse!(args)
options options
rescue OptionParser::InvalidOption rescue OptionParser::InvalidOption
show_help show_help
@ -114,7 +128,7 @@ module Vagrant
puts "Description: #{description}" puts "Description: #{description}"
end end
puts @parser.help puts option_parser.help
exit exit
end end
end end

View File

@ -5,11 +5,11 @@ module Vagrant
description "Initializes current folder for Vagrant usage" description "Initializes current folder for Vagrant usage"
def execute(args) def execute(args)
parse_options(args) do |opts, options| create_vagrantfile(args[0])
opts.banner = "Usage: vagrant init [name]"
end end
create_vagrantfile(args[0]) def options_spec(opts)
opts.banner = "Usage: vagrant init [name]"
end end
# Actually writes the initial Vagrantfile to the current working directory. # Actually writes the initial Vagrantfile to the current working directory.

View File

@ -71,36 +71,40 @@ class CommandsBaseTest < Test::Unit::TestCase
end end
end end
context "getting the option parser" do
should "create it with the options spec if it hasn't been created yet" do
opts = mock("opts")
result = mock("result")
OptionParser.expects(:new).yields(opts).returns(result)
@instance.expects(:options_spec).with(opts)
assert_equal result, @instance.option_parser(true)
end
should "not create it once its been created" do
result = mock("result")
OptionParser.expects(:new).once.returns(result)
assert_equal result, @instance.option_parser(true)
assert_equal result, @instance.option_parser
assert_equal result, @instance.option_parser
end
end
context "parsing options" do context "parsing options" do
setup do setup do
@args = [] @args = []
@options = mock("options")
@option_parser = mock("option_parser")
@instance.stubs(:option_parser).returns(@option_parser)
@instance.stubs(:options).returns(@options)
end end
should "return the options hash" do should "parse the options with the args" do
value = mock("foo") @option_parser.expects(:parse!).with(@args).once
result = @instance.parse_options(@args) do |opts, options| assert_equal @options, @instance.parse_options(@args)
options[:foo] = value
end
assert_equal value, result[:foo]
end
should "parse with the given args" do
parser = mock("parser")
OptionParser.stubs(:new).returns(parser)
parser.expects(:parse!).with(@args)
@instance.parse_options(@args) do; end
end
should "show help if an invalid options error is raised" do
parser = mock("parser")
OptionParser.stubs(:new).returns(parser)
parser.expects(:parse!).raises(OptionParser::InvalidOption)
@instance.expects(:show_help).once
@instance.parse_options(@args) do; end
end end
end end
end end