aboutsummaryrefslogtreecommitdiffstats
path: root/tests/fsm/run-test.sh
blob: fbdcbf048f04da9eea8fa1598f345169da2d709c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#!/bin/bash

# run this test many times:
# time bash -c 'for ((i=0; i<100; i++)); do echo "-- $i --"; bash run-test.sh || exit 1; done'

set -e

OPTIND=1
count=50
seed=""    # default to no seed specified
while getopts "c:S:" opt
do
    case "$opt" in
	c) count="$OPTARG" ;;
	S) seed="-S $OPTARG" ;;
    esac
done
shift "$((OPTIND-1))"

rm -rf temp
mkdir -p temp
echo "generating tests.."
python3 generate.py -c $count $seed

{
	all_targets="all_targets:"
	echo "all: all_targets"
	echo "	@echo"
	for i in $( ls temp/*.ys | sed 's,[^0-9],,g; s,^0*\(.\),\1,g;' ); do
		idx=$( printf "%05d" $i )
		echo "temp/uut_${idx}.log: temp/uut_${idx}.ys temp/uut_${idx}.v"
		echo "	@echo -n '[$i]'"
		echo "	@../../yosys -ql temp/uut_${idx}.out temp/uut_${idx}.ys"
		echo "	@mv temp/uut_${idx}.out temp/uut_${idx}.log"
		echo "	@grep -q 'SAT proof finished' temp/uut_${idx}.log && echo -n K || echo -n T"
		all_targets="$all_targets temp/uut_${idx}.log"
	done
	echo "$all_targets"
} > temp/makefile

echo "running tests.."
${MAKE:-make} -f temp/makefile

exit 0