From fcbf63e62c627deae76c1b8cb8c0876c536ed811 Mon Sep 17 00:00:00 2001 From: Jari Vetoniemi Date: Mon, 16 Mar 2020 18:49:26 +0900 Subject: Fresh start --- jni/ruby/test/optparse/test_placearg.rb | 56 +++++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 jni/ruby/test/optparse/test_placearg.rb (limited to 'jni/ruby/test/optparse/test_placearg.rb') diff --git a/jni/ruby/test/optparse/test_placearg.rb b/jni/ruby/test/optparse/test_placearg.rb new file mode 100644 index 0000000..0bbd1a0 --- /dev/null +++ b/jni/ruby/test/optparse/test_placearg.rb @@ -0,0 +1,56 @@ +require_relative 'test_optparse' + +class TestOptionParser::PlaceArg < TestOptionParser + def setup + super + @opt.def_option("-x [VAL]") {|x| @flag = x} + @opt.def_option("--option [VAL]") {|x| @flag = x} + @opt.def_option("-T [level]", /^[0-4]$/, Integer) {|x| @topt = x} + @topt = nil + @opt.def_option("-n") {} + @opt.def_option("--regexp [REGEXP]", Regexp) {|x| @reopt = x} + @reopt = nil + end + + def test_short + assert_equal(%w"", no_error {@opt.parse!(%w"-x -n")}) + assert_equal(nil, @flag) + @flag = false + assert_equal(%w"", no_error {@opt.parse!(%w"-x foo")}) + assert_equal("foo", @flag) + assert_equal(%w"", no_error {@opt.parse!(%w"-xbar")}) + assert_equal("bar", @flag) + assert_equal(%w"", no_error {@opt.parse!(%w"-x=")}) + assert_equal("=", @flag) + end + + def test_abbrev + assert_equal(%w"", no_error {@opt.parse!(%w"-o -n")}) + assert_equal(nil, @flag) + @flag = false + assert_equal(%w"", no_error {@opt.parse!(%w"-o foo")}) + assert_equal("foo", @flag) + assert_equal(%w"", no_error {@opt.parse!(%w"-obar")}) + assert_equal("bar", @flag) + assert_equal(%w"", no_error {@opt.parse!(%w"-o=")}) + assert_equal("=", @flag) + end + + def test_long + assert_equal(%w"", no_error {@opt.parse!(%w"--opt -n")}) + assert_equal(nil, @flag) + assert_equal(%w"foo", no_error {@opt.parse!(%w"--opt= foo")}) + assert_equal("", @flag) + assert_equal(%w"", no_error {@opt.parse!(%w"--opt=foo")}) + assert_equal("foo", @flag) + assert_equal(%w"", no_error {@opt.parse!(%w"--opt bar")}) + assert_equal("bar", @flag) + end + + def test_conv + assert_equal(%w"te.rb", no_error('[ruby-dev:38333]') {@opt.parse!(%w"-T te.rb")}) + assert_nil(@topt) + assert_equal(%w"te.rb", no_error('[ruby-dev:38333]') {@opt.parse!(%w"-T1 te.rb")}) + assert_equal(1, @topt) + end +end -- cgit v1.2.3