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:
parent
adacad7908
commit
008d020c4d
|
@ -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
1
tests/.gitignore
vendored
|
@ -11,3 +11,4 @@
|
|||
/submod_props*/
|
||||
/multi_assert*/
|
||||
/aim_vs_smt2_nonzero_start_offset*/
|
||||
/2props1trace*/
|
||||
|
|
|
@ -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
1
tests/scripted/.gitignore
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
/junit_*/
|
11
tests/scripted/Makefile
Normal file
11
tests/scripted/Makefile
Normal 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
|
16
tests/scripted/junit_expect.sby
Normal file
16
tests/scripted/junit_expect.sby
Normal 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
|
5
tests/scripted/junit_expect.sh
Normal file
5
tests/scripted/junit_expect.sh
Normal 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
|
Loading…
Reference in a new issue