1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
/*************************************************************************
* Copyright (C) 2018-2022 Blue Brain Project
*
* This file is part of NMODL distributed under the terms of the GNU
* Lesser General Public License. See top-level LICENSE file for details.
*************************************************************************/
#include <catch2/catch_test_macros.hpp>
#include "ast/program.hpp"
#include "parser/nmodl_driver.hpp"
#include "test/unit/utils/nmodl_constructs.hpp"
#include "test/unit/utils/test_utils.hpp"
#include "utils/common_utils.hpp"
#include "visitors/checkparent_visitor.hpp"
#include "visitors/nmodl_visitor.hpp"
using namespace nmodl;
using namespace visitor;
using namespace test;
using namespace test_utils;
using nmodl::parser::NmodlDriver;
//=============================================================================
// AST to NMODL printer tests
//=============================================================================
std::string run_nmodl_visitor(const std::string& text) {
NmodlDriver driver;
const auto& ast = driver.parse_string(text);
std::stringstream stream;
NmodlPrintVisitor(stream).visit_program(*ast);
// check that, after visitor rearrangement, parents are still up-to-date
CheckParentVisitor().check_ast(*ast);
return stream.str();
}
SCENARIO("Convert AST back to NMODL form", "[visitor][nmodl]") {
TempFile unit("Unit.inc", nmodl_valid_constructs.at("unit_statement_1").input);
for (const auto& construct: nmodl_valid_constructs) {
auto test_case = construct.second;
const std::string& input_nmodl_text = reindent_text(test_case.input);
const std::string& output_nmodl_text = reindent_text(test_case.output);
GIVEN(test_case.name) {
THEN("Visitor successfully returns : " + input_nmodl_text) {
auto result = run_nmodl_visitor(input_nmodl_text);
REQUIRE(result == output_nmodl_text);
}
}
}
}
|