testr/testr.py

69 lines
1.9 KiB
Python
Raw Normal View History

2023-11-02 20:30:32 -04:00
import time
2023-11-02 16:02:06 -04:00
from colorama import just_fix_windows_console, Fore, Style
just_fix_windows_console()
2023-11-02 15:06:32 -04:00
import asyncio
from pathlib import Path
from testr.file_data import DirectorySuite, ExecutableRunner
2023-11-02 16:02:06 -04:00
from testr.runner import StatusCode, TestOptions
2023-10-14 21:13:37 -04:00
import argparse
parser = argparse.ArgumentParser()
2023-11-02 15:06:32 -04:00
test_runner_group = parser.add_mutually_exclusive_group(required=True)
test_data_group = parser.add_mutually_exclusive_group(required=True)
test_data_group.add_argument("--testdir", help="Directory for test cases")
test_runner_group.add_argument("--exec", help="Executable to run test cases against")
2023-11-02 15:23:09 -04:00
parser.add_argument("--timelim", help="Time limit in seconds", type=float, default=5.0)
2023-11-02 15:06:32 -04:00
args = parser.parse_args()
2023-11-02 15:23:09 -04:00
2023-11-02 16:02:06 -04:00
code_styles = {
StatusCode.AC: Fore.GREEN,
StatusCode.WA: Fore.RED,
StatusCode.IR: Fore.YELLOW,
StatusCode.TLE: Fore.YELLOW,
}
2023-11-02 15:06:32 -04:00
async def main():
2023-11-02 20:30:32 -04:00
start_time = time.perf_counter()
2023-11-02 15:06:32 -04:00
test_suite = DirectorySuite(Path(args.testdir))
test_runner = ExecutableRunner(Path(args.exec))
2023-11-02 20:30:32 -04:00
status_counts = { k: 0 for k in StatusCode }
test_case_count = 0
2023-11-02 15:23:09 -04:00
async for test_case in test_runner.run_test_suite(
test_suite,
TestOptions(
time_limit=args.timelim
)
):
2023-11-02 20:30:32 -04:00
test_case_count += 1
status_counts[test_case.code] += 1
2023-11-02 16:02:06 -04:00
print(
2023-11-02 20:30:32 -04:00
f"{test_case.test_data.name : <15} "
f"[ {code_styles.get(test_case.code, '')}{test_case.code.name}{Style.RESET_ALL} ]"
2023-11-02 16:02:06 -04:00
)
2023-11-02 15:06:32 -04:00
2023-11-02 20:30:32 -04:00
if test_case_count > 15:
print("\n Summary:\n")
for code in StatusCode:
if status_counts[code] > 0:
print(
f"{code_styles.get(code, '')}{code.name : >7}{Style.RESET_ALL}: "
f"x{status_counts[code]}"
)
print(f"\n Finished in{time.perf_counter() - start_time : .2f} seconds.\n")
2023-11-02 15:23:09 -04:00
2023-11-02 15:06:32 -04:00
if __name__ == "__main__":
asyncio.run(main())