mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Fix tests.
This commit is contained in:
parent
44825d1c1e
commit
6385641f6e
@ -248,7 +248,7 @@ public:
|
|||||||
/// @returns the canonical name of this type for use in library function signatures.
|
/// @returns the canonical name of this type for use in library function signatures.
|
||||||
virtual std::string canonicalName() const { return toString(true); }
|
virtual std::string canonicalName() const { return toString(true); }
|
||||||
/// @returns the signature of this type in external functions, i.e. `uint256` for integers
|
/// @returns the signature of this type in external functions, i.e. `uint256` for integers
|
||||||
/// or `(uint256, bytes8)[2]` for an array of structs. If @a _structsByName,
|
/// or `(uint256,bytes8)[2]` for an array of structs. If @a _structsByName,
|
||||||
/// structs are given by canonical name like `ContractName.StructName[2]`.
|
/// structs are given by canonical name like `ContractName.StructName[2]`.
|
||||||
virtual std::string signatureInExternalFunction(bool /*_structsByName*/) const
|
virtual std::string signatureInExternalFunction(bool /*_structsByName*/) const
|
||||||
{
|
{
|
||||||
|
@ -50,7 +50,7 @@ private:
|
|||||||
std::vector<TypePointer> const& _types,
|
std::vector<TypePointer> const& _types,
|
||||||
bool _forLibrary
|
bool _forLibrary
|
||||||
);
|
);
|
||||||
/// @returns a Json object with "name", "type" and potentially "subtype" keys, according
|
/// @returns a Json object with "name", "type" and potentially "components" keys, according
|
||||||
/// to the ABI specification.
|
/// to the ABI specification.
|
||||||
/// If it is possible to express the type as a single string, it is allowed to return a single string.
|
/// If it is possible to express the type as a single string, it is allowed to return a single string.
|
||||||
static Json::Value formatType(std::string const& _name, Type const& _type, bool _forLibrary);
|
static Json::Value formatType(std::string const& _name, Type const& _type, bool _forLibrary);
|
||||||
|
@ -981,6 +981,7 @@ BOOST_AUTO_TEST_CASE(return_structs)
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"payable" : false,
|
"payable" : false,
|
||||||
|
"stateMutability" : "nonpayable",
|
||||||
"type" : "function"
|
"type" : "function"
|
||||||
}]
|
}]
|
||||||
)";
|
)";
|
||||||
@ -1022,6 +1023,7 @@ BOOST_AUTO_TEST_CASE(return_structs_with_contracts)
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"payable": false,
|
"payable": false,
|
||||||
|
"stateMutability" : "nonpayable",
|
||||||
"type": "function"
|
"type": "function"
|
||||||
}]
|
}]
|
||||||
)";
|
)";
|
||||||
@ -1127,6 +1129,7 @@ BOOST_AUTO_TEST_CASE(structs_in_libraries)
|
|||||||
"name": "g",
|
"name": "g",
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"payable": false,
|
"payable": false,
|
||||||
|
"stateMutability": "nonpayable",
|
||||||
"type": "function"
|
"type": "function"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -1140,6 +1143,7 @@ BOOST_AUTO_TEST_CASE(structs_in_libraries)
|
|||||||
"name": "f",
|
"name": "f",
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"payable": false,
|
"payable": false,
|
||||||
|
"stateMutability": "nonpayable",
|
||||||
"type": "function"
|
"type": "function"
|
||||||
}]
|
}]
|
||||||
)";
|
)";
|
||||||
|
@ -9685,6 +9685,7 @@ BOOST_AUTO_TEST_CASE(contracts_separated_with_comment)
|
|||||||
BOOST_AUTO_TEST_CASE(return_structs)
|
BOOST_AUTO_TEST_CASE(return_structs)
|
||||||
{
|
{
|
||||||
char const* sourceCode = R"(
|
char const* sourceCode = R"(
|
||||||
|
pragma experimental ABIEncoderV2;
|
||||||
contract C {
|
contract C {
|
||||||
struct S { uint a; T[] sub; }
|
struct S { uint a; T[] sub; }
|
||||||
struct T { uint[2] x; }
|
struct T { uint[2] x; }
|
||||||
|
@ -1102,7 +1102,7 @@ BOOST_AUTO_TEST_CASE(struct_accessor_one_array_only)
|
|||||||
Data public data;
|
Data public data;
|
||||||
}
|
}
|
||||||
)";
|
)";
|
||||||
CHECK_ERROR(sourceCode, TypeError, "Internal type is not allowed for public state variables.");
|
CHECK_ERROR(sourceCode, TypeError, "Internal or recursive type is not allowed for public state variables.");
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(base_class_state_variable_internal_member)
|
BOOST_AUTO_TEST_CASE(base_class_state_variable_internal_member)
|
||||||
@ -4904,7 +4904,7 @@ BOOST_AUTO_TEST_CASE(internal_function_as_external_parameter)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
)";
|
)";
|
||||||
CHECK_ERROR(text, TypeError, "Internal type is not allowed for public or external functions.");
|
CHECK_ERROR(text, TypeError, "Internal or recursive type is not allowed for public or external functions.");
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(internal_function_returned_from_public_function)
|
BOOST_AUTO_TEST_CASE(internal_function_returned_from_public_function)
|
||||||
@ -4916,7 +4916,7 @@ BOOST_AUTO_TEST_CASE(internal_function_returned_from_public_function)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
)";
|
)";
|
||||||
CHECK_ERROR(text, TypeError, "Internal type is not allowed for public or external functions.");
|
CHECK_ERROR(text, TypeError, "Internal or recursive type is not allowed for public or external functions.");
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(internal_function_as_external_parameter_in_library_internal)
|
BOOST_AUTO_TEST_CASE(internal_function_as_external_parameter_in_library_internal)
|
||||||
@ -4938,7 +4938,7 @@ BOOST_AUTO_TEST_CASE(internal_function_as_external_parameter_in_library_external
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
)";
|
)";
|
||||||
CHECK_ERROR(text, TypeError, "Internal type is not allowed for public or external functions.");
|
CHECK_ERROR(text, TypeError, "Internal or recursive type is not allowed for public or external functions.");
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(function_type_arrays)
|
BOOST_AUTO_TEST_CASE(function_type_arrays)
|
||||||
|
Loading…
Reference in New Issue
Block a user