-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_one.sh
executable file
·37 lines (32 loc) · 976 Bytes
/
run_one.sh
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
#! /usr/bin/env bash
set -o errexit
set -o nounset
set -o xtrace
BASH_PROFILE=$HOME/.bash_profile
if [ -f "$BASH_PROFILE" ]; then
source $BASH_PROFILE
fi
TEST_LOG=run.log
TEST_DIR=test
cd $TEST_DIR
truncate -s 0 $TEST_LOG
FILES=`ls TestDmaCore.bsv`
###########################################################################
for FILE in $FILES; do
# echo $FILE
TESTCASES=`grep -Phzo 'doc.*?\nmodule\s+\S+(?=\()' $FILE | xargs -0 -I {} echo "{}" | grep module | cut -d ' ' -f 2`
for TESTCASE in $TESTCASES; do
make -j8 TESTFILE=$FILE TOPMODULE=$TESTCASE 2>&1 | tee -a $TEST_LOG
done
###########################################################################
done
###########################################################################
FAIL_KEYWORKS='Error\|ImmAssert'
grep -w $FAIL_KEYWORKS $TEST_LOG | cat
ERR_NUM=`grep -c -w $FAIL_KEYWORKS $TEST_LOG | cat`
if [ $ERR_NUM -gt 0 ]; then
echo "FAIL"
false
else
echo "PASS"
fi