mirror of
https://github.com/YosysHQ/sby.git
synced 2025-10-24 01:44:37 +00:00
tests: Windows fixes
Make tests runnable on Windows, as long as a unix like environment as e.g. provided by MSYS2 is available.
This commit is contained in:
parent
ab98938faa
commit
ea7fc7dc2c
3 changed files with 50 additions and 16 deletions
|
@ -2,11 +2,27 @@ test:
|
||||||
|
|
||||||
.PHONY: test clean refresh help
|
.PHONY: test clean refresh help
|
||||||
|
|
||||||
|
OS_NAME := $(shell python3 -c "import os;print(os.name)")
|
||||||
|
ifeq (nt,$(OS_NAME))
|
||||||
|
ifeq (quoted,$(shell echo "quoted"))
|
||||||
|
OS_NAME := nt-unix-like
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq (nt,$(OS_NAME))
|
||||||
|
$(error This Makefile requires unix-like tools and shell, e.g. MSYS2.)
|
||||||
|
endif
|
||||||
|
|
||||||
help:
|
help:
|
||||||
@cat make/help.txt
|
@cat make/help.txt
|
||||||
|
|
||||||
export SBY_WORKDIR_GITIGNORE=1
|
export SBY_WORKDIR_GITIGNORE := 1
|
||||||
export SBY_MAIN=$(realpath $(dir $(firstword $(MAKEFILE_LIST)))/../sbysrc/sby.py)
|
|
||||||
|
SBY_MAIN := $(realpath $(dir $(firstword $(MAKEFILE_LIST)))/../sbysrc/sby.py)
|
||||||
|
ifeq (nt-unix-like,$(OS_NAME))
|
||||||
|
SBY_MAIN := $(shell cygpath -w $(SBY_MAIN))
|
||||||
|
endif
|
||||||
|
export SBY_MAIN
|
||||||
|
|
||||||
make/rules/collect.mk: make/collect_tests.py
|
make/rules/collect.mk: make/collect_tests.py
|
||||||
python3 make/collect_tests.py
|
python3 make/collect_tests.py
|
||||||
|
|
|
@ -4,7 +4,8 @@ import re
|
||||||
tests = []
|
tests = []
|
||||||
checked_dirs = []
|
checked_dirs = []
|
||||||
|
|
||||||
SAFE_PATH = re.compile(r"^[a-zA-Z0-9_./]*$")
|
SAFE_PATH = re.compile(r"^[a-zA-Z0-9_./\\]*$")
|
||||||
|
|
||||||
|
|
||||||
def collect(path):
|
def collect(path):
|
||||||
# don't pick up any paths that need escaping nor any sby workdirs
|
# don't pick up any paths that need escaping nor any sby workdirs
|
||||||
|
@ -15,8 +16,6 @@ def collect(path):
|
||||||
for entry in path.glob("*.sby"):
|
for entry in path.glob("*.sby"):
|
||||||
filename = str(entry)
|
filename = str(entry)
|
||||||
if not SAFE_PATH.match(filename):
|
if not SAFE_PATH.match(filename):
|
||||||
continue
|
|
||||||
if not re.match(r"^[a-zA-Z0-9_./]*$", filename):
|
|
||||||
print(f"skipping {filename!r}, use only [a-zA-Z0-9_./] in filenames")
|
print(f"skipping {filename!r}, use only [a-zA-Z0-9_./] in filenames")
|
||||||
continue
|
continue
|
||||||
tests.append(entry)
|
tests.append(entry)
|
||||||
|
@ -25,6 +24,10 @@ def collect(path):
|
||||||
collect(entry)
|
collect(entry)
|
||||||
|
|
||||||
|
|
||||||
|
def unix_path(path):
|
||||||
|
return "/".join(path.parts)
|
||||||
|
|
||||||
|
|
||||||
collect(Path("."))
|
collect(Path("."))
|
||||||
collect(Path("../docs/examples"))
|
collect(Path("../docs/examples"))
|
||||||
|
|
||||||
|
@ -33,16 +36,18 @@ out_file.parent.mkdir(exist_ok=True)
|
||||||
|
|
||||||
with out_file.open("w") as output:
|
with out_file.open("w") as output:
|
||||||
|
|
||||||
|
|
||||||
for checked_dir in checked_dirs:
|
for checked_dir in checked_dirs:
|
||||||
print(f"{out_file}: {checked_dir}", file=output)
|
print(f"{out_file}: {checked_dir}", file=output)
|
||||||
|
|
||||||
for test in tests:
|
for test in tests:
|
||||||
print(f"make/rules/test/{test}.mk: {test}", file=output)
|
test_unix = unix_path(test)
|
||||||
|
print(f"make/rules/test/{test_unix}.mk: {test_unix}", file=output)
|
||||||
for ext in [".sh", ".py"]:
|
for ext in [".sh", ".py"]:
|
||||||
script_file = test.parent / (test.stem + ext)
|
script_file = test.parent / (test.stem + ext)
|
||||||
if script_file.exists():
|
if script_file.exists():
|
||||||
print(f"make/rules/test/{test}.mk: {script_file}", file=output)
|
script_file_unix = unix_path(script_file)
|
||||||
print(f"make/rules/test/{test}.mk: make/test_rules.py", file=output)
|
print(f"make/rules/test/{test_unix}.mk: {script_file_unix}", file=output)
|
||||||
|
print(f"make/rules/test/{test_unix}.mk: make/test_rules.py", file=output)
|
||||||
for test in tests:
|
for test in tests:
|
||||||
print(f"-include make/rules/test/{test}.mk", file=output)
|
test_unix = unix_path(test)
|
||||||
|
print(f"-include make/rules/test/{test_unix}.mk", file=output)
|
||||||
|
|
|
@ -7,6 +7,11 @@ from pathlib import Path
|
||||||
|
|
||||||
from required_tools import REQUIRED_TOOLS
|
from required_tools import REQUIRED_TOOLS
|
||||||
|
|
||||||
|
|
||||||
|
def unix_path(path):
|
||||||
|
return "/".join(path.parts)
|
||||||
|
|
||||||
|
|
||||||
sby_file = Path(sys.argv[1])
|
sby_file = Path(sys.argv[1])
|
||||||
sby_dir = sby_file.parent
|
sby_dir = sby_file.parent
|
||||||
|
|
||||||
|
@ -56,7 +61,10 @@ with rules_file.open("w") as rules:
|
||||||
solvers.add(solver)
|
solvers.add(solver)
|
||||||
engine_solvers.add((engine, solver))
|
engine_solvers.add((engine, solver))
|
||||||
|
|
||||||
if any(line.startswith("read -verific") or line.startswith("verific") for line in info["script"]):
|
if any(
|
||||||
|
line.startswith("read -verific") or line.startswith("verific")
|
||||||
|
for line in info["script"]
|
||||||
|
):
|
||||||
required_tools.add("verific")
|
required_tools.add("verific")
|
||||||
|
|
||||||
required_tools = sorted(required_tools)
|
required_tools = sorted(required_tools)
|
||||||
|
@ -66,12 +74,17 @@ with rules_file.open("w") as rules:
|
||||||
|
|
||||||
shell_script = sby_dir / f"{sby_file.stem}.sh"
|
shell_script = sby_dir / f"{sby_file.stem}.sh"
|
||||||
|
|
||||||
if shell_script.exists():
|
sby_dir_unix = unix_path(sby_dir)
|
||||||
command = f"cd {sby_dir} && SBY_FILE={sby_file.name} WORKDIR={workdirname} TASK={task} bash {shell_script.name}"
|
|
||||||
else:
|
|
||||||
command = f"cd {sby_dir} && python3 $(SBY_MAIN) -f {sby_file.name} {task}"
|
|
||||||
|
|
||||||
print(f"\t@python3 make/required_tools.py run {target} {shlex.quote(command)} {shlex.join(required_tools)}", file=rules)
|
if shell_script.exists():
|
||||||
|
command = f"cd {sby_dir_unix} && env SBY_FILE={sby_file.name} WORKDIR={workdirname} TASK={task} bash {shell_script.name}"
|
||||||
|
else:
|
||||||
|
command = f"cd {sby_dir_unix} && python3 $(SBY_MAIN) -f {sby_file.name} {task}"
|
||||||
|
|
||||||
|
print(
|
||||||
|
f"\t@python3 make/required_tools.py run {target} {shlex.quote(command)} {shlex.join(required_tools)}",
|
||||||
|
file=rules,
|
||||||
|
)
|
||||||
|
|
||||||
print(f".PHONY: clean-{target}", file=rules)
|
print(f".PHONY: clean-{target}", file=rules)
|
||||||
print(f"clean-{target}:", file=rules)
|
print(f"clean-{target}:", file=rules)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue