aboutsummaryrefslogtreecommitdiffstats
path: root/test/libsolidity/ViewPureChecker.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'test/libsolidity/ViewPureChecker.cpp')
-rw-r--r--test/libsolidity/ViewPureChecker.cpp104
1 files changed, 51 insertions, 53 deletions
diff --git a/test/libsolidity/ViewPureChecker.cpp b/test/libsolidity/ViewPureChecker.cpp
index 9cea9850..3f02564f 100644
--- a/test/libsolidity/ViewPureChecker.cpp
+++ b/test/libsolidity/ViewPureChecker.cpp
@@ -40,10 +40,10 @@ BOOST_AUTO_TEST_CASE(smoke_test)
char const* text = R"(
contract C {
uint x;
- function g() pure {}
- function f() view returns (uint) { return now; }
- function h() { x = 2; }
- function i() payable { x = 2; }
+ function g() pure public {}
+ function f() view public returns (uint) { return now; }
+ function h() public { x = 2; }
+ function i() payable public { x = 2; }
}
)";
CHECK_SUCCESS_NO_WARNINGS(text);
@@ -53,10 +53,10 @@ BOOST_AUTO_TEST_CASE(call_internal_functions_success)
{
char const* text = R"(
contract C {
- function g() pure { g(); }
- function f() view returns (uint) { f(); g(); }
- function h() { h(); g(); f(); }
- function i() payable { i(); h(); g(); f(); }
+ function g() pure public { g(); }
+ function f() view public returns (uint) { f(); g(); }
+ function h() public { h(); g(); f(); }
+ function i() payable public { i(); h(); g(); f(); }
}
)";
CHECK_SUCCESS_NO_WARNINGS(text);
@@ -66,7 +66,7 @@ BOOST_AUTO_TEST_CASE(suggest_pure)
{
char const* text = R"(
contract C {
- function g() view { }
+ function g() view public { }
}
)";
CHECK_WARNING(text, "can be restricted to pure");
@@ -77,7 +77,7 @@ BOOST_AUTO_TEST_CASE(suggest_view)
char const* text = R"(
contract C {
uint x;
- function g() returns (uint) { return x; }
+ function g() public returns (uint) { return x; }
}
)";
CHECK_WARNING(text, "can be restricted to view");
@@ -86,7 +86,7 @@ BOOST_AUTO_TEST_CASE(suggest_view)
BOOST_AUTO_TEST_CASE(call_internal_functions_fail)
{
CHECK_ERROR(
- "contract C{ function f() pure { g(); } function g() view {} }",
+ "contract C{ function f() pure public { g(); } function g() view public {} }",
TypeError,
"Function declared as pure, but this expression (potentially) reads from the environment or state and thus requires \"view\""
);
@@ -95,7 +95,7 @@ BOOST_AUTO_TEST_CASE(call_internal_functions_fail)
BOOST_AUTO_TEST_CASE(write_storage_fail)
{
CHECK_WARNING(
- "contract C{ uint x; function f() view { x = 2; } }",
+ "contract C{ uint x; function f() view public { x = 2; } }",
"Function declared as view, but this expression (potentially) modifies the state and thus requires non-payable (the default) or payable."
);
}
@@ -129,7 +129,7 @@ BOOST_AUTO_TEST_CASE(environment_access)
for (string const& x: view)
{
CHECK_ERROR(
- "contract C { function f() pure { var x = " + x + "; x; } }",
+ "contract C { function f() pure public { var x = " + x + "; x; } }",
TypeError,
"Function declared as pure, but this expression (potentially) reads from the environment or state and thus requires \"view\""
);
@@ -137,7 +137,7 @@ BOOST_AUTO_TEST_CASE(environment_access)
for (string const& x: pure)
{
CHECK_WARNING(
- "contract C { function f() view { var x = " + x + "; x; } }",
+ "contract C { function f() view public { var x = " + x + "; x; } }",
"restricted to pure"
);
}
@@ -153,15 +153,15 @@ BOOST_AUTO_TEST_CASE(modifiers)
modifier nonpayablem(uint) { x = 2; _; }
}
contract C is D {
- function f() purem(0) pure {}
- function g() viewm(0) view {}
- function h() nonpayablem(0) {}
- function i() purem(x) view {}
- function j() viewm(x) view {}
- function k() nonpayablem(x) {}
- function l() purem(x = 2) {}
- function m() viewm(x = 2) {}
- function n() nonpayablem(x = 2) {}
+ function f() purem(0) pure public {}
+ function g() viewm(0) view public {}
+ function h() nonpayablem(0) public {}
+ function i() purem(x) view public {}
+ function j() viewm(x) view public {}
+ function k() nonpayablem(x) public {}
+ function l() purem(x = 2) public {}
+ function m() viewm(x = 2) public {}
+ function n() nonpayablem(x = 2) public {}
}
)";
CHECK_SUCCESS_NO_WARNINGS(text);
@@ -171,10 +171,10 @@ BOOST_AUTO_TEST_CASE(interface)
{
string text = R"(
interface D {
- function f() view;
+ function f() view public;
}
contract C is D {
- function f() view {}
+ function f() view public {}
}
)";
CHECK_SUCCESS_NO_WARNINGS(text);
@@ -185,10 +185,10 @@ BOOST_AUTO_TEST_CASE(overriding)
string text = R"(
contract D {
uint x;
- function f() { x = 2; }
+ function f() public { x = 2; }
}
contract C is D {
- function f() {}
+ function f() public {}
}
)";
CHECK_SUCCESS_NO_WARNINGS(text);
@@ -203,12 +203,10 @@ BOOST_AUTO_TEST_CASE(returning_structs)
function f() view internal returns (S storage) {
return s;
}
- function g()
- {
+ function g() public {
f().x = 2;
}
- function h() view
- {
+ function h() view public {
f();
f().x;
}
@@ -222,13 +220,13 @@ BOOST_AUTO_TEST_CASE(mappings)
string text = R"(
contract C {
mapping(uint => uint) a;
- function f() view {
+ function f() view public {
a;
}
- function g() view {
+ function g() view public {
a[2];
}
- function h() {
+ function h() public {
a[2] = 3;
}
}
@@ -242,18 +240,18 @@ BOOST_AUTO_TEST_CASE(local_storage_variables)
contract C {
struct S { uint a; }
S s;
- function f() view {
+ function f() view public {
S storage x = s;
x;
}
- function g() view {
+ function g() view public {
S storage x = s;
x = s;
}
- function i() {
+ function i() public {
s.a = 2;
}
- function h() {
+ function h() public {
S storage x = s;
x.a = 2;
}
@@ -266,14 +264,14 @@ BOOST_AUTO_TEST_CASE(builtin_functions)
{
string text = R"(
contract C {
- function f() {
+ function f() public {
this.transfer(1);
require(this.send(2));
selfdestruct(this);
require(this.delegatecall());
require(this.call());
}
- function g() pure {
+ function g() pure public {
var x = keccak256("abc");
var y = sha256("abc");
var z = ecrecover(1, 2, 3, 4);
@@ -281,7 +279,7 @@ BOOST_AUTO_TEST_CASE(builtin_functions)
assert(true);
x; y; z;
}
- function() payable {}
+ function() payable public {}
}
)";
CHECK_SUCCESS_NO_WARNINGS(text);
@@ -291,7 +289,7 @@ BOOST_AUTO_TEST_CASE(function_types)
{
string text = R"(
contract C {
- function f() pure {
+ function f() pure public {
function () external nonpayFun;
function () external view viewFun;
function () external pure pureFun;
@@ -301,12 +299,12 @@ BOOST_AUTO_TEST_CASE(function_types)
pureFun;
pureFun();
}
- function g() view {
+ function g() view public {
function () external view viewFun;
viewFun();
}
- function h() {
+ function h() public {
function () external nonpayFun;
nonpayFun();
@@ -321,7 +319,7 @@ BOOST_AUTO_TEST_CASE(creation)
string text = R"(
contract D {}
contract C {
- function f() { new D(); }
+ function f() public { new D(); }
}
)";
CHECK_SUCCESS_NO_WARNINGS(text);
@@ -333,20 +331,20 @@ BOOST_AUTO_TEST_CASE(assembly)
contract C {
struct S { uint x; }
S s;
- function e() pure {
+ function e() pure public {
assembly { mstore(keccak256(0, 20), mul(s_slot, 2)) }
}
- function f() pure {
+ function f() pure public {
uint x;
assembly { x := 7 }
}
- function g() view {
+ function g() view public {
assembly { for {} 1 { pop(sload(0)) } { } }
}
- function h() view {
+ function h() view public {
assembly { function g() { pop(blockhash(20)) } }
}
- function j() {
+ function j() public {
assembly { pop(call(0, 1, 2, 3, 4, 5, 6)) }
}
}
@@ -358,7 +356,7 @@ BOOST_AUTO_TEST_CASE(assembly_staticcall)
{
string text = R"(
contract C {
- function i() view {
+ function i() view public {
assembly { pop(staticcall(0, 1, 2, 3, 4, 5)) }
}
}
@@ -370,7 +368,7 @@ BOOST_AUTO_TEST_CASE(assembly_jump)
{
string text = R"(
contract C {
- function k() {
+ function k() public {
assembly { jump(2) }
}
}
@@ -383,7 +381,7 @@ BOOST_AUTO_TEST_CASE(constant)
string text = R"(
contract C {
uint constant x = 2;
- function k() pure returns (uint) {
+ function k() pure public returns (uint) {
return x;
}
}