mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #14524 from ethereum/move-around-tests
Move around tests
This commit is contained in:
commit
c4af926a5d
@ -64,6 +64,7 @@ public:
|
|||||||
bool visit(SourceUnit const&) override { return true; }
|
bool visit(SourceUnit const&) override { return true; }
|
||||||
bool visit(ContractDefinition const&) override { return true; }
|
bool visit(ContractDefinition const&) override { return true; }
|
||||||
bool visit(InlineAssembly const& _inlineAssembly) override;
|
bool visit(InlineAssembly const& _inlineAssembly) override;
|
||||||
|
bool visit(ImportDirective const&) override { return true; }
|
||||||
bool visit(PragmaDirective const&) override { return false; }
|
bool visit(PragmaDirective const&) override { return false; }
|
||||||
|
|
||||||
bool visit(IfStatement const&) override { return true; }
|
bool visit(IfStatement const&) override { return true; }
|
||||||
|
@ -240,6 +240,13 @@ public:
|
|||||||
/// @returns false on error.
|
/// @returns false on error.
|
||||||
bool compile(State _stopAfter = State::CompilationSuccessful);
|
bool compile(State _stopAfter = State::CompilationSuccessful);
|
||||||
|
|
||||||
|
/// Checks whether experimental analysis is on; used in SyntaxTests to skip compilation in case it's ``true``.
|
||||||
|
/// @returns true if experimental analysis is set
|
||||||
|
bool isExperimentalAnalysis() const
|
||||||
|
{
|
||||||
|
return !!m_experimentalAnalysis;
|
||||||
|
}
|
||||||
|
|
||||||
/// @returns the list of sources (paths) used
|
/// @returns the list of sources (paths) used
|
||||||
std::vector<std::string> sourceNames() const;
|
std::vector<std::string> sourceNames() const;
|
||||||
|
|
||||||
|
@ -209,7 +209,15 @@ esac
|
|||||||
# boost_filesystem_bug specifically tests a local fix for a boost::filesystem
|
# boost_filesystem_bug specifically tests a local fix for a boost::filesystem
|
||||||
# bug. Since the test involves a malformed path, there is no point in running
|
# bug. Since the test involves a malformed path, there is no point in running
|
||||||
# tests on it. See https://github.com/boostorg/filesystem/issues/176
|
# tests on it. See https://github.com/boostorg/filesystem/issues/176
|
||||||
IMPORT_TEST_FILES=$(find "${TEST_DIRS[@]}" -name "*.sol" -and -not -name "boost_filesystem_bug.sol" -not -path "*/experimental/*")
|
# In addition, exclude all experimental Solidity tests (new type inference system)
|
||||||
|
EXCLUDE_FILES=(
|
||||||
|
boost_filesystem_bug.sol
|
||||||
|
pragma_experimental_solidity.sol
|
||||||
|
)
|
||||||
|
IMPORT_TEST_FILES=$(find "${TEST_DIRS[@]}" -name "*.sol" -and $(printf "! -name %s " ${EXCLUDE_FILES[@]}) -not -path "*/experimental/*")
|
||||||
|
|
||||||
|
echo $IMPORT_TEST_FILES
|
||||||
|
exit
|
||||||
|
|
||||||
NSOURCES="$(echo "${IMPORT_TEST_FILES}" | wc -l)"
|
NSOURCES="$(echo "${IMPORT_TEST_FILES}" | wc -l)"
|
||||||
echo "Looking at ${NSOURCES} .sol files..."
|
echo "Looking at ${NSOURCES} .sol files..."
|
||||||
|
@ -67,7 +67,7 @@ void SyntaxTest::parseAndAnalyze()
|
|||||||
{
|
{
|
||||||
setupCompiler();
|
setupCompiler();
|
||||||
|
|
||||||
if (compiler().parse() && compiler().analyze())
|
if (compiler().parse() && compiler().analyze() && !compiler().isExperimentalAnalysis())
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (!compiler().compile())
|
if (!compiler().compile())
|
||||||
|
@ -85,6 +85,8 @@ contract C {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// ====
|
// ====
|
||||||
|
// EVMVersion: >=constantinople
|
||||||
|
// ====
|
||||||
// compileViaYul: true
|
// compileViaYul: true
|
||||||
// ----
|
// ----
|
||||||
// (): 0 -> 0
|
// (): 0 -> 0
|
||||||
|
@ -6,3 +6,5 @@ import std.stub;
|
|||||||
// ----
|
// ----
|
||||||
// Warning 2264: (std.stub:63-92): Experimental features are turned on. Do not use experimental features on live deployments.
|
// Warning 2264: (std.stub:63-92): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
// Warning 2264: (0-29): Experimental features are turned on. Do not use experimental features on live deployments.
|
// Warning 2264: (0-29): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
|
// Info 4164: (std.stub:94-117): Inferred type: () -> ()
|
||||||
|
// Info 4164: (std.stub:111-113): Inferred type: ()
|
@ -6,3 +6,5 @@ import std.stub as stub;
|
|||||||
// ----
|
// ----
|
||||||
// Warning 2264: (std.stub:63-92): Experimental features are turned on. Do not use experimental features on live deployments.
|
// Warning 2264: (std.stub:63-92): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
// Warning 2264: (0-29): Experimental features are turned on. Do not use experimental features on live deployments.
|
// Warning 2264: (0-29): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
|
// Info 4164: (std.stub:94-117): Inferred type: () -> ()
|
||||||
|
// Info 4164: (std.stub:111-113): Inferred type: ()
|
@ -6,3 +6,6 @@ import { identity } from std.stub;
|
|||||||
// ----
|
// ----
|
||||||
// Warning 2264: (std.stub:63-92): Experimental features are turned on. Do not use experimental features on live deployments.
|
// Warning 2264: (std.stub:63-92): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
// Warning 2264: (0-29): Experimental features are turned on. Do not use experimental features on live deployments.
|
// Warning 2264: (0-29): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
|
// Info 4164: (std.stub:94-117): Inferred type: () -> ()
|
||||||
|
// Info 4164: (std.stub:111-113): Inferred type: ()
|
||||||
|
// Info 4164: (40-48): Inferred type: () -> ()
|
@ -6,3 +6,5 @@ import * as stub from std.stub;
|
|||||||
// ----
|
// ----
|
||||||
// Warning 2264: (std.stub:63-92): Experimental features are turned on. Do not use experimental features on live deployments.
|
// Warning 2264: (std.stub:63-92): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
// Warning 2264: (0-29): Experimental features are turned on. Do not use experimental features on live deployments.
|
// Warning 2264: (0-29): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
|
// Info 4164: (std.stub:94-117): Inferred type: () -> ()
|
||||||
|
// Info 4164: (std.stub:111-113): Inferred type: ()
|
@ -0,0 +1,24 @@
|
|||||||
|
pragma experimental solidity;
|
||||||
|
|
||||||
|
import { identity as id } from std.stub;
|
||||||
|
|
||||||
|
contract C
|
||||||
|
{
|
||||||
|
fallback() external
|
||||||
|
{
|
||||||
|
id();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ====
|
||||||
|
// EVMVersion: >=constantinople
|
||||||
|
// ----
|
||||||
|
// Warning 2264: (std.stub:63-92): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
|
// Warning 2264: (0-29): Experimental features are turned on. Do not use experimental features on live deployments.
|
||||||
|
// Info 4164: (std.stub:94-117): Inferred type: () -> ()
|
||||||
|
// Info 4164: (std.stub:111-113): Inferred type: ()
|
||||||
|
// Info 4164: (40-48): Inferred type: () -> ()
|
||||||
|
// Info 4164: (90-135): Inferred type: () -> ()
|
||||||
|
// Info 4164: (98-100): Inferred type: ()
|
||||||
|
// Info 4164: (124-128): Inferred type: ()
|
||||||
|
// Info 4164: (124-126): Inferred type: () -> ()
|
@ -70,5 +70,5 @@ while read -r file; do
|
|||||||
echo "$file"
|
echo "$file"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
done < <(find "${REPO_ROOT}/test" -iname "*.sol" -and -not -name "documentation.sol" -and -not -name "boost_filesystem_bug.sol")
|
done < <(find "${REPO_ROOT}/test" -iname "*.sol" -and -not -name "documentation.sol" -and -not -name "boost_filesystem_bug.sol" -not -path "*/experimental/*")
|
||||||
echo
|
echo
|
||||||
|
Loading…
Reference in New Issue
Block a user