#!/bin/sh
src_dir=$1
run=$2
date=$3
src_file=$src_dir/report.txt
if [ ! -f $src_dir/report.txt ]
then
echo "$src_dir/report.txt is missing"
exit 1
fi
###
#
# General html functions
trim(){
echo $*
}
header(){
cat <$*
EOF
}
footer(){
cat <
EOF
}
heading(){
h=$1; shift
cat <$*
EOF
}
table(){
echo ""
}
row(){
echo ""
}
end_row(){
echo "
"
}
c_column(){
cat <$*
EOF
}
bold(){
cat <$*
EOF
}
column(){
cat <$*
EOF
}
para(){
cat <
EOF
}
hr(){
cat <
EOF
}
# -- Verify
time_spec(){
# $1 - secs
_ts_tmp=$1
_ts_s=`expr $_ts_tmp % 60`
_ts_tmp=`expr $_ts_tmp / 60`
_ts_m=`expr $_ts_tmp % 60`
if [ $_ts_tmp -ge 60 ]
then
_ts_tmp=`expr $_ts_tmp / 60`
else
_ts_tmp=0
fi
a=3
_ts_h=$_ts_tmp
if [ $_ts_h -gt 0 ]
then
ret="${_ts_h}h"
fi
[ $_ts_m -gt 0 ] || [ $_ts_h -gt 0 ] && ret="$ret${_ts_m}m"
ret="$ret${_ts_s}s"
echo $ret
}
### Main
report_file=$src_dir/report.html
summary_file=$src_dir/summary.html
passed=0
failed=0
total=0
pass(){
passed=`expr $passed + 1`
}
fail(){
failed=`expr $failed + 1`
}
(
header Report $run $date
table "border=1"
row
column `bold Test case`
column `bold Result`
column `bold Elapsed`
column `bold Log`
end_row
) > $report_file
cat $src_file | while read line
do
eval `echo $line | awk -F";" '{ printf("prg=\"%s\"; no=\"%s\"; res=\"%s\"; time=\"%s\"", $1, $2, $3, $4); }'`
prg=`trim $prg`
no=`trim $no`
res=`trim $res`
time=`trim $time`
res_dir="log"
ts=`time_spec $time`
res_txt=""
case $res in
0) pass; res_txt="PASSED";;
*) fail; res_txt="FAILED";;
esac
if [ ! -d "$src_dir/result.$no" ]; then res_dir=" "; fi
total=`expr $total + $time`
(
row
column $prg
column $res_txt
column $ts
column $res_dir
end_row
) >> $report_file
(
row
column $run
column $date
column $passed
column $failed
column `time_spec $total`
column "report"
column "log.txt"
end_row
) > $summary_file
done
(
end_table
footer
) >> $report_file
exit 0