aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-10-10 22:00:58 +0800
committerGitHub <noreply@github.com>2018-10-10 22:00:58 +0800
commit5b5a4d0172bb0d3cd9fb49aaf23fa8cbb63548c0 (patch)
tree83548812a8e52d408508cb07791f63078d4785fc /test
parent62fb0e29c9177996b75cd49cbd4237256dc8111e (diff)
parent212a6e146a48e85907907bfa8a111c26e5b52b4b (diff)
downloaddexon-solidity-5b5a4d0172bb0d3cd9fb49aaf23fa8cbb63548c0.tar
dexon-solidity-5b5a4d0172bb0d3cd9fb49aaf23fa8cbb63548c0.tar.gz
dexon-solidity-5b5a4d0172bb0d3cd9fb49aaf23fa8cbb63548c0.tar.bz2
dexon-solidity-5b5a4d0172bb0d3cd9fb49aaf23fa8cbb63548c0.tar.lz
dexon-solidity-5b5a4d0172bb0d3cd9fb49aaf23fa8cbb63548c0.tar.xz
dexon-solidity-5b5a4d0172bb0d3cd9fb49aaf23fa8cbb63548c0.tar.zst
dexon-solidity-5b5a4d0172bb0d3cd9fb49aaf23fa8cbb63548c0.zip
Merge pull request #5134 from ethereum/fuzzer-input-file
solfuzzer: adds --input-file=FILENAME command line argument (defaulting to stdin)
Diffstat (limited to 'test')
-rw-r--r--test/tools/fuzzer.cpp38
1 files changed, 27 insertions, 11 deletions
diff --git a/test/tools/fuzzer.cpp b/test/tools/fuzzer.cpp
index f7b42b25..bb020f8c 100644
--- a/test/tools/fuzzer.cpp
+++ b/test/tools/fuzzer.cpp
@@ -28,6 +28,7 @@
#include <boost/program_options.hpp>
#include <string>
+#include <sstream>
#include <iostream>
using namespace std;
@@ -48,15 +49,17 @@ string contains(string const& _haystack, vector<string> const& _needles)
return "";
}
-void testConstantOptimizer()
+void testConstantOptimizer(string const& input)
{
if (!quiet)
cout << "Testing constant optimizer" << endl;
vector<u256> numbers;
- while (!cin.eof())
+ stringstream sin(input);
+
+ while (!sin.eof())
{
h256 data;
- cin.read(reinterpret_cast<char*>(data.data()), 32);
+ sin.read(reinterpret_cast<char*>(data.data()), 32);
numbers.push_back(u256(data));
}
if (!quiet)
@@ -108,20 +111,18 @@ void runCompiler(string input)
}
}
-void testStandardCompiler()
+void testStandardCompiler(string const& input)
{
if (!quiet)
cout << "Testing compiler via JSON interface." << endl;
- string input = readStandardInput();
runCompiler(input);
}
-void testCompiler(bool optimize)
+void testCompiler(string const& input, bool optimize)
{
if (!quiet)
cout << "Testing compiler " << (optimize ? "with" : "without") << " optimizer." << endl;
- string input = readStandardInput();
Json::Value config = Json::objectValue;
config["language"] = "Solidity";
@@ -168,15 +169,24 @@ Allowed options)",
"Expects a binary string of up to 32 bytes on stdin."
)
(
+ "input-file",
+ po::value<string>(),
+ "input file"
+ )
+ (
"without-optimizer",
"Run without optimizations. Cannot be used together with standard-json."
);
+ // All positional options should be interpreted as input files
+ po::positional_options_description filesPositions;
+ filesPositions.add("input-file", 1);
+
po::variables_map arguments;
try
{
po::command_line_parser cmdLineParser(argc, argv);
- cmdLineParser.options(options);
+ cmdLineParser.options(options).positional(filesPositions);
po::store(cmdLineParser.run(), arguments);
}
catch (po::error const& _exception)
@@ -185,17 +195,23 @@ Allowed options)",
return 1;
}
+ string input;
+ if (arguments.count("input-file"))
+ input = readFileAsString(arguments["input-file"].as<string>());
+ else
+ input = readStandardInput();
+
if (arguments.count("quiet"))
quiet = true;
if (arguments.count("help"))
cout << options;
else if (arguments.count("const-opt"))
- testConstantOptimizer();
+ testConstantOptimizer(input);
else if (arguments.count("standard-json"))
- testStandardCompiler();
+ testStandardCompiler(input);
else
- testCompiler(!arguments.count("without-optimizer"));
+ testCompiler(input, !arguments.count("without-optimizer"));
return 0;
}