Move unused pruner tests.

This commit is contained in:
chriseth 2018-10-11 18:41:01 +02:00
parent 463642996a
commit a937a449df
12 changed files with 113 additions and 129 deletions

View File

@ -1,129 +0,0 @@
/*
This file is part of solidity.
solidity is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
solidity is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with solidity. If not, see <http://www.gnu.org/licenses/>.
*/
/**
* @date 2017
* Unit tests for the pruning of unused variables and functions.
*/
#include <test/libjulia/Common.h>
#include <libjulia/optimiser/UnusedPruner.h>
#include <libsolidity/inlineasm/AsmPrinter.h>
#include <boost/test/unit_test.hpp>
#include <boost/range/adaptors.hpp>
#include <boost/algorithm/string/join.hpp>
using namespace std;
using namespace dev;
using namespace dev::julia;
using namespace dev::julia::test;
using namespace dev::solidity;
#define CHECK(_original, _expectation)\
do\
{\
assembly::AsmPrinter p;\
Block b = disambiguate(_original, false);\
UnusedPruner::runUntilStabilised(b);\
string result = p(b);\
BOOST_CHECK_EQUAL(result, format(_expectation, false));\
}\
while(false)
BOOST_AUTO_TEST_SUITE(YulUnusedPruner)
BOOST_AUTO_TEST_CASE(smoke_test)
{
CHECK("{ }", "{ }");
}
BOOST_AUTO_TEST_CASE(trivial)
{
CHECK(
"{ let a := 1 let b := 1 mstore(0, 1) }",
"{ mstore(0, 1) }"
);
}
BOOST_AUTO_TEST_CASE(multi_declarations)
{
CHECK(
"{ let x, y }",
"{ }"
);
}
BOOST_AUTO_TEST_CASE(multi_assignments)
{
CHECK(
"{ let x, y x := 1 y := 2 }",
"{ let x, y x := 1 y := 2 }"
);
}
BOOST_AUTO_TEST_CASE(multi_partial_assignments)
{
CHECK(
"{ let x, y x := 1 }",
"{ let x, y x := 1 }"
);
}
BOOST_AUTO_TEST_CASE(functions)
{
CHECK(
"{ function f() { let a := 1 } function g() { f() } }",
"{ }"
);
}
BOOST_AUTO_TEST_CASE(intermediate_assignment)
{
CHECK(
"{ let a := 1 a := 4 let b := 1 }",
"{ let a := 1 a := 4 }"
);
}
BOOST_AUTO_TEST_CASE(intermediate_multi_assignment){
CHECK(
"{ let a, b function f() -> x { } a := f() b := 1 }",
"{ let a, b function f() -> x { } a := f() b := 1 }"
);
}
BOOST_AUTO_TEST_CASE(multi_declare)
{
CHECK(
"{ function f() -> x, y { } let a, b := f() }",
"{ function f() -> x, y { } let a, b := f() }"
);
}
BOOST_AUTO_TEST_CASE(multi_assign)
{
CHECK(
"{ let a let b function f() -> x, y { } a, b := f() }",
"{ let a let b function f() -> x, y { } a, b := f() }"
);
}
BOOST_AUTO_TEST_SUITE_END()

View File

@ -32,6 +32,7 @@
#include <libjulia/optimiser/MainFunction.h>
#include <libjulia/optimiser/Rematerialiser.h>
#include <libjulia/optimiser/ExpressionSimplifier.h>
#include <libjulia/optimiser/UnusedPruner.h>
#include <libsolidity/parsing/Scanner.h>
#include <libsolidity/inlineasm/AsmPrinter.h>
@ -140,6 +141,11 @@ bool YulOptimizerTest::run(ostream& _stream, string const& _linePrefix, bool con
disambiguate();
(ExpressionSimplifier{})(*m_ast);
}
else if (m_optimizerStep == "unusedPruner")
{
disambiguate();
UnusedPruner::runUntilStabilised(*m_ast);
}
else
{
FormattedScope(_stream, _formatted, {formatting::BOLD, formatting::RED}) << _linePrefix << "Invalid optimizer step: " << m_optimizerStep << endl;

View File

@ -0,0 +1,8 @@
{
function f() { let a := 1 }
function g() { f() }
}
// ----
// unusedPruner
// {
// }

View File

@ -0,0 +1,11 @@
{
let a := 1
a := 4
let b := 1
}
// ----
// unusedPruner
// {
// let a := 1
// a := 4
// }

View File

@ -0,0 +1,16 @@
{
let a, b
function f() -> x { }
a := f()
b := 1
}
// ----
// unusedPruner
// {
// let a, b
// function f() -> x
// {
// }
// a := f()
// b := 1
// }

View File

@ -0,0 +1,16 @@
{
let a
let b
function f() -> x, y { }
a, b := f()
}
// ----
// unusedPruner
// {
// let a
// let b
// function f() -> x, y
// {
// }
// a, b := f()
// }

View File

@ -0,0 +1,12 @@
{
let x, y
x := 1
y := 2
}
// ----
// unusedPruner
// {
// let x, y
// x := 1
// y := 2
// }

View File

@ -0,0 +1,7 @@
{
let x, y
}
// ----
// unusedPruner
// {
// }

View File

@ -0,0 +1,12 @@
{
function f() -> x, y { }
let a, b := f()
}
// ----
// unusedPruner
// {
// function f() -> x, y
// {
// }
// let a, b := f()
// }

View File

@ -0,0 +1,10 @@
{
let x, y
x := 1
}
// ----
// unusedPruner
// {
// let x, y
// x := 1
// }

View File

@ -0,0 +1,5 @@
{ }
// ----
// unusedPruner
// {
// }

View File

@ -0,0 +1,10 @@
{
let a := 1
let b := 1
mstore(0, 1)
}
// ----
// unusedPruner
// {
// mstore(0, 1)
// }