aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2016-07-29 17:46:57 +0800
committerchriseth <c@ethdev.com>2016-08-01 21:30:19 +0800
commitac0d1388008ed616ab7b35a5b3a27e7400decd46 (patch)
treea6e2f3d6ebaa20077a7742d40a25954863216612 /test
parent21a7dda733b68a4417c4822b22bd4810a9c3e5d1 (diff)
downloaddexon-solidity-ac0d1388008ed616ab7b35a5b3a27e7400decd46.tar
dexon-solidity-ac0d1388008ed616ab7b35a5b3a27e7400decd46.tar.gz
dexon-solidity-ac0d1388008ed616ab7b35a5b3a27e7400decd46.tar.bz2
dexon-solidity-ac0d1388008ed616ab7b35a5b3a27e7400decd46.tar.lz
dexon-solidity-ac0d1388008ed616ab7b35a5b3a27e7400decd46.tar.xz
dexon-solidity-ac0d1388008ed616ab7b35a5b3a27e7400decd46.tar.zst
dexon-solidity-ac0d1388008ed616ab7b35a5b3a27e7400decd46.zip
Test case.
Diffstat (limited to 'test')
-rw-r--r--test/libsolidity/SolidityOptimizer.cpp58
1 files changed, 58 insertions, 0 deletions
diff --git a/test/libsolidity/SolidityOptimizer.cpp b/test/libsolidity/SolidityOptimizer.cpp
index 67b161b9..2e4ed4b3 100644
--- a/test/libsolidity/SolidityOptimizer.cpp
+++ b/test/libsolidity/SolidityOptimizer.cpp
@@ -1177,6 +1177,64 @@ BOOST_AUTO_TEST_CASE(computing_constants)
) == optimizedBytecode.cend());
}
+BOOST_AUTO_TEST_CASE(inconsistency)
+{
+ // This is a test of a bug in the optimizer.
+ char const* sourceCode = R"(
+ contract Inconsistency {
+ struct Value {
+ uint badnum;
+ uint number;
+ }
+
+ struct Container {
+ uint[] valueIndices;
+ Value[] values;
+ }
+
+ Container[] containers;
+ uint[] valueIndices;
+ uint INDEX_ZERO = 0;
+ uint debug;
+
+ // Called with params: containerIndex=0, valueIndex=0
+ function levelIII(uint containerIndex, uint valueIndex) private {
+ Container container = containers[containerIndex];
+ Value value = container.values[valueIndex];
+ debug = container.valueIndices[value.number];
+ }
+ function levelII() private {
+ for (uint i = 0; i < valueIndices.length; i++) {
+ levelIII(INDEX_ZERO, valueIndices[i]);
+ }
+ }
+
+ function trigger() public returns (uint) {
+ containers.length++;
+ Container container = containers[0];
+
+ container.values.push(Value({
+ badnum: 9000,
+ number: 0
+ }));
+
+ container.valueIndices.length++;
+ valueIndices.length++;
+
+ levelII();
+ return debug;
+ }
+
+ function DoNotCallButDoNotDelete() public {
+ levelII();
+ levelIII(1, 2);
+ }
+ }
+ )";
+ compileBothVersions(sourceCode);
+ compareVersions("trigger()");
+}
+
BOOST_AUTO_TEST_SUITE_END()
}