Make the test for invalid named arguments more robust

- Add more parameters and use different types.
- Now it's clear that the name used in the error message is wrong.
This commit is contained in:
Kamil Śliwak 2020-09-17 17:20:43 +02:00
parent dc62d763eb
commit 4045f41c8d

View File

@ -1,11 +1,13 @@
contract test { contract test {
function a(uint a, uint b) public returns (uint r) { function f(uint a, bool b, bytes memory c, uint d, bool e) public returns (uint r) {
r = a + b; if (b && !e)
r = a + d;
else
r = c.length;
} }
function b() public returns (uint r) { function g() public returns (uint r) {
r = a({a: 1, c: 2}); r = f({c: "abc", x: 1, e: 2, a: 11, b: 12});
} }
} }
// ---- // ----
// Warning 2519: (31-37): This declaration shadows an existing declaration. // TypeError 4974: (249-288): Named argument "a" does not match function declaration.
// TypeError 4974: (153-168): Named argument "c" does not match function declaration.