[ir-test]: Enhance ir-test for Linux and Windows

This is a series of enhancements for ir-test and related Makefile
for Linux and Windows.

UpdateLog:
1) Make ir-test run from any directory
2) add --help option and print program usage
3) Enable user to specify test folders and/or files to run
4) Check unsupported option and print help usage
5) Update Makefile to use new ir-test options
6) some code refactory

Signed-off-by: Tony Su <tao.su@intel.com>
Reviewed-by  : Dmitry Stogov
Reviewed-by  : Anatol Belski
This commit is contained in:
Tony Su 2023-04-17 15:13:05 +08:00
parent 1f7a2bd243
commit 4b9391c8b1
3 changed files with 87 additions and 30 deletions

View File

@ -91,10 +91,10 @@ test: $(BUILD_DIR)/ir $(BUILD_DIR)/ir-test
$(BUILD_DIR)/ir $(SRC_DIR)/test.ir --dump --save 2>$(BUILD_DIR)/test.log $(BUILD_DIR)/ir $(SRC_DIR)/test.ir --dump --save 2>$(BUILD_DIR)/test.log
$(BUILD_DIR)/ir $(SRC_DIR)/test.ir --dot $(BUILD_DIR)/ir.dot $(BUILD_DIR)/ir $(SRC_DIR)/test.ir --dot $(BUILD_DIR)/ir.dot
dot -Tpdf $(BUILD_DIR)/ir.dot -o $(BUILD_DIR)/ir.pdf dot -Tpdf $(BUILD_DIR)/ir.dot -o $(BUILD_DIR)/ir.pdf
BUILD_DIR=$(BUILD_DIR) SRC_DIR=$(SRC_DIR) $(BUILD_DIR)/ir-test $(BUILD_DIR)/ir-test $(SRC_DIR)/tests
test-ci: $(BUILD_DIR)/ir $(BUILD_DIR)/ir-test test-ci: $(BUILD_DIR)/ir $(BUILD_DIR)/ir-test
BUILD_DIR=$(BUILD_DIR) SRC_DIR=$(SRC_DIR) $(BUILD_DIR)/ir-test --show-diff $(BUILD_DIR)/ir-test --show-diff $(SRC_DIR)/tests
clean: clean:
rm -rf $(BUILD_DIR)/ir $(BUILD_DIR)/ir_test $(BUILD_DIR)/*.o \ rm -rf $(BUILD_DIR)/ir $(BUILD_DIR)/ir_test $(BUILD_DIR)/*.o \

View File

@ -12,8 +12,10 @@
#include <sstream> #include <sstream>
#include <filesystem> #include <filesystem>
#include <array> #include <array>
#include <set>
#include <exception> #include <exception>
#include <cstdlib> #include <cstdlib>
#include <cassert>
#ifdef _WIN32 #ifdef _WIN32
# include <windows.h> # include <windows.h>
@ -37,7 +39,8 @@ std::vector<std::string> bad_list;
std::vector<std::tuple<std::string, std::string>> failed; std::vector<std::tuple<std::string, std::string>> failed;
std::vector<std::tuple<std::string, std::string, std::string>> xfailed_list; std::vector<std::tuple<std::string, std::string, std::string>> xfailed_list;
bool show_diff = false, colorize = true; bool show_diff = false, colorize = true;
std::string src_dir, build_dir, test_dir, ir_exe, ir_target; std::string ir_exe, ir_target;
std::string this_exe, this_exe_path;
namespace ir { namespace ir {
decltype(auto) trim(std::string s) { decltype(auto) trim(std::string s) {
@ -60,12 +63,6 @@ namespace ir {
return result; return result;
} }
decltype(auto) get_dir_from_env(const char* name) {
const char* _tmp = std::getenv(name);
std::string ret = _tmp ? _tmp : ".";
return ret;
}
enum color { GREEN, YELLOW, RED }; enum color { GREEN, YELLOW, RED };
decltype(auto) colorize(const std::string& s, enum color c) { decltype(auto) colorize(const std::string& s, enum color c) {
@ -218,38 +215,102 @@ namespace ir {
} }
}; };
void find_tests_in_dir(std::string& test_dir, std::vector<std::string>& irt_files) { void find_tests_in_dir(std::set<std::string>& user_files, std::vector<std::string>& irt_files) {
for (const std::filesystem::directory_entry& ent : assert(user_files.size()>0);
std::filesystem::recursive_directory_iterator(test_dir)) {
std::string fl(ent.path().string()); for (const auto& f : user_files) {
if (fl.length() < 4 || 0 != fl.compare(fl.length()-4, 4, ".irt")) continue; if (std::filesystem::is_directory(f)) {
irt_files.push_back(fl); for (const std::filesystem::directory_entry& ent :
std::filesystem::recursive_directory_iterator(f)) {
std::string fl(ent.path().string());
if (fl.length() < 4 || ent.path().extension() != ".irt")
continue;
irt_files.push_back(fl);
}
} else {
irt_files.push_back(f);
}
} }
std::sort(irt_files.begin(), irt_files.end(), [&](const std::string& a, const std::string& b) {
return 1 <= b.compare(a); std::sort(irt_files.begin(),
}); irt_files.end(),
[&](const std::string& a, const std::string& b) {
return 1 <= b.compare(a);
});
} }
} }
static void print_help(void)
{
std::cout << "Run IR uint tests\n";
std::cout << "Usage:\n ";
std::cout << ::this_exe
<< " [--show-diff] [--no-color] [test folders or files...]\n";
std::cout << " Run all tests if no test folders/files are specified\n";
}
int main(int argc, char **argv) { int main(int argc, char **argv) {
// Save this executable path to infer ir executable path
::this_exe = argv[0];
::this_exe_path = std::filesystem::path{::this_exe}.parent_path().string();
// Store test folders/files specified by user
std::set<std::string> user_files;
bool bad_opt = false; // unsupported option given
bool bad_files = false; // bad file or folder given
for (int i = 1; i < argc; i++) { for (int i = 1; i < argc; i++) {
// XXX use some cleaner arg parsing solution // XXX use some cleaner arg parsing solution
if (!std::string(argv[i]).compare("--show-diff")) { if (!std::string(argv[i]).compare("--show-diff")) {
::show_diff = true; ::show_diff = true;
continue;
} else if (!std::string(argv[i]).compare("--no-color")) { } else if (!std::string(argv[i]).compare("--no-color")) {
::colorize = false; ::colorize = false;
continue;
} else if (!std::string(argv[i]).compare("--help")) {
print_help();
return 0;
} else if (std::string(argv[i]).find_first_of("-") == 0) {
// Unsupported options
bad_opt = true;
std::cerr << ir::colorize("ERROR", ir::RED)
<< ": Unsupported Option [" << argv[i] << "]\n";
} else {
// User specified test folders/files
std::string file = argv[i];
if (std::filesystem::exists(file)
&& (std::filesystem::is_directory(file)
|| std::filesystem::is_regular_file(file))) {
user_files.insert(argv[i]);
} else {
bad_files = true;
std::cerr << ir::colorize("ERROR", ir::RED)
<< ": Bad File or Folder [" << file << "] \n";
}
} }
} /* for: arguments iteration */
if (bad_opt || bad_files) {
if (bad_opt)
print_help();
return 1;
} }
ir::init_console(); ir::init_console();
::build_dir = ir::get_dir_from_env("BUILD_DIR"); ::ir_exe = ::this_exe_path + PATH_SEP + "ir" + EXE_SUF;
::src_dir = ir::get_dir_from_env("SRC_DIR");
::test_dir = ::src_dir + PATH_SEP + "tests";
::ir_exe = ::build_dir + PATH_SEP + "ir" + EXE_SUF;
::ir_target = ir::trim(ir::exec(::ir_exe + " --target")); ::ir_target = ir::trim(ir::exec(::ir_exe + " --target"));
std::vector<std::string> irt_files;
ir::find_tests_in_dir(::test_dir, irt_files); // Get test files, either specified by user or all tests by default
std::vector<std::string> irt_files;
if (user_files.empty()) {
// Pretend user specified all test
std::string tests_dir = ::this_exe_path + PATH_SEP + "tests";
user_files.insert(tests_dir);
}
ir::find_tests_in_dir(user_files, irt_files);
// Run each test
for (const std::string& test_fl : irt_files) { for (const std::string& test_fl : irt_files) {
try { try {
auto test = ir::test(test_fl); auto test = ir::test(test_fl);

View File

@ -118,15 +118,11 @@ $(BUILD_DIR)\ir-test.exe: $(SRC_DIR)/ir-test.cxx
test: $(BUILD_DIR)\ir.exe $(BUILD_DIR)\ir-test.exe test: $(BUILD_DIR)\ir.exe $(BUILD_DIR)\ir-test.exe
set PATH=$(VCPKG_DIR)\installed\$(VCPKG_TRIPLET)\bin:%%PATH%% set PATH=$(VCPKG_DIR)\installed\$(VCPKG_TRIPLET)\bin:%%PATH%%
$(BUILD_DIR)\ir.exe $(SRC_DIR)\test.ir --dump --save $(BUILD_DIR)\test.log $(BUILD_DIR)\ir.exe $(SRC_DIR)\test.ir --dump --save $(BUILD_DIR)\test.log
set BUILD_DIR=$(BUILD_DIR) $(BUILD_DIR)\ir-test.exe $(SRC_DIR)\tests
set SRC_DIR=$(SRC_DIR)
$(BUILD_DIR)\ir-test.exe
test-ci: $(BUILD_DIR)\ir.exe $(BUILD_DIR)\ir-test.exe test-ci: $(BUILD_DIR)\ir.exe $(BUILD_DIR)\ir-test.exe
set PATH=$(VCPKG_DIR)\installed\$(VCPKG_TRIPLET)\bin:%%PATH%% set PATH=$(VCPKG_DIR)\installed\$(VCPKG_TRIPLET)\bin:%%PATH%%
set BUILD_DIR=$(BUILD_DIR) $(BUILD_DIR)\ir-test.exe --show-diff $(SRC_DIR)\tests
set SRC_DIR=$(SRC_DIR)
$(BUILD_DIR)\ir-test.exe --show-diff
clean: clean:
del /f /q $(BUILD_DIR)\*.obj $(BUILD_DIR)\*.exe $(BUILD_DIR)\*.pdb $(BUILD_DIR)\*.ilk $(BUILD_DIR)\*.h del /f /q $(BUILD_DIR)\*.obj $(BUILD_DIR)\*.exe $(BUILD_DIR)\*.pdb $(BUILD_DIR)\*.ilk $(BUILD_DIR)\*.h