3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-04-05 22:14:08 +00:00

note unexpected return statuses in junit

This commit is contained in:
N. Engelhardt 2022-03-29 19:10:29 +02:00
parent adacad7908
commit 008d020c4d
7 changed files with 44 additions and 3 deletions

View file

@ -788,7 +788,11 @@ class SbyTask:
if self.retcode == 16:
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
elif self.retcode != 0:
print(f'<failure type="{junit_type}" message="{self.status}" />', file=f)
if len(self.expect) > 1 or "PASS" not in self.expect:
expected = " ".join(self.expect)
print(f'<failure type="EXPECT" message="Task returned status {self.status}. Expected values were: {expected}" />', file=f)
else:
print(f'<failure type="{self.status}" message="Task returned status {self.status}." />', file=f)
print(f'</testcase>', file=f)
for check in checks:
@ -814,11 +818,11 @@ class SbyTask:
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
print(f'</testcase>', file=f)
else:
junit_type = "assert" if self.opt_mode in ["bmc", "prove"] else self.opt_mode
print(f'<testcase classname="{junit_tc_name}" name="{junit_tc_name}" time="{self.total_time}">', file=f)
if junit_errors:
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
elif junit_failures:
junit_type = "assert" if self.opt_mode in ["bmc", "prove"] else self.opt_mode
print(f'<failure type="{junit_type}" message="{self.status}" />', file=f)
print(f'</testcase>', file=f)
print('<system-out>', end="", file=f)

1
tests/.gitignore vendored
View file

@ -11,3 +11,4 @@
/submod_props*/
/multi_assert*/
/aim_vs_smt2_nonzero_start_offset*/
/2props1trace*/

View file

@ -4,7 +4,7 @@ JUNIT_TESTS=junit_assert_pass junit_assert_fail junit_assert_preunsat \
junit_cover_pass junit_cover_uncovered junit_cover_assert junit_cover_preunsat \
junit_timeout_error_timeout junit_timeout_error_syntax junit_timeout_error_solver
.PHONY: test validate_junit
.PHONY: test validate_junit scripted
test: $(JUNIT_TESTS)
@ -14,4 +14,7 @@ test_%: %.sby FORCE
$(JUNIT_TESTS): $(SBY_TESTS)
python3 validate_junit.py $@/$@.xml
scripted:
make -C scripted
FORCE:

1
tests/scripted/.gitignore vendored Normal file
View file

@ -0,0 +1 @@
/junit_*/

11
tests/scripted/Makefile Normal file
View file

@ -0,0 +1,11 @@
SH_FILES=$(wildcard *.sh)
SH_TESTS=$(addprefix test_,$(SH_FILES:.sh=))
test: $(SH_TESTS)
test_%: %.sh FORCE
bash $<
FORCE:
.PHONY: test FORCE

View file

@ -0,0 +1,16 @@
[options]
mode bmc
depth 1
expect fail,timeout
[engines]
smtbmc
[script]
read -formal foo.v
prep -top foo
[file foo.v]
module foo;
always_comb assert(1);
endmodule

View file

@ -0,0 +1,5 @@
#!/bin/bash
# this is expected to return 1 so don't use 'set -e'
python3 ../../sbysrc/sby.py -f junit_expect.sby
grep '<failure type="EXPECT" message="Task returned status PASS. Expected values were: FAIL TIMEOUT" />' junit_expect/junit_expect.xml