summaryrefslogtreecommitdiff
path: root/test/ruby/test_proc.rb
diff options
context:
space:
mode:
authorJeremy Evans <code@jeremyevans.net>2019-10-04 15:41:13 -0700
committerJeremy Evans <code@jeremyevans.net>2020-01-02 18:40:45 -0800
commitff96565686c05919bcae3ea77831879e95f67457 (patch)
treee04eaa5afdaaa942ccfef86648ebfb8a632e8c33 /test/ruby/test_proc.rb
parentbeae6cbf0fd8b6619e5212552de98022d4c4d4d4 (diff)
Update tests for full keyword argument separation
Notes
Notes: Merged: https://github.com/ruby/ruby/pull/2794
Diffstat (limited to 'test/ruby/test_proc.rb')
-rw-r--r--test/ruby/test_proc.rb112
1 files changed, 28 insertions, 84 deletions
diff --git a/test/ruby/test_proc.rb b/test/ruby/test_proc.rb
index fce1bd4a87..af4cf11623 100644
--- a/test/ruby/test_proc.rb
+++ b/test/ruby/test_proc.rb
@@ -1501,29 +1501,15 @@ class TestProcKeywords < Test::Unit::TestCase
g = ->(kw) { kw.merge(:a=>2) }
assert_equal(2, (f >> g).call(a: 3)[:a])
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (f << g).call(a: 3)[:a])
- end
+ assert_raise(ArgumentError) { (f << g).call(a: 3)[:a] }
assert_equal(2, (f >> g).call(a: 3)[:a])
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (f << g).call({a: 3})[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(2, (f >> g).call({a: 3})[:a])
- end
+ assert_raise(ArgumentError) { (f << g).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (f >> g).call({a: 3})[:a] }
assert_equal(2, (g << f).call(a: 3)[:a])
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (g >> f).call(a: 3)[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(2, (g << f).call({a: 3})[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (g >> f).call({a: 3})[:a])
- end
- assert_warn(/Passing the keyword argument as the last hash parameter is deprecated.*Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (f << g).call(**{})[:a])
- end
+ assert_raise(ArgumentError) { (g >> f).call(a: 3)[:a] }
+ assert_raise(ArgumentError) { (g << f).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (g >> f).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (f << g).call(**{})[:a] }
assert_equal(2, (f >> g).call(**{})[:a])
end
@@ -1531,29 +1517,15 @@ class TestProcKeywords < Test::Unit::TestCase
f = ->(**kw) { kw.merge(:a=>1) }.method(:call)
g = ->(kw) { kw.merge(:a=>2) }.method(:call)
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (f << g).call(a: 3)[:a])
- end
+ assert_raise(ArgumentError) { (f << g).call(a: 3)[:a] }
assert_equal(2, (f >> g).call(a: 3)[:a])
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (f << g).call({a: 3})[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(2, (f >> g).call({a: 3})[:a])
- end
+ assert_raise(ArgumentError) { (f << g).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (f >> g).call({a: 3})[:a] }
assert_equal(2, (g << f).call(a: 3)[:a])
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (g >> f).call(a: 3)[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(2, (g << f).call({a: 3})[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (g >> f).call({a: 3})[:a])
- end
- assert_warn(/Passing the keyword argument as the last hash parameter is deprecated.*Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (f << g).call(**{})[:a])
- end
+ assert_raise(ArgumentError) { (g >> f).call(a: 3)[:a] }
+ assert_raise(ArgumentError) { (g << f).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (g >> f).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (f << g).call(**{})[:a] }
assert_equal(2, (f >> g).call(**{})[:a])
end
@@ -1565,29 +1537,15 @@ class TestProcKeywords < Test::Unit::TestCase
def g.<<(f) to_proc << f end
def g.>>(f) to_proc >> f end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (f << g).call(a: 3)[:a])
- end
+ assert_raise(ArgumentError) { (f << g).call(a: 3)[:a] }
assert_equal(2, (f >> g).call(a: 3)[:a])
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (f << g).call({a: 3})[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(2, (f >> g).call({a: 3})[:a])
- end
+ assert_raise(ArgumentError) { (f << g).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (f >> g).call({a: 3})[:a] }
assert_equal(2, (g << f).call(a: 3)[:a])
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (g >> f).call(a: 3)[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(2, (g << f).call({a: 3})[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method is defined here/m) do
- assert_equal(1, (g >> f).call({a: 3})[:a])
- end
- assert_warn(/Passing the keyword argument as the last hash parameter is deprecated.*The called method `call'/m) do
- assert_equal(1, (f << g).call(**{})[:a])
- end
+ assert_raise(ArgumentError) { (g >> f).call(a: 3)[:a] }
+ assert_raise(ArgumentError) { (g << f).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (g >> f).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (f << g).call(**{})[:a] }
assert_equal(2, (f >> g).call(**{})[:a])
f = ->(kw) { kw.merge(:a=>1) }
@@ -1598,29 +1556,15 @@ class TestProcKeywords < Test::Unit::TestCase
def g.>>(f) to_proc >> f end
assert_equal(1, (f << g).call(a: 3)[:a])
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method `call'/m) do
- assert_equal(2, (f >> g).call(a: 3)[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method `call'/m) do
- assert_equal(1, (f << g).call({a: 3})[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method `call'/m) do
- assert_equal(2, (f >> g).call({a: 3})[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method `call'/m) do
- assert_equal(2, (g << f).call(a: 3)[:a])
- end
+ assert_raise(ArgumentError) { (f >> g).call(a: 3)[:a] }
+ assert_raise(ArgumentError) { (f << g).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (f >> g).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (g << f).call(a: 3)[:a] }
assert_equal(1, (g >> f).call(a: 3)[:a])
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method `call'/m) do
- assert_equal(2, (g << f).call({a: 3})[:a])
- end
- assert_warn(/Using the last argument as keyword parameters is deprecated.*The called method `call'/m) do
- assert_equal(1, (g >> f).call({a: 3})[:a])
- end
+ assert_raise(ArgumentError) { (g << f).call({a: 3})[:a] }
+ assert_raise(ArgumentError) { (g >> f).call({a: 3})[:a] }
assert_equal(1, (f << g).call(**{})[:a])
- assert_warn(/Passing the keyword argument as the last hash parameter is deprecated.*Using the last argument as keyword parameters is deprecated.*The called method `call'/m) do
- assert_equal(2, (f >> g).call(**{})[:a])
- end
+ assert_raise(ArgumentError) { (f >> g).call(**{})[:a] }
end
end