3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-08-26 06:36:02 +00:00

Tests for --keep-going

This also changes the test Makefile to run `.check.py` files after
running the corresponding `.sby` file to allow more precise testing of
the keep going feature.
This commit is contained in:
Jannis Harder 2022-03-24 16:36:59 +01:00
parent 7824460e27
commit 2d3d96478a
11 changed files with 182 additions and 1 deletions

View file

@ -0,0 +1,27 @@
from check_output import *
src = "keepgoing_multi_step.sv"
for task in ["keepgoing_multi_step_bmc", "keepgoing_multi_step_prove"]:
assert_0 = line_ref(task, src, "assert(0)")
step_3_7 = line_ref(task, src, "step 3,7")
step_5 = line_ref(task, src, "step 5")
step_7 = line_ref(task, src, "step 7")
log = open(task + "/logfile.txt").read()
log_per_trace = log.split("Writing trace to VCD file")[:-1]
assert len(log_per_trace) == 4
assert re.search(r"Assert failed in test: %s \(.*\)$" % assert_0, log_per_trace[0], re.M)
for i in range(1, 4):
assert re.search(r"Assert failed in test: %s \(.*\) \[failed before\]$" % assert_0, log_per_trace[i], re.M)
assert re.search(r"Assert failed in test: %s \(.*\)$" % step_3_7, log_per_trace[1], re.M)
assert re.search(r"Assert failed in test: %s \(.*\)$" % step_5, log_per_trace[2], re.M)
assert re.search(r"Assert failed in test: %s \(.*\) \[failed before\]$" % step_3_7, log_per_trace[3], re.M)
assert re.search(r"Assert failed in test: %s \(.*\)$" % step_7, log_per_trace[3], re.M)