mirror of https://github.com/YosysHQ/yosys.git
tests: Centralize test collection and Makefile generation
This commit is contained in:
parent
c6ff947f6b
commit
acd47bbd52
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash --yosys-args "-w 'Yosys has only limited support for tri-state logic at the moment.'"
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../../yosys -ql ${x%.ys}.log -w 'Yosys has only limited support for tri-state logic at the moment.' $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash --yosys-args "-w 'Yosys has only limited support for tri-state logic at the moment.'"
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../../yosys -ql ${x%.ys}.log -w 'Yosys has only limited support for tri-state logic at the moment.' $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash --yosys-args "-w 'Yosys has only limited support for tri-state logic at the moment.'"
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../../yosys -ql ${x%.ys}.log -w 'Yosys has only limited support for tri-state logic at the moment.' $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash --yosys-args "-w 'Yosys has only limited support for tri-state logic at the moment.'"
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../../yosys -ql ${x%.ys}.log -w 'Yosys has only limited support for tri-state logic at the moment.' $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash --yosys-args "-w 'Yosys has only limited support for tri-state logic at the moment.'"
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../../yosys -ql ${x%.ys}.log -w 'Yosys has only limited support for tri-state logic at the moment.' $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash --yosys-args "-w 'Yosys has only limited support for tri-state logic at the moment.'"
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../../yosys -ql ${x%.ys}.log -w 'Yosys has only limited support for tri-state logic at the moment.' $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash --yosys-args "-w 'Yosys has only limited support for tri-state logic at the moment.'"
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../../yosys -ql ${x%.ys}.log -w 'Yosys has only limited support for tri-state logic at the moment.' $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -0,0 +1,94 @@
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
YOSYS_BASEDIR="$(cd "$(dirname "${BASH_SOURCE[0]}")"/../ >/dev/null 2>&1 && pwd)"
|
||||||
|
|
||||||
|
# $ generate_target target_name test_command
|
||||||
|
generate_target() {
|
||||||
|
target_name=$1
|
||||||
|
test_command=$2
|
||||||
|
echo "all:: $target_name"
|
||||||
|
echo ".PHONY: $target_name"
|
||||||
|
echo "$target_name:"
|
||||||
|
printf "\t@%s\n" "$test_command"
|
||||||
|
printf "\t@echo 'Passed %s'\n" "$target_name"
|
||||||
|
}
|
||||||
|
|
||||||
|
# $ generate_ys_test ys_file [yosys_args]
|
||||||
|
generate_ys_test() {
|
||||||
|
ys_file=$1
|
||||||
|
yosys_args=${2:-}
|
||||||
|
generate_target "$ys_file" "$YOSYS_BASEDIR/yosys -ql ${ys_file%.*}.log $yosys_args $ys_file"
|
||||||
|
}
|
||||||
|
|
||||||
|
# $ generate_bash_test bash_file
|
||||||
|
generate_bash_test() {
|
||||||
|
bash_file=$1
|
||||||
|
generate_target "$bash_file" "bash -v $bash_file >${bash_file%.*}.log 2>&1"
|
||||||
|
}
|
||||||
|
|
||||||
|
# $ generate_tests [-y|--yosys-scripts] [-s|--prove-sv] [-b|--bash] [-a|--yosys-args yosys_args]
|
||||||
|
generate_tests() {
|
||||||
|
do_ys=false
|
||||||
|
do_sv=false
|
||||||
|
do_sh=false
|
||||||
|
yosys_args=""
|
||||||
|
|
||||||
|
while [[ $# -gt 0 ]]; do
|
||||||
|
arg="$1"
|
||||||
|
case "$arg" in
|
||||||
|
-y|--yosys-scripts)
|
||||||
|
do_ys=true
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-s|--prove-sv)
|
||||||
|
do_sv=true
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-b|--bash)
|
||||||
|
do_sh=true
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-a|--yosys-args)
|
||||||
|
yosys_args+="$2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo >&2 "Unknown argument: $1"
|
||||||
|
exit 1
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if [[ ! ( $do_ys = true || $do_sv = true || $do_sh = true ) ]]; then
|
||||||
|
echo >&2 "Error: No file types selected"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo ".PHONY: all"
|
||||||
|
echo "all::"
|
||||||
|
|
||||||
|
if [[ $do_ys = true ]]; then
|
||||||
|
for x in *.ys; do
|
||||||
|
generate_ys_test "$x" "$yosys_args"
|
||||||
|
done
|
||||||
|
fi;
|
||||||
|
if [[ $do_sv = true ]]; then
|
||||||
|
for x in *.sv; do
|
||||||
|
if [ ! -f "${x%.sv}.ys" ]; then
|
||||||
|
generate_ys_test "$x" "-p \"prep -top top; sat -verify -prove-asserts\" $yosys_args"
|
||||||
|
fi;
|
||||||
|
done
|
||||||
|
fi;
|
||||||
|
if [[ $do_sh == true ]]; then
|
||||||
|
for s in *.sh; do
|
||||||
|
if [ "$s" != "run-test.sh" ]; then
|
||||||
|
generate_bash_test "$s"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
run_tests() {
|
||||||
|
generate_tests "$@" > run-test.mk
|
||||||
|
exec ${MAKE:-make} -f run-test.mk
|
||||||
|
}
|
|
@ -1,6 +1,4 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
set -e
|
set -eu
|
||||||
for x in *.ys; do
|
source ../gen-tests-makefile.sh
|
||||||
echo "Running $x.."
|
run_tests --yosys-scripts
|
||||||
../../yosys -ql ${x%.ys}.log $x
|
|
||||||
done
|
|
||||||
|
|
|
@ -1,6 +1,4 @@
|
||||||
#!/bin/bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
for x in *.ys; do
|
source ../gen-tests-makefile.sh
|
||||||
echo "Running $x.."
|
run_tests --yosys-scripts
|
||||||
../../yosys -ql ${x%.ys}.log $x
|
|
||||||
done
|
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --prove-sv
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../yosys -ql ${x%.ys}.log $x"
|
|
||||||
done
|
|
||||||
for x in *.sv; do
|
|
||||||
if [ ! -f "${x%.sv}.ys" ]; then
|
|
||||||
echo "all:: check-$x"
|
|
||||||
echo "check-$x:"
|
|
||||||
echo " @echo 'Checking $x..'"
|
|
||||||
echo " @../../yosys -ql ${x%.sv}.log -p \"prep -top top; sat -verify -prove-asserts\" $x"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
set -ev
|
set -e
|
||||||
|
|
||||||
../../yosys -b 'verilog -noattr' -o mem_simple_4x1_synth.v -p 'proc; opt; memory -nomap; techmap -map mem_simple_4x1_map.v;; techmap; opt; abc;; stat' mem_simple_4x1_uut.v
|
../../yosys -b 'verilog -noattr' -o mem_simple_4x1_synth.v -p 'proc; opt; memory -nomap; techmap -map mem_simple_4x1_map.v;; techmap; opt; abc;; stat' mem_simple_4x1_uut.v
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,3 @@
|
||||||
set -ev
|
set -e
|
||||||
|
|
||||||
../../yosys -p 'hierarchy -top top; techmap -map recursive_map.v -max_iter 1; select -assert-count 2 t:sub; select -assert-count 2 t:bar' recursive.v
|
../../yosys -p 'hierarchy -top top; techmap -map recursive_map.v -max_iter 1; select -assert-count 2 t:sub; select -assert-count 2 t:bar' recursive.v
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash --yosys-args "-e 'select out of bounds'"
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../yosys -ql ${x%.ys}.log -e 'select out of bounds' $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s > ${s%.sh}.log 2>&1"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../yosys -ql ${x%.ys}.log $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
|
@ -1,20 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -eu
|
||||||
{
|
source ../gen-tests-makefile.sh
|
||||||
echo "all::"
|
run_tests --yosys-scripts --bash
|
||||||
for x in *.ys; do
|
|
||||||
echo "all:: run-$x"
|
|
||||||
echo "run-$x:"
|
|
||||||
echo " @echo 'Running $x..'"
|
|
||||||
echo " @../../yosys -ql ${x%.ys}.log $x"
|
|
||||||
done
|
|
||||||
for s in *.sh; do
|
|
||||||
if [ "$s" != "run-test.sh" ]; then
|
|
||||||
echo "all:: run-$s"
|
|
||||||
echo "run-$s:"
|
|
||||||
echo " @echo 'Running $s..'"
|
|
||||||
echo " @bash $s"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
} > run-test.mk
|
|
||||||
exec ${MAKE:-make} -f run-test.mk
|
|
||||||
|
|
Loading…
Reference in New Issue