mirror of
https://github.com/YosysHQ/sby.git
synced 2025-04-06 14:24: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:
|
if self.retcode == 16:
|
||||||
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
|
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
|
||||||
elif self.retcode != 0:
|
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)
|
print(f'</testcase>', file=f)
|
||||||
|
|
||||||
for check in checks:
|
for check in checks:
|
||||||
|
@ -814,11 +818,11 @@ class SbyTask:
|
||||||
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
|
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
|
||||||
print(f'</testcase>', file=f)
|
print(f'</testcase>', file=f)
|
||||||
else:
|
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)
|
print(f'<testcase classname="{junit_tc_name}" name="{junit_tc_name}" time="{self.total_time}">', file=f)
|
||||||
if junit_errors:
|
if junit_errors:
|
||||||
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
|
print(f'<error type="ERROR"/>', file=f) # type mandatory, message optional
|
||||||
elif junit_failures:
|
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'<failure type="{junit_type}" message="{self.status}" />', file=f)
|
||||||
print(f'</testcase>', file=f)
|
print(f'</testcase>', file=f)
|
||||||
print('<system-out>', end="", file=f)
|
print('<system-out>', end="", file=f)
|
||||||
|
|
1
tests/.gitignore
vendored
1
tests/.gitignore
vendored
|
@ -11,3 +11,4 @@
|
||||||
/submod_props*/
|
/submod_props*/
|
||||||
/multi_assert*/
|
/multi_assert*/
|
||||||
/aim_vs_smt2_nonzero_start_offset*/
|
/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_cover_pass junit_cover_uncovered junit_cover_assert junit_cover_preunsat \
|
||||||
junit_timeout_error_timeout junit_timeout_error_syntax junit_timeout_error_solver
|
junit_timeout_error_timeout junit_timeout_error_syntax junit_timeout_error_solver
|
||||||
|
|
||||||
.PHONY: test validate_junit
|
.PHONY: test validate_junit scripted
|
||||||
|
|
||||||
test: $(JUNIT_TESTS)
|
test: $(JUNIT_TESTS)
|
||||||
|
|
||||||
|
@ -14,4 +14,7 @@ test_%: %.sby FORCE
|
||||||
$(JUNIT_TESTS): $(SBY_TESTS)
|
$(JUNIT_TESTS): $(SBY_TESTS)
|
||||||
python3 validate_junit.py $@/$@.xml
|
python3 validate_junit.py $@/$@.xml
|
||||||
|
|
||||||
|
scripted:
|
||||||
|
make -C scripted
|
||||||
|
|
||||||
FORCE:
|
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