From 8dd6f7769282e01b92eae32e1293e55487d3e31a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kamil=20=C5=9Aliwak?= Date: Thu, 23 Mar 2023 11:37:46 +0100 Subject: [PATCH 1/4] Extra test for operator cleanup --- ...meter_and_return_cleanup_between_calls.sol | 22 +++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 test/libsolidity/semanticTests/operators/userDefined/operator_parameter_and_return_cleanup_between_calls.sol diff --git a/test/libsolidity/semanticTests/operators/userDefined/operator_parameter_and_return_cleanup_between_calls.sol b/test/libsolidity/semanticTests/operators/userDefined/operator_parameter_and_return_cleanup_between_calls.sol new file mode 100644 index 000000000..b51ad8dad --- /dev/null +++ b/test/libsolidity/semanticTests/operators/userDefined/operator_parameter_and_return_cleanup_between_calls.sol @@ -0,0 +1,22 @@ +type U8 is uint8; +using {yoloAdd as +, yoloDiv as /} for U8 global; + +function yoloAdd(U8 x, U8 y) pure returns (U8 z) { + assembly { + z := add(x, y) // Wrong! No cleanup. + } +} + +function yoloDiv(U8 x, U8 y) pure returns (U8 z) { + assembly { + z := div(x, y) // Wrong! No cleanup. + } +} + +contract C { + function divAddNoOverflow(U8 a, U8 b, U8 c) external pure returns (U8) { + return a / (b + c); + } +} +// ---- +// divAddNoOverflow(uint8,uint8,uint8): 4, 0xff, 3 -> 0 From 5687f6e93454e896835033f2126cdec2206006db Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kamil=20=C5=9Aliwak?= Date: Fri, 7 Apr 2023 14:48:13 +0200 Subject: [PATCH 2/4] Tests for literal denominations with non-integer literals --- .../literals/fractional_denominations.sol | 15 +++++++++++++++ .../invalid_denomination_address.sol | 5 +++++ .../invalid_denomination_on_bool.sol | 5 +++++ .../invalid_denomination_on_string.sol | 5 +++++ 4 files changed, 30 insertions(+) create mode 100644 test/libsolidity/semanticTests/literals/fractional_denominations.sol create mode 100644 test/libsolidity/syntaxTests/denominations/invalid_denomination_address.sol create mode 100644 test/libsolidity/syntaxTests/denominations/invalid_denomination_on_bool.sol create mode 100644 test/libsolidity/syntaxTests/denominations/invalid_denomination_on_string.sol diff --git a/test/libsolidity/semanticTests/literals/fractional_denominations.sol b/test/libsolidity/semanticTests/literals/fractional_denominations.sol new file mode 100644 index 000000000..6bc448f09 --- /dev/null +++ b/test/libsolidity/semanticTests/literals/fractional_denominations.sol @@ -0,0 +1,15 @@ +contract C { + uint public g = 1.5 gwei; + uint public e = 1.5 ether; + uint public m = 1.5 minutes; + uint public h = 1.5 hours; + uint public d = 1.5 days; + uint public w = 1.5 weeks; +} +// ---- +// g() -> 1500000000 +// e() -> 1500000000000000000 +// m() -> 90 +// h() -> 5400 +// d() -> 129600 +// w() -> 907200 diff --git a/test/libsolidity/syntaxTests/denominations/invalid_denomination_address.sol b/test/libsolidity/syntaxTests/denominations/invalid_denomination_address.sol new file mode 100644 index 000000000..8eec22dee --- /dev/null +++ b/test/libsolidity/syntaxTests/denominations/invalid_denomination_address.sol @@ -0,0 +1,5 @@ +contract C { + address a = 0x11111122222333334444455555666667777788888 wei; +} +// ---- +// TypeError 5145: (26-73): Hexadecimal numbers cannot be used with unit denominations. You can use an expression of the form "0x1234 * 1 day" instead. diff --git a/test/libsolidity/syntaxTests/denominations/invalid_denomination_on_bool.sol b/test/libsolidity/syntaxTests/denominations/invalid_denomination_on_bool.sol new file mode 100644 index 000000000..58d7d205e --- /dev/null +++ b/test/libsolidity/syntaxTests/denominations/invalid_denomination_on_bool.sol @@ -0,0 +1,5 @@ +contract C { + bool constant x = true ether; +} +// ---- +// ParserError 2314: (37-42): Expected ';' but got 'ether' diff --git a/test/libsolidity/syntaxTests/denominations/invalid_denomination_on_string.sol b/test/libsolidity/syntaxTests/denominations/invalid_denomination_on_string.sol new file mode 100644 index 000000000..9d27c5d3d --- /dev/null +++ b/test/libsolidity/syntaxTests/denominations/invalid_denomination_on_string.sol @@ -0,0 +1,5 @@ +contract C { + string s = "abc" ether; +} +// ---- +// ParserError 2314: (31-36): Expected ';' but got 'ether' From fc7cd5484960cf2227ff2a728b5018715651e155 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kamil=20=C5=9Aliwak?= Date: Thu, 6 Apr 2023 12:53:30 +0200 Subject: [PATCH 3/4] Tests for changing virtual function mutability when overriding --- ..._override_changing_mutability_internal.sol | 23 +++++++++++++++++++ ...al_override_changing_mutability_public.sol | 23 +++++++++++++++++++ 2 files changed, 46 insertions(+) create mode 100644 test/libsolidity/semanticTests/virtualFunctions/virtual_override_changing_mutability_internal.sol create mode 100644 test/libsolidity/semanticTests/virtualFunctions/virtual_override_changing_mutability_public.sol diff --git a/test/libsolidity/semanticTests/virtualFunctions/virtual_override_changing_mutability_internal.sol b/test/libsolidity/semanticTests/virtualFunctions/virtual_override_changing_mutability_internal.sol new file mode 100644 index 000000000..cee1bcdde --- /dev/null +++ b/test/libsolidity/semanticTests/virtualFunctions/virtual_override_changing_mutability_internal.sol @@ -0,0 +1,23 @@ +contract A { + function f() internal virtual { + mutableWithViewOverride(); + mutableWithPureOverride(); + viewWithPureOverride(); + } + + function mutableWithViewOverride() internal virtual {} + function mutableWithPureOverride() internal virtual {} + function viewWithPureOverride() internal view virtual {} +} + +contract C is A { + function run() public { + f(); + } + + function mutableWithViewOverride() internal view override {} + function mutableWithPureOverride() internal pure override {} + function viewWithPureOverride() internal pure override {} +} +// ---- +// run() -> diff --git a/test/libsolidity/semanticTests/virtualFunctions/virtual_override_changing_mutability_public.sol b/test/libsolidity/semanticTests/virtualFunctions/virtual_override_changing_mutability_public.sol new file mode 100644 index 000000000..c3d9e60a0 --- /dev/null +++ b/test/libsolidity/semanticTests/virtualFunctions/virtual_override_changing_mutability_public.sol @@ -0,0 +1,23 @@ +contract A { + function f() internal virtual { + mutableWithViewOverride(); + mutableWithPureOverride(); + viewWithPureOverride(); + } + + function mutableWithViewOverride() public virtual {} + function mutableWithPureOverride() public virtual {} + function viewWithPureOverride() public view virtual {} +} + +contract C is A { + function run() public { + f(); + } + + function mutableWithViewOverride() public view override {} + function mutableWithPureOverride() public pure override {} + function viewWithPureOverride() public pure override {} +} +// ---- +// run() -> From 66fcd542bc61b3999bdd8051659579ffcf597d6e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kamil=20=C5=9Aliwak?= Date: Fri, 24 Feb 2023 19:54:50 +0100 Subject: [PATCH 4/4] Tests for denominations in array sizes --- .../literals/denominations_in_array_sizes.sol | 25 +++++++++++++++++++ .../denominations_in_array_sizes.sol | 12 +++++++++ 2 files changed, 37 insertions(+) create mode 100644 test/libsolidity/semanticTests/literals/denominations_in_array_sizes.sol create mode 100644 test/libsolidity/syntaxTests/denominations/denominations_in_array_sizes.sol diff --git a/test/libsolidity/semanticTests/literals/denominations_in_array_sizes.sol b/test/libsolidity/semanticTests/literals/denominations_in_array_sizes.sol new file mode 100644 index 000000000..43a09af05 --- /dev/null +++ b/test/libsolidity/semanticTests/literals/denominations_in_array_sizes.sol @@ -0,0 +1,25 @@ +contract C { + uint[2 wei] a; + uint[2 gwei] b; + uint[2 ether] c; + uint[2 seconds] d; + uint[2 minutes] e; + uint[2 hours] f; + uint[2 days] g; + uint[2 weeks] h; + + function lengths() public returns (uint, uint, uint, uint, uint, uint, uint, uint) { + return ( + a.length, + b.length, + c.length, + d.length, + e.length, + f.length, + g.length, + h.length + ); + } +} +// ---- +// lengths() -> 2, 2000000000, 2000000000000000000, 2, 120, 7200, 172800, 1209600 diff --git a/test/libsolidity/syntaxTests/denominations/denominations_in_array_sizes.sol b/test/libsolidity/syntaxTests/denominations/denominations_in_array_sizes.sol new file mode 100644 index 000000000..46c7a0d87 --- /dev/null +++ b/test/libsolidity/syntaxTests/denominations/denominations_in_array_sizes.sol @@ -0,0 +1,12 @@ +contract C { + uint[42 wei] a; + uint[42 gwei] b; + uint[42 ether] c; + uint[42 seconds] d; + uint[42 minutes] e; + uint[42 hours] f; + uint[42 days] g; + uint[42 weeks] h; +} +// ---- +// Warning 7325: (58-72): Type uint256[42000000000000000000] covers a large part of storage and thus makes collisions likely. Either use mappings or dynamic arrays and allow their size to be increased only in small quantities per transaction.