/* KLayout Layout Viewer Copyright (C) 2006-2019 Matthias Koefferlein This program 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 2 of the License, or (at your option) any later version. This program 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 this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ #include "tlUnitTest.h" #include "dbReader.h" #include "dbTestSupport.h" #include "dbNetlist.h" #include "dbNetlistSpiceReader.h" #include "lymMacro.h" #include "tlFileUtils.h" void run_test (tl::TestBase *_this, const std::string &suffix, const std::string &layout, bool with_l2n = false, bool with_lvsdb = false) { std::string rs = tl::testsrc (); rs += "/testdata/lvs/" + suffix + ".lvs"; std::string src = tl::testsrc (); src += "/testdata/lvs/" + layout; std::string au_lvsdb = tl::testsrc (); au_lvsdb += "/testdata/lvs/" + suffix + ".lvsdb.gz"; std::string au_cir = tl::testsrc (); au_cir += "/testdata/lvs/" + suffix + ".cir.gz"; std::string au_l2n = tl::testsrc (); au_l2n += "/testdata/lvs/" + suffix + ".l2n.gz"; std::string output_lvsdb = _this->tmp_file ("tmp.lvsdb"); std::string output_cir = _this->tmp_file ("tmp.cir"); std::string output_l2n = _this->tmp_file ("tmp.l2n"); { // Set some variables lym::Macro config; config.set_text (tl::sprintf ( "$lvs_test_source = '%s'\n" "$lvs_test_target_lvsdb = '%s'\n" "$lvs_test_target_cir = '%s'\n" "$lvs_test_target_l2n = '%s'\n" , src, output_lvsdb, output_cir, output_l2n) ); config.set_interpreter (lym::Macro::Ruby); EXPECT_EQ (config.run (), 0); } lym::Macro lvs; lvs.load_from (rs); EXPECT_EQ (lvs.run (), 0); _this->compare_text_files (output_cir, au_cir); if (with_lvsdb) { _this->compare_text_files (output_lvsdb, au_lvsdb); } if (with_l2n) { _this->compare_text_files (output_l2n, au_l2n); } } TEST(1_full) { run_test (_this, "vexriscv", "vexriscv.oas.gz"); }