mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
[yul-phaser] TestHelpers: Add TemporaryDirectory class
This commit is contained in:
parent
5e00b57e02
commit
5e814acc3c
@ -19,12 +19,18 @@
|
|||||||
|
|
||||||
#include <libyul/optimiser/Suite.h>
|
#include <libyul/optimiser/Suite.h>
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
|
||||||
#include <regex>
|
#include <regex>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace solidity;
|
using namespace solidity;
|
||||||
using namespace solidity::yul;
|
using namespace solidity::yul;
|
||||||
using namespace solidity::phaser;
|
using namespace solidity::phaser;
|
||||||
|
using namespace solidity::phaser::test;
|
||||||
|
|
||||||
|
namespace fs = boost::filesystem;
|
||||||
|
|
||||||
function<Mutation> phaser::test::wholeChromosomeReplacement(Chromosome _newChromosome)
|
function<Mutation> phaser::test::wholeChromosomeReplacement(Chromosome _newChromosome)
|
||||||
{
|
{
|
||||||
@ -71,6 +77,40 @@ size_t phaser::test::countDifferences(Chromosome const& _chromosome1, Chromosome
|
|||||||
return count + abs(static_cast<int>(_chromosome1.length() - _chromosome2.length()));
|
return count + abs(static_cast<int>(_chromosome1.length() - _chromosome2.length()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TemporaryDirectory::TemporaryDirectory(std::string const& _prefix):
|
||||||
|
m_path((fs::temp_directory_path() / fs::unique_path(_prefix + "%%%%-%%%%-%%%%-%%%%")).string())
|
||||||
|
{
|
||||||
|
// Prefix should just be a file name and not contain anything that would make us step out of /tmp.
|
||||||
|
assert(fs::path(_prefix) == fs::path(_prefix).stem());
|
||||||
|
|
||||||
|
fs::create_directory(m_path);
|
||||||
|
}
|
||||||
|
|
||||||
|
TemporaryDirectory::~TemporaryDirectory()
|
||||||
|
{
|
||||||
|
// A few paranoid sanity checks just to be extra sure we're not deleting someone's homework.
|
||||||
|
assert(m_path.find(fs::temp_directory_path().string()) == 0);
|
||||||
|
assert(fs::path(m_path) != fs::temp_directory_path());
|
||||||
|
assert(fs::path(m_path) != fs::path(m_path).root_path());
|
||||||
|
assert(!fs::path(m_path).empty());
|
||||||
|
|
||||||
|
boost::system::error_code errorCode;
|
||||||
|
uintmax_t numRemoved = fs::remove_all(m_path, errorCode);
|
||||||
|
if (errorCode.value() != boost::system::errc::success)
|
||||||
|
{
|
||||||
|
cerr << "Failed to completely remove temporary directory '" << m_path << "'. ";
|
||||||
|
cerr << "Only " << numRemoved << " files were actually removed." << endl;
|
||||||
|
cerr << "Reason: " << errorCode.message() << endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
string TemporaryDirectory::memberPath(string const& _relativePath) const
|
||||||
|
{
|
||||||
|
assert(fs::path(_relativePath).is_relative());
|
||||||
|
|
||||||
|
return (fs::path(m_path) / _relativePath).string();
|
||||||
|
}
|
||||||
|
|
||||||
string phaser::test::stripWhitespace(string const& input)
|
string phaser::test::stripWhitespace(string const& input)
|
||||||
{
|
{
|
||||||
regex whitespaceRegex("\\s+");
|
regex whitespaceRegex("\\s+");
|
||||||
|
@ -79,6 +79,31 @@ size_t countDifferences(Chromosome const& _chromosome1, Chromosome const& _chrom
|
|||||||
/// integers.
|
/// integers.
|
||||||
std::map<std::string, size_t> enumerateOptmisationSteps();
|
std::map<std::string, size_t> enumerateOptmisationSteps();
|
||||||
|
|
||||||
|
// FILESYSTEM UTILITIES
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An object that creates a unique temporary directory and automatically deletes it and its
|
||||||
|
* content upon being destroyed.
|
||||||
|
*
|
||||||
|
* The directory is guaranteed to be newly created and empty. Directory names are generated
|
||||||
|
* randomly. If a directory with the same name already exists (very unlikely but possible) the
|
||||||
|
* object won't reuse it and will fail with an exception instead.
|
||||||
|
*/
|
||||||
|
class TemporaryDirectory
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
TemporaryDirectory(std::string const& _prefix = "yul-phaser-test-");
|
||||||
|
~TemporaryDirectory();
|
||||||
|
|
||||||
|
std::string const& path() const { return m_path; }
|
||||||
|
|
||||||
|
/// Converts a path relative to the directory held by the object into an absolute one.
|
||||||
|
std::string memberPath(std::string const& _relativePath) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::string m_path;
|
||||||
|
};
|
||||||
|
|
||||||
// STRING UTILITIES
|
// STRING UTILITIES
|
||||||
|
|
||||||
/// Returns the input string with all the whitespace characters (spaces, line endings, etc.) removed.
|
/// Returns the input string with all the whitespace characters (spaces, line endings, etc.) removed.
|
||||||
|
@ -19,14 +19,18 @@
|
|||||||
|
|
||||||
#include <libyul/optimiser/Suite.h>
|
#include <libyul/optimiser/Suite.h>
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
#include <boost/test/unit_test.hpp>
|
#include <boost/test/unit_test.hpp>
|
||||||
|
|
||||||
|
#include <fstream>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace solidity::yul;
|
using namespace solidity::yul;
|
||||||
using namespace boost::test_tools;
|
using namespace boost::test_tools;
|
||||||
|
|
||||||
|
namespace fs = boost::filesystem;
|
||||||
|
|
||||||
namespace solidity::phaser::test
|
namespace solidity::phaser::test
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -114,6 +118,63 @@ BOOST_AUTO_TEST_CASE(enumerateOptimisationSteps_should_assing_indices_to_all_ava
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(TemporaryDirectory_should_create_and_delete_a_unique_and_empty_directory)
|
||||||
|
{
|
||||||
|
fs::path dirPath;
|
||||||
|
{
|
||||||
|
TemporaryDirectory tempDir("temporary-directory-test-");
|
||||||
|
dirPath = tempDir.path();
|
||||||
|
|
||||||
|
BOOST_TEST(dirPath.stem().string().find("temporary-directory-test-") == 0);
|
||||||
|
BOOST_TEST(fs::equivalent(dirPath.parent_path(), fs::temp_directory_path()));
|
||||||
|
BOOST_TEST(fs::is_directory(dirPath));
|
||||||
|
BOOST_TEST(fs::is_empty(dirPath));
|
||||||
|
}
|
||||||
|
BOOST_TEST(!fs::exists(dirPath));
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(TemporaryDirectory_should_delete_its_directory_even_if_not_empty)
|
||||||
|
{
|
||||||
|
fs::path dirPath;
|
||||||
|
{
|
||||||
|
TemporaryDirectory tempDir("temporary-directory-test-");
|
||||||
|
dirPath = tempDir.path();
|
||||||
|
|
||||||
|
BOOST_TEST(fs::is_directory(dirPath));
|
||||||
|
|
||||||
|
{
|
||||||
|
ofstream tmpFile((dirPath / "test-file.txt").string());
|
||||||
|
tmpFile << "Delete me!" << endl;
|
||||||
|
}
|
||||||
|
assert(fs::is_regular_file(dirPath / "test-file.txt"));
|
||||||
|
}
|
||||||
|
BOOST_TEST(!fs::exists(dirPath / "test-file.txt"));
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(TemporaryDirectory_memberPath_should_construct_paths_relative_to_the_temporary_directory)
|
||||||
|
{
|
||||||
|
TemporaryDirectory tempDir("temporary-directory-test-");
|
||||||
|
|
||||||
|
BOOST_TEST(fs::equivalent(tempDir.memberPath(""), tempDir.path()));
|
||||||
|
BOOST_TEST(fs::equivalent(tempDir.memberPath("."), tempDir.path() / fs::path(".")));
|
||||||
|
BOOST_TEST(fs::equivalent(tempDir.memberPath(".."), tempDir.path() / fs::path("..")));
|
||||||
|
|
||||||
|
// NOTE: fs::equivalent() only works with paths that actually exist
|
||||||
|
{
|
||||||
|
ofstream file;
|
||||||
|
file.open(tempDir.memberPath("file.txt"), ios::out);
|
||||||
|
}
|
||||||
|
BOOST_TEST(fs::equivalent(tempDir.memberPath("file.txt"), tempDir.path() / fs::path("file.txt")));
|
||||||
|
|
||||||
|
{
|
||||||
|
fs::create_directories(tempDir.memberPath("a/b/"));
|
||||||
|
|
||||||
|
ofstream file;
|
||||||
|
file.open(tempDir.memberPath("a/b/file.txt"), ios::out);
|
||||||
|
}
|
||||||
|
BOOST_TEST(fs::equivalent(tempDir.memberPath("a/b/file.txt"), tempDir.path() / fs::path("a") / fs::path("b") / fs::path("file.txt")));
|
||||||
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(stripWhitespace_should_remove_all_whitespace_characters_from_a_string)
|
BOOST_AUTO_TEST_CASE(stripWhitespace_should_remove_all_whitespace_characters_from_a_string)
|
||||||
{
|
{
|
||||||
BOOST_TEST(stripWhitespace("") == "");
|
BOOST_TEST(stripWhitespace("") == "");
|
||||||
|
Loading…
Reference in New Issue
Block a user