From b0084b7963ce35978c178ac1fd02b33a3a23af12 Mon Sep 17 00:00:00 2001 From: "Thomas E. Enebo" Date: Wed, 1 May 2024 10:08:06 -0400 Subject: [PATCH 1/4] SignalException is using wrong arity check (from test_arity in MRI) --- .../java/org/jruby/RubySignalException.java | 21 ++++++++----------- 1 file changed, 9 insertions(+), 12 deletions(-) diff --git a/core/src/main/java/org/jruby/RubySignalException.java b/core/src/main/java/org/jruby/RubySignalException.java index 04c9f95ebc8..fa9ed8f6e7a 100644 --- a/core/src/main/java/org/jruby/RubySignalException.java +++ b/core/src/main/java/org/jruby/RubySignalException.java @@ -62,26 +62,23 @@ static RubyClass define(Ruby runtime, RubyClass exceptionClass) { return signalExceptionClass; } - @JRubyMethod(optional = 2, checkArity = false, visibility = PRIVATE) + @JRubyMethod(required = 1, optional = 2, checkArity = false, visibility = PRIVATE) public IRubyObject initialize(ThreadContext context, IRubyObject[] args, Block block) { - int argc = Arity.checkArgumentCount(context, args, 0, 2); + int argc = Arity.checkArgumentCount(context, args, 1, 2); final Ruby runtime = context.runtime; int argnum = 1; - IRubyObject sig = context.nil; - long _signo; - if (argc > 0) { - sig = TypeConverter.checkToInteger(runtime, args[0], "to_int"); + IRubyObject sig = TypeConverter.checkToInteger(runtime, args[0], "to_int"); - if (sig.isNil()) { - sig = args[0]; - } else { - argnum = 2; - } + if (sig.isNil()) { + sig = args[0]; + Arity.checkArgumentCount(runtime, args, 1, argnum); + } else { + argnum = 2; } - Arity.checkArgumentCount(runtime, args, 1, argnum); + long _signo; if (argnum == 2) { _signo = sig.convertToInteger().getLongValue(); From 94105c25e8b6ed969ff9ea9ec5ad34ecd2de0a3d Mon Sep 17 00:00:00 2001 From: "Thomas E. Enebo" Date: Wed, 1 May 2024 10:11:51 -0400 Subject: [PATCH 2/4] Hash.new(1) {} is giving wrong argument error string --- core/src/main/java/org/jruby/RubyHash.java | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/core/src/main/java/org/jruby/RubyHash.java b/core/src/main/java/org/jruby/RubyHash.java index c5b39bce15b..205ceca7001 100644 --- a/core/src/main/java/org/jruby/RubyHash.java +++ b/core/src/main/java/org/jruby/RubyHash.java @@ -814,11 +814,10 @@ public IRubyObject initialize(ThreadContext context, final Block block) { public IRubyObject initialize(ThreadContext context, IRubyObject _default, final Block block) { modify(); - if (block.isGiven()) { - throw context.runtime.newArgumentError("wrong number of arguments"); - } else { - ifNone = _default; - } + if (block.isGiven()) throw context.runtime.newArgumentError(1, 0); + + ifNone = _default; + return this; } From 4a4e30e63e4bf15be9cc28de8a7dd76a746d66b2 Mon Sep 17 00:00:00 2001 From: "Thomas E. Enebo" Date: Wed, 1 May 2024 10:15:19 -0400 Subject: [PATCH 3/4] another mismatched error string --- core/src/main/ruby/jruby/kernel/jruby/process_util.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/src/main/ruby/jruby/kernel/jruby/process_util.rb b/core/src/main/ruby/jruby/kernel/jruby/process_util.rb index 7786153dcd9..b009973d390 100644 --- a/core/src/main/ruby/jruby/kernel/jruby/process_util.rb +++ b/core/src/main/ruby/jruby/kernel/jruby/process_util.rb @@ -4,7 +4,7 @@ def self.exec_args(args) env, prog, opts = nil if args.size < 1 - raise ArgumentError, 'wrong number of arguments' + raise ArgumentError, 'wrong number of arguments (given 0, expected 1+)' end # peel off options From bd638821ecadf5741a3a0a12c1c0774411943756 Mon Sep 17 00:00:00 2001 From: "Thomas E. Enebo" Date: Wed, 1 May 2024 10:17:15 -0400 Subject: [PATCH 4/4] Remove tags for arity specs in MRI test suite as they pass now --- test/mri/excludes/TestArity.rb | 3 --- 1 file changed, 3 deletions(-) delete mode 100644 test/mri/excludes/TestArity.rb diff --git a/test/mri/excludes/TestArity.rb b/test/mri/excludes/TestArity.rb deleted file mode 100644 index 760fd49eb42..00000000000 --- a/test/mri/excludes/TestArity.rb +++ /dev/null @@ -1,3 +0,0 @@ -exclude :test_message_change_issue_6085, "needs investigation" -exclude :test_method_err_mess, "needs investigation" -exclude :test_proc_err_mess, "needs investigation" \ No newline at end of file