mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Fix test for gas overloading in .transfer()
This commit is contained in:
parent
c46c68dfd8
commit
cde027d144
@ -1707,11 +1707,22 @@ BOOST_AUTO_TEST_CASE(transfer_ether)
|
|||||||
throw;
|
throw;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
contract D {
|
||||||
|
// This takes about ~3600 gas, which exceeds the 2300 gas stipend.
|
||||||
|
function () payable {
|
||||||
|
bytes32 tmp = 1;
|
||||||
|
for (uint i = 0; i < 20; i++)
|
||||||
|
tmp = sha3(tmp);
|
||||||
|
}
|
||||||
|
}
|
||||||
)";
|
)";
|
||||||
compileAndRun(sourceCode, 0, "B");
|
compileAndRun(sourceCode, 0, "B");
|
||||||
u160 const nonPayableRecipient = m_contractAddress;
|
u160 const nonPayableRecipient = m_contractAddress;
|
||||||
compileAndRun(sourceCode, 0, "C");
|
compileAndRun(sourceCode, 0, "C");
|
||||||
u160 const oogRecipient = m_contractAddress;
|
u160 const oogRecipient = m_contractAddress;
|
||||||
|
compileAndRun(sourceCode, 0, "D");
|
||||||
|
u160 const expensiveRecipient = m_contractAddress;
|
||||||
compileAndRun(sourceCode, 20, "A");
|
compileAndRun(sourceCode, 20, "A");
|
||||||
u160 payableRecipient(23);
|
u160 payableRecipient(23);
|
||||||
BOOST_CHECK(callContractFunction("a(address,uint256)", payableRecipient, 10) == encodeArgs(10));
|
BOOST_CHECK(callContractFunction("a(address,uint256)", payableRecipient, 10) == encodeArgs(10));
|
||||||
@ -1719,8 +1730,8 @@ BOOST_AUTO_TEST_CASE(transfer_ether)
|
|||||||
BOOST_CHECK_EQUAL(balanceAt(m_contractAddress), 10);
|
BOOST_CHECK_EQUAL(balanceAt(m_contractAddress), 10);
|
||||||
BOOST_CHECK(callContractFunction("b(address,uint256)", nonPayableRecipient, 10) == encodeArgs());
|
BOOST_CHECK(callContractFunction("b(address,uint256)", nonPayableRecipient, 10) == encodeArgs());
|
||||||
BOOST_CHECK(callContractFunction("b(address,uint256)", oogRecipient, 10) == encodeArgs());
|
BOOST_CHECK(callContractFunction("b(address,uint256)", oogRecipient, 10) == encodeArgs());
|
||||||
BOOST_CHECK(callContractFunction("c(address,uint256,uint256)", payableRecipient, 1, 9000) == encodeArgs(9));
|
BOOST_CHECK(callContractFunction("c(address,uint256,uint256)", expensiveRecipient, 1, 9000) == encodeArgs(9));
|
||||||
BOOST_CHECK(callContractFunction("c(address,uint256,uint256)", payableRecipient, 1, 0) == encodeArgs());
|
BOOST_CHECK(callContractFunction("c(address,uint256,uint256)", expensiveRecipient, 1, 0) == encodeArgs());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(log0)
|
BOOST_AUTO_TEST_CASE(log0)
|
||||||
|
Loading…
Reference in New Issue
Block a user