diff options
author | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-08-15 19:08:43 +0000 |
---|---|---|
committer | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-08-15 19:08:43 +0000 |
commit | d464704f111d211c1f1ff9ef23ef1d755054be00 (patch) | |
tree | b58b17b645dc463322e5fca57fe282360db659c9 /ruby_1_8_5/test/optparse/test_noarg.rb | |
parent | e4f06b3f2dec4b5d6334c5e9907e1cecbf649fc4 (diff) |
add tag v1_8_5_54
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/tags/v1_8_5_54@12952 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ruby_1_8_5/test/optparse/test_noarg.rb')
-rw-r--r-- | ruby_1_8_5/test/optparse/test_noarg.rb | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/ruby_1_8_5/test/optparse/test_noarg.rb b/ruby_1_8_5/test/optparse/test_noarg.rb new file mode 100644 index 0000000000..28c469093d --- /dev/null +++ b/ruby_1_8_5/test/optparse/test_noarg.rb @@ -0,0 +1,57 @@ +require 'test_optparse' + +module TestOptionParser::NoArg + class Def1 < TestOptionParser + include NoArg + def setup + super + @opt.def_option("-x") {|x| @flag = x} + @opt.def_option("--option") {|x| @flag = x} + end + end + class Def2 < TestOptionParser + include NoArg + def setup + super + @opt.def_option("-x", "--option") {|x| @flag = x} + end + end + + def test_short + assert_raises(OptionParser::InvalidOption) {@opt.parse!(%w"-xq")} + assert_equal(%w"", no_error {@opt.parse!(%w"-x")}) + assert_equal(true, @flag) + @flag = nil + assert_equal(%w"foo", no_error {@opt.parse!(%w"-x foo")}) + assert_equal(true, @flag) + end + + def test_abbrev + assert_raises(OptionParser::InvalidOption) {@opt.parse!(%w"-oq")} + assert_equal(%w"", no_error {@opt.parse!(%w"-o")}) + assert_equal(true, @flag) + @flag = nil + assert_raises(OptionParser::InvalidOption) {@opt.parse!(%w"-O")} + assert_nil(@flag) + @flag = nil + assert_equal(%w"foo", no_error {@opt.parse!(%w"-o foo")}) + assert_equal(true, @flag) + end + + def test_long + assert_raises(OptionParser::NeedlessArgument) {@opt.parse!(%w"--option=x")} + assert_equal(%w"", no_error {@opt.parse!(%w"--opt")}) + assert_equal(true, @flag) + @flag = nil + assert_equal(%w"foo", no_error {@opt.parse!(%w"--opt foo")}) + assert_equal(true, @flag) + end + + def test_ambiguous + @opt.def_option("--open") {|x|} + assert_raises(OptionParser::AmbiguousOption) {@opt.parse!(%w"--op")} + assert_raises(OptionParser::AmbiguousOption) {@opt.parse!(%w"-o")} + assert_equal(%w"", no_error {@opt.parse!(%w"--opt")}) + assert_equal(true, @flag) + end +end |