Merge pull request #25 from LianaHus/sol_strings_as_mapping_keys

added check for string as mapping key for local var.
This commit is contained in:
Gav Wood 2015-08-27 22:36:35 +02:00
commit 714223f552

View File

@ -5188,14 +5188,17 @@ BOOST_AUTO_TEST_CASE(storage_string_as_mapping_key_without_variable)
char const* sourceCode = R"( char const* sourceCode = R"(
contract Test { contract Test {
mapping(string => uint) data; mapping(string => uint) data;
function f() returns (uint) { function f() returns (uint r, uint rl) {
data["abc"] = 2; mapping(string => uint) dataLocal;
return data["abc"]; dataLocal["abc"] = 2;
rl = dataLocal["abc"];
data["abc"] = 3;
r = data["abc"];
} }
} }
)"; )";
compileAndRun(sourceCode, 0, "Test"); compileAndRun(sourceCode, 0, "Test");
BOOST_CHECK(callContractFunction("f()") == encodeArgs(u256(2))); BOOST_CHECK(callContractFunction("f()") == encodeArgs(u256(3), u256(2)));
} }
BOOST_AUTO_TEST_SUITE_END() BOOST_AUTO_TEST_SUITE_END()