2021-07-10 11:43:53 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
import argparse, datetime, os, subprocess, sys, shutil
|
|
|
|
from pathlib import Path
|
|
|
|
|
|
|
|
parser = argparse.ArgumentParser(description="OpenMW integration tests.")
|
|
|
|
parser.add_argument(
|
|
|
|
"example_suite",
|
|
|
|
type=str,
|
|
|
|
help="path to openmw example suite (use 'git clone https://gitlab.com/OpenMW/example-suite/' to get it)",
|
|
|
|
)
|
|
|
|
parser.add_argument("--omw", type=str, default="openmw", help="path to openmw binary")
|
|
|
|
parser.add_argument(
|
|
|
|
"--workdir", type=str, default="integration_tests_output", help="directory for temporary files and logs"
|
|
|
|
)
|
2023-12-24 20:25:07 +00:00
|
|
|
parser.add_argument("--verbose", action='store_true', help="print all openmw output")
|
2021-07-10 11:43:53 +00:00
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
example_suite_dir = Path(args.example_suite).resolve()
|
2024-06-24 22:44:39 +00:00
|
|
|
|
|
|
|
content_paths = (
|
|
|
|
example_suite_dir / "game_template" / "data" / "template.omwgame",
|
|
|
|
example_suite_dir / "example_animated_creature" / "data" / "landracer.omwaddon",
|
2024-08-17 13:09:00 +00:00
|
|
|
example_suite_dir / "the_hub" / "data" / "the_hub.omwaddon",
|
2024-06-24 22:44:39 +00:00
|
|
|
)
|
|
|
|
for path in content_paths:
|
|
|
|
if not path.is_file():
|
|
|
|
sys.exit(f"{path} is not found, use 'git clone https://gitlab.com/OpenMW/example-suite/' to get it")
|
2021-07-10 11:43:53 +00:00
|
|
|
|
|
|
|
openmw_binary = Path(args.omw).resolve()
|
|
|
|
if not openmw_binary.is_file():
|
|
|
|
sys.exit(f"{openmw_binary} not found")
|
|
|
|
|
|
|
|
work_dir = Path(args.workdir).resolve()
|
|
|
|
work_dir.mkdir(parents=True, exist_ok=True)
|
|
|
|
config_dir = work_dir / "config"
|
|
|
|
userdata_dir = work_dir / "userdata"
|
|
|
|
tests_dir = Path(__file__).resolve().parent / "data" / "integration_tests"
|
2022-10-10 21:39:32 +00:00
|
|
|
testing_util_dir = tests_dir / "testing_util"
|
2021-07-10 11:43:53 +00:00
|
|
|
time_str = datetime.datetime.now().strftime("%Y-%m-%d-%H.%M.%S")
|
|
|
|
|
|
|
|
|
|
|
|
def runTest(name):
|
|
|
|
print(f"Start {name}")
|
|
|
|
shutil.rmtree(config_dir, ignore_errors=True)
|
|
|
|
config_dir.mkdir()
|
|
|
|
shutil.copyfile(example_suite_dir / "settings.cfg", config_dir / "settings.cfg")
|
|
|
|
test_dir = tests_dir / name
|
|
|
|
with open(config_dir / "openmw.cfg", "w", encoding="utf-8") as omw_cfg:
|
2024-06-24 22:44:39 +00:00
|
|
|
for path in content_paths:
|
|
|
|
omw_cfg.write(f'data="{path.parent}"\n')
|
2021-07-10 11:43:53 +00:00
|
|
|
omw_cfg.writelines(
|
|
|
|
(
|
2022-10-10 21:39:32 +00:00
|
|
|
f'data="{testing_util_dir}"\n',
|
2021-07-10 11:43:53 +00:00
|
|
|
f'data-local="{test_dir}"\n',
|
|
|
|
f'user-data="{userdata_dir}"\n',
|
|
|
|
)
|
|
|
|
)
|
2024-06-24 22:44:39 +00:00
|
|
|
for path in content_paths:
|
|
|
|
omw_cfg.write(f'content={path.name}\n')
|
2023-06-12 14:20:36 +00:00
|
|
|
if (test_dir / "openmw.cfg").exists():
|
|
|
|
omw_cfg.write(open(test_dir / "openmw.cfg").read())
|
|
|
|
elif (test_dir / "test.omwscripts").exists():
|
2021-07-10 11:43:53 +00:00
|
|
|
omw_cfg.write("content=test.omwscripts\n")
|
2022-06-05 23:10:33 +00:00
|
|
|
with open(config_dir / "settings.cfg", "a", encoding="utf-8") as settings_cfg:
|
|
|
|
settings_cfg.write(
|
|
|
|
"[Video]\n"
|
|
|
|
"resolution x = 640\n"
|
|
|
|
"resolution y = 480\n"
|
|
|
|
"framerate limit = 60\n"
|
2024-07-20 21:56:55 +00:00
|
|
|
"[Game]\n"
|
2024-07-20 19:15:17 +00:00
|
|
|
"smooth animation transitions = true\n"
|
2024-08-03 10:55:24 +00:00
|
|
|
"[Lua]\n"
|
2024-08-08 20:34:48 +00:00
|
|
|
f"memory limit = {1024 * 1024 * 256}\n"
|
2022-06-05 23:10:33 +00:00
|
|
|
)
|
|
|
|
stdout_lines = list()
|
|
|
|
exit_ok = True
|
|
|
|
test_success = True
|
2021-07-10 11:43:53 +00:00
|
|
|
with subprocess.Popen(
|
2022-06-05 23:10:33 +00:00
|
|
|
[openmw_binary, "--replace=config", "--config", config_dir, "--skip-menu", "--no-grab", "--no-sound"],
|
2021-07-10 11:43:53 +00:00
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
stderr=subprocess.STDOUT,
|
|
|
|
encoding="utf-8",
|
2022-06-05 23:10:33 +00:00
|
|
|
env={
|
2023-03-01 22:30:19 +00:00
|
|
|
"OPENMW_OSG_STATS_FILE": str(work_dir / f"{name}.{time_str}.osg_stats.log"),
|
2022-06-05 23:10:33 +00:00
|
|
|
"OPENMW_OSG_STATS_LIST": "times",
|
|
|
|
**os.environ,
|
|
|
|
},
|
2021-07-10 11:43:53 +00:00
|
|
|
) as process:
|
|
|
|
quit_requested = False
|
|
|
|
for line in process.stdout:
|
2023-12-24 20:25:07 +00:00
|
|
|
if args.verbose:
|
|
|
|
sys.stdout.write(line)
|
|
|
|
else:
|
|
|
|
stdout_lines.append(line)
|
2021-07-10 11:43:53 +00:00
|
|
|
words = line.split(" ")
|
|
|
|
if len(words) > 1 and words[1] == "E]":
|
|
|
|
print(line, end="")
|
|
|
|
elif "Quit requested by a Lua script" in line:
|
|
|
|
quit_requested = True
|
|
|
|
elif "TEST_START" in line:
|
|
|
|
w = line.split("TEST_START")[1].split("\t")
|
|
|
|
print(f"TEST {w[2].strip()}\t\t", end="")
|
|
|
|
elif "TEST_OK" in line:
|
|
|
|
print(f"OK")
|
|
|
|
elif "TEST_FAILED" in line:
|
|
|
|
w = line.split("TEST_FAILED")[1].split("\t")
|
|
|
|
print(f"FAILED {w[3]}\t\t")
|
2022-06-05 23:10:33 +00:00
|
|
|
test_success = False
|
2021-07-10 11:43:53 +00:00
|
|
|
process.wait(5)
|
|
|
|
if not quit_requested:
|
|
|
|
print("ERROR: Unexpected termination")
|
2022-06-05 23:10:33 +00:00
|
|
|
exit_ok = False
|
|
|
|
if process.returncode != 0:
|
|
|
|
print(f"ERROR: openmw exited with code {process.returncode}")
|
|
|
|
exit_ok = False
|
|
|
|
if os.path.exists(config_dir / "openmw.log"):
|
|
|
|
shutil.copyfile(config_dir / "openmw.log", work_dir / f"{name}.{time_str}.log")
|
2023-12-24 20:25:07 +00:00
|
|
|
if not exit_ok and not args.verbose:
|
2022-06-05 23:10:33 +00:00
|
|
|
sys.stdout.writelines(stdout_lines)
|
|
|
|
if test_success and exit_ok:
|
|
|
|
print(f"{name} succeeded")
|
|
|
|
else:
|
|
|
|
print(f"{name} failed")
|
|
|
|
return test_success and exit_ok
|
2021-07-10 11:43:53 +00:00
|
|
|
|
|
|
|
|
2022-06-05 23:10:33 +00:00
|
|
|
status = 0
|
2021-07-10 11:43:53 +00:00
|
|
|
for entry in tests_dir.glob("test_*"):
|
|
|
|
if entry.is_dir():
|
2022-06-05 23:10:33 +00:00
|
|
|
if not runTest(entry.name):
|
|
|
|
status = -1
|
2024-06-24 22:48:43 +00:00
|
|
|
if status == 0:
|
|
|
|
shutil.rmtree(config_dir, ignore_errors=True)
|
|
|
|
shutil.rmtree(userdata_dir, ignore_errors=True)
|
2022-06-05 23:10:33 +00:00
|
|
|
exit(status)
|