diff options
author | bloodstalker <thabogre@gmail.com> | 2020-08-21 06:57:17 +0000 |
---|---|---|
committer | bloodstalker <thabogre@gmail.com> | 2020-08-21 06:57:17 +0000 |
commit | 5e5495a1b588bc246d258a8a99facce4af2a9af3 (patch) | |
tree | 62db3195740fe91a1c1e4620e3204fae6430117b | |
parent | wip-tests (diff) | |
download | cgrep-5e5495a1b588bc246d258a8a99facce4af2a9af3.tar.gz cgrep-5e5495a1b588bc246d258a8a99facce4af2a9af3.zip |
test push
-rwxr-xr-x | testscript/main.py | 91 |
1 files changed, 49 insertions, 42 deletions
diff --git a/testscript/main.py b/testscript/main.py index 90b7737..67a3146 100755 --- a/testscript/main.py +++ b/testscript/main.py @@ -10,53 +10,57 @@ import re test_files = ["/home/bloodstalker/extra/cgrep/cgrep.cpp"] test_files_2 = [ - "./test/function.cpp", - "./test/fielddecl.cpp", - "./test/cxxmethoddecl.cpp", - "./test/vardecl.cpp", - "./test/classdecl.cpp", - "./test/structdecl.cpp", - "./test/uniondecdef.cpp", - "./test/nameddecldef.cpp", - "./test/declrefexpr.cpp", - "./test/callexpr.cpp", - "./test/cxxmembercallexpr.cpp", - ] + "./test/function.cpp", + "./test/fielddecl.cpp", + "./test/cxxmethoddecl.cpp", + "./test/vardecl.cpp", + "./test/classdecl.cpp", + "./test/structdecl.cpp", + "./test/uniondecdef.cpp", + "./test/nameddecldef.cpp", + "./test/declrefexpr.cpp", + "./test/callexpr.cpp", + "./test/cxxmembercallexpr.cpp", +] cgrep_test_args = [ - "-A 1 -B 1 --func --var --regex n[aA]m", - "-A 1 -B 1 --func --var --awk --regex n[aA]m", - "-A 1 -B 1 --func --declrefexpr --regex n[aA]m --nocolor", - "-A 1 -B 1 --func --declrefexpr --memfunc --call --cxxcall --var --regex run", - "-A 1 -B 1 --macro --header --regex n[aA]m", - "-A 1 -B 1 --class --regex and", - "-A 1 -B 1 --struct --union --regex n[aA]m", - "-A 1 -B 1 --nameddecl --regex n[aA]m", - "-A 1 -B 1 --cxxcall --call --regex add", - "-A 1 -B 1 --cfield --regex ite", - "--union --regex [Uu]nion ./test/main.cpp", - "--struct --regex [sS]truct ./test/main.cpp", - "--dir ./ --regex run --func",] + "-A 1 -B 1 --func --var --regex n[aA]m", + "-A 1 -B 1 --func --var --awk --regex n[aA]m", + "-A 1 -B 1 --func --declrefexpr --regex n[aA]m --nocolor", + "-A 1 -B 1 --func --declrefexpr --memfunc --call --cxxcall --var --regex run", + "-A 1 -B 1 --macro --header --regex n[aA]m", + "-A 1 -B 1 --class --regex and", + "-A 1 -B 1 --struct --union --regex n[aA]m", + "-A 1 -B 1 --nameddecl --regex n[aA]m", + "-A 1 -B 1 --cxxcall --call --regex add", + "-A 1 -B 1 --cfield --regex ite", + "--union --regex [Uu]nion ./test/main.cpp", + "--struct --regex [sS]truct ./test/main.cpp", + "--dir ./ --regex run --func", ] cgrep_test_args_2 = [ - "--func --regex test", - "--cxxfield --regex test", - "--memfunc --regex test", - "--var --regex test", - "--class --regex test", - "--struct --regex test", - "--union --regex test", - "--nameddecl --regex test", - "--declrefexpr --regex test", - "--call --regex test", - "--cxxcall --regex test", - ] + "--func --regex test", + "--cxxfield --regex test", + "--memfunc --regex test", + "--var --regex test", + "--class --regex test", + "--struct --regex test", + "--union --regex test", + "--nameddecl --regex test", + "--declrefexpr --regex test", + "--call --regex test", + "--cxxcall --regex test", +] + class Argparser(object): def __init__(self): parser = argparse.ArgumentParser() parser.add_argument("--string", type=str, help="string") - parser.add_argument("--bool", action="store_true", help="bool", default=False) + parser.add_argument("--capturereference", type=str, + help="capture a new reference for the test outputs using the current outputs") + parser.add_argument("--compare", action="store_true", + help="compare the current test results with the reference", default=False) self.args = parser.parse_args() @@ -81,19 +85,22 @@ def call_from_shell_pprint(command, *command_args): def call_from_shell_list_pprint(command_list): - print(call_from_list_shell(command_list).stdout.decode("utf-8")) + print(call_from_shell_list(command_list).stdout.decode("utf-8")) def main(): - argparser = Argparser() + # argparser = Argparser() cgrep_exe = "cgrep" os.chdir("../") # get LLVM libdir llvm_libdir = call_from_shell_list(["llvm-config", "--libdir"]) # get LLVM version. upstream builds can have extra unwanted text attached. - llvm_version = re.findall("[0-9]*\.[0-9]*\.[0-9]*", call_from_shell_list(["llvm-config", "--version"]).stdout.decode("utf-8")) + llvm_version = re.findall("[0-9]*\.[0-9]*\.[0-9]*", call_from_shell_list( + ["llvm-config", "--version"]).stdout.decode("utf-8")) # buld the magic sause. we dont wanna get stddef.h not found. - clang_builtin_headers = "--extra-arg=-I" + llvm_libdir.stdout.decode("utf-8")[:-1] + "/clang/" + llvm_version[0] + "/include" + clang_builtin_headers = "--extra-arg=-I" + \ + llvm_libdir.stdout.decode( + "utf-8")[:-1] + "/clang/" + llvm_version[0] + "/include" for cgrep_test_arg, cgrep_test_files in zip(cgrep_test_args_2, test_files_2): arg_list = cgrep_test_arg.split() arg_list.insert(0, cgrep_exe) |