aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorValentin Wüstholz <wuestholz@gmail.com>2017-01-23 03:49:12 +0800
committerchriseth <c@ethdev.com>2017-01-26 23:39:07 +0800
commit9bcbd93ac59a19320fd56e27c58a6283f2450666 (patch)
treecf102bce6745c1e771dcacbd83a6e850a09c0054 /test
parent102fd7ee5daeb7d7a7bb1254cf0ce71a23ad1220 (diff)
downloaddexon-solidity-9bcbd93ac59a19320fd56e27c58a6283f2450666.tar
dexon-solidity-9bcbd93ac59a19320fd56e27c58a6283f2450666.tar.gz
dexon-solidity-9bcbd93ac59a19320fd56e27c58a6283f2450666.tar.bz2
dexon-solidity-9bcbd93ac59a19320fd56e27c58a6283f2450666.tar.lz
dexon-solidity-9bcbd93ac59a19320fd56e27c58a6283f2450666.tar.xz
dexon-solidity-9bcbd93ac59a19320fd56e27c58a6283f2450666.tar.zst
dexon-solidity-9bcbd93ac59a19320fd56e27c58a6283f2450666.zip
Change translation of implicit throws (issue #1589).
This adds a new invalid instruction that is used for encoding implicit throws that are emitted by the compiler. This makes it possible to distinguish such runtime errors from user-provided, explicit throws.
Diffstat (limited to 'test')
-rw-r--r--test/libsolidity/Assembly.cpp4
-rw-r--r--test/libsolidity/SolidityExpressionCompiler.cpp14
2 files changed, 14 insertions, 4 deletions
diff --git a/test/libsolidity/Assembly.cpp b/test/libsolidity/Assembly.cpp
index 155dd5c9..aed3c854 100644
--- a/test/libsolidity/Assembly.cpp
+++ b/test/libsolidity/Assembly.cpp
@@ -116,8 +116,8 @@ BOOST_AUTO_TEST_CASE(location_test)
shared_ptr<string const> n = make_shared<string>("");
AssemblyItems items = compileContract(sourceCode);
vector<SourceLocation> locations =
- vector<SourceLocation>(18, SourceLocation(2, 75, n)) +
- vector<SourceLocation>(27, SourceLocation(20, 72, n)) +
+ vector<SourceLocation>(17, SourceLocation(2, 75, n)) +
+ vector<SourceLocation>(32, SourceLocation(20, 72, n)) +
vector<SourceLocation>{SourceLocation(42, 51, n), SourceLocation(65, 67, n)} +
vector<SourceLocation>(2, SourceLocation(58, 67, n)) +
vector<SourceLocation>(3, SourceLocation(20, 72, n));
diff --git a/test/libsolidity/SolidityExpressionCompiler.cpp b/test/libsolidity/SolidityExpressionCompiler.cpp
index 0c5a09c3..ca630169 100644
--- a/test/libsolidity/SolidityExpressionCompiler.cpp
+++ b/test/libsolidity/SolidityExpressionCompiler.cpp
@@ -337,13 +337,23 @@ BOOST_AUTO_TEST_CASE(arithmetics)
byte(Instruction::ADD),
byte(Instruction::DUP2),
byte(Instruction::ISZERO),
- byte(Instruction::PUSH1), 0x0,
+ byte(Instruction::PUSH1), 0x1e,
byte(Instruction::JUMPI),
+ byte(Instruction::PUSH1), 0x20,
+ byte(Instruction::JUMP),
+ byte(Instruction::JUMPDEST),
+ byte(Instruction::INVALID),
+ byte(Instruction::JUMPDEST),
byte(Instruction::MOD),
byte(Instruction::DUP2),
byte(Instruction::ISZERO),
- byte(Instruction::PUSH1), 0x0,
+ byte(Instruction::PUSH1), 0x2a,
byte(Instruction::JUMPI),
+ byte(Instruction::PUSH1), 0x2c,
+ byte(Instruction::JUMP),
+ byte(Instruction::JUMPDEST),
+ byte(Instruction::INVALID),
+ byte(Instruction::JUMPDEST),
byte(Instruction::DIV),
byte(Instruction::MUL)});
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());