aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity
diff options
context:
space:
mode:
authorLiana Husikyan <liana@ethdev.com>2015-06-03 22:14:23 +0800
committerLiana Husikyan <liana@ethdev.com>2015-06-04 17:48:09 +0800
commitc7e6bbb82c7ad989df59906e8287db852012bbb9 (patch)
tree7c1158c6d00ab2e9ce3899e8e7c9e126fdaa05bf /libsolidity
parent5ef445f64f0e7854dcf9ac89b7867570bbbbbe69 (diff)
downloaddexon-solidity-c7e6bbb82c7ad989df59906e8287db852012bbb9.tar
dexon-solidity-c7e6bbb82c7ad989df59906e8287db852012bbb9.tar.gz
dexon-solidity-c7e6bbb82c7ad989df59906e8287db852012bbb9.tar.bz2
dexon-solidity-c7e6bbb82c7ad989df59906e8287db852012bbb9.tar.lz
dexon-solidity-c7e6bbb82c7ad989df59906e8287db852012bbb9.tar.xz
dexon-solidity-c7e6bbb82c7ad989df59906e8287db852012bbb9.tar.zst
dexon-solidity-c7e6bbb82c7ad989df59906e8287db852012bbb9.zip
- conversion of positive literals to signed int
- tests
Diffstat (limited to 'libsolidity')
-rw-r--r--libsolidity/SolidityEndToEndTest.cpp4
-rw-r--r--libsolidity/SolidityNameAndTypeResolution.cpp40
2 files changed, 44 insertions, 0 deletions
diff --git a/libsolidity/SolidityEndToEndTest.cpp b/libsolidity/SolidityEndToEndTest.cpp
index e7287b39..1d0f1fc2 100644
--- a/libsolidity/SolidityEndToEndTest.cpp
+++ b/libsolidity/SolidityEndToEndTest.cpp
@@ -4177,10 +4177,14 @@ BOOST_AUTO_TEST_CASE(positive_integers_to_signed)
char const* sourceCode = R"(
contract test {
int8 public x = 2;
+ int8 public y = 127;
+ int16 public q = 250;
}
)";
compileAndRun(sourceCode, 0, "test");
BOOST_CHECK(callContractFunction("x()") == encodeArgs(2));
+ BOOST_CHECK(callContractFunction("y()") == encodeArgs(127));
+ BOOST_CHECK(callContractFunction("q()") == encodeArgs(250));
}
BOOST_AUTO_TEST_SUITE_END()
diff --git a/libsolidity/SolidityNameAndTypeResolution.cpp b/libsolidity/SolidityNameAndTypeResolution.cpp
index 48404aaa..a35b7bbe 100644
--- a/libsolidity/SolidityNameAndTypeResolution.cpp
+++ b/libsolidity/SolidityNameAndTypeResolution.cpp
@@ -1816,6 +1816,46 @@ BOOST_AUTO_TEST_CASE(string_length)
BOOST_CHECK_THROW(parseTextAndResolveNames(sourceCode), TypeError);
}
+BOOST_AUTO_TEST_CASE(negative_integers_to_signed_out_of_bound)
+{
+ char const* sourceCode = R"(
+ contract test {
+ int8 public i = -129;
+ }
+ )";
+ BOOST_CHECK_THROW(parseTextAndResolveNames(sourceCode), TypeError);
+}
+
+BOOST_AUTO_TEST_CASE(negative_integers_to_signed_min)
+{
+ char const* sourceCode = R"(
+ contract test {
+ int8 public i = -128;
+ }
+ )";
+ BOOST_CHECK_NO_THROW(parseTextAndResolveNames(sourceCode));
+}
+
+BOOST_AUTO_TEST_CASE(positive_integers_to_signed_out_of_bound)
+{
+ char const* sourceCode = R"(
+ contract test {
+ int8 public j = 128;
+ }
+ )";
+ BOOST_CHECK_THROW(parseTextAndResolveNames(sourceCode), TypeError);
+}
+
+BOOST_AUTO_TEST_CASE(positive_integers_to_signed_out_of_bound_max)
+{
+ char const* sourceCode = R"(
+ contract test {
+ int8 public j = 127;
+ }
+ )";
+ BOOST_CHECK_NO_THROW(parseTextAndResolveNames(sourceCode));
+}
+
BOOST_AUTO_TEST_SUITE_END()
}