Merge pull request #14524 from ethereum/move-around-tests

Move around tests
This commit is contained in:
Daniel 2023-09-05 11:56:02 +02:00 committed by GitHub
commit c4af926a5d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
19 changed files with 54 additions and 3 deletions

View File

@ -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; }

View File

@ -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;

View File

@ -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..."

View File

@ -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())

View File

@ -85,6 +85,8 @@ contract C {
} }
} }
// ==== // ====
// EVMVersion: >=constantinople
// ====
// compileViaYul: true // compileViaYul: true
// ---- // ----
// (): 0 -> 0 // (): 0 -> 0

View File

@ -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: ()

View File

@ -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: ()

View File

@ -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: () -> ()

View File

@ -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: ()

View File

@ -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: () -> ()

View File

@ -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