diff options
author | chriseth <chris@ethereum.org> | 2018-04-04 20:37:43 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-04-04 20:37:43 +0800 |
commit | 2fe5607a5a6618f27f4ed5c1effb4273c662ee3a (patch) | |
tree | aef8f1dc5fa400e27ea5072f10c64f7ec5374b22 /test/libsolidity/SolidityOptimizer.cpp | |
parent | c5c5b23ff485075836b0b80db6e7cfebf0eebb4b (diff) | |
parent | 0cbe55005de79b0f7c5c770d50c3eb87df019789 (diff) | |
download | dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.gz dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.bz2 dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.lz dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.xz dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.zst dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.zip |
Merge pull request #3721 from ethereum/simpleDynArray
Create empty dynamic memory arrays more efficiently.
Diffstat (limited to 'test/libsolidity/SolidityOptimizer.cpp')
-rw-r--r-- | test/libsolidity/SolidityOptimizer.cpp | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/test/libsolidity/SolidityOptimizer.cpp b/test/libsolidity/SolidityOptimizer.cpp index cf4550c7..a0df76f3 100644 --- a/test/libsolidity/SolidityOptimizer.cpp +++ b/test/libsolidity/SolidityOptimizer.cpp @@ -93,8 +93,10 @@ public: { m_contractAddress = m_nonOptimizedContract; bytes nonOptimizedOutput = callContractFunction(_sig, _arguments...); + m_gasUsedNonOptimized = m_gasUsed; m_contractAddress = m_optimizedContract; bytes optimizedOutput = callContractFunction(_sig, _arguments...); + m_gasUsedOptimized = m_gasUsed; BOOST_CHECK_MESSAGE(!optimizedOutput.empty(), "No optimized output for " + _sig); BOOST_CHECK_MESSAGE(!nonOptimizedOutput.empty(), "No un-optimized output for " + _sig); BOOST_CHECK_MESSAGE(nonOptimizedOutput == optimizedOutput, "Computed values do not match." @@ -120,6 +122,8 @@ public: } protected: + u256 m_gasUsedOptimized; + u256 m_gasUsedNonOptimized; bytes m_nonOptimizedBytecode; bytes m_optimizedBytecode; Address m_optimizedContract; @@ -584,6 +588,26 @@ BOOST_AUTO_TEST_CASE(invalid_state_at_control_flow_join) compareVersions("test()"); } +BOOST_AUTO_TEST_CASE(init_empty_dynamic_arrays) +{ + // This is not so much an optimizer test, but rather a test + // that allocating empty arrays is implemented efficiently. + // In particular, initializing a dynamic memory array does + // not use any memory. + char const* sourceCode = R"( + contract Test { + function f() pure returns (uint r) { + uint[][] memory x = new uint[][](20000); + return x.length; + } + } + )"; + compileBothVersions(sourceCode); + compareVersions("f()"); + BOOST_CHECK_LE(m_gasUsedNonOptimized, 1900000); + BOOST_CHECK_LE(1600000, m_gasUsedNonOptimized); +} + BOOST_AUTO_TEST_CASE(optimise_multi_stores) { char const* sourceCode = R"( |