-
Notifications
You must be signed in to change notification settings - Fork 10
/
Generate-Report.sh
executable file
·70 lines (57 loc) · 3.28 KB
/
Generate-Report.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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#!/bin/bash
if [ $# -ne 5 ]
then
echo; echo "Usage: $0 <script-to-extracts-the-result> <Baseline result> <Baseline log file> <Current results> <Current log file>"
echo; echo "eg:"
echo; echo " # $0 ./extract-smallfile-results.sh ~/config-for-cluster1/BaseLine-fuse-smallfile-result.txt ~/config-for-cluster1/BaselinePerfTest.log ./results/fuse-smallfile-result.txt ./results/PerfTest.log"
exit
fi
Extractor="$1"
BaselineResult="$2"
BaselineLog="$3"
CurrentResult="$4"
CurrentLog="$5"
CurrentExtractedResult="/tmp/$$-current.txt"
BaselineExtractedResult="/tmp/$$-Baseline.txt"
Table="/tmp/$$-Report.txt"
TableWithoutHeadersForAnalysisOfStatus="/tmp/$$-Report-without-header.txt"
# Check if comparison is between same type of volumes
BaselineVolumeType=$(grep "Type:" $BaselineLog |tr -dc '[[:print:]]') # here tr command will remove any non-printable characters
CurrentVolumeType=$(grep "Type:" $CurrentLog | tr -dc '[[:print:]]' )
BaselineNumberOfBricks=$(grep "Number of Bricks:" $BaselineLog | tr -dc '[[:print:]]')
CurrentNumberOfBricks=$(grep "Number of Bricks:" $CurrentLog | tr -dc '[[:print:]]')
if [[ "${BaselineVolumeType}" != "${CurrentVolumeType}" ]] || [[ "${BaselineNumberOfBricks}" != "${CurrentNumberOfBricks}" ]]
then
echo "Warning: Volumes are not same"
fi
# Extract the results of the current test and Baseline test
$Extractor $BaselineResult > $BaselineExtractedResult
$Extractor $CurrentResult > $CurrentExtractedResult
# Get the New and the Old gluster version from the PerfTest.log file
Temp=$(grep 'glusterfs-server-' $CurrentLog | head -1 | sed 's/server-//g' )
CurrentGlusterVersion=${Temp::-11} # delete trailing characters
Temp=$(grep 'glusterfs-server-' $BaselineLog| head -1 | sed 's/server-//g' )
BaselineGlusterVersion=${Temp::-11} # delete trailing characters
echo "CurrentGlusterVersion=$CurrentGlusterVersion" >> env.properties
# Create a table
echo "=============================================================================================================
FOPs $BaselineGlusterVersion $CurrentGlusterVersion $CurrentGlusterVersion
vs
$BaselineGlusterVersion
=============================================================================================================" > $Table
join -t: -1 1 -2 1 $BaselineExtractedResult $CurrentExtractedResult | awk 'BEGIN { FS=":"; } { printf "%-20s\t\t %-20d \t\t%-20d \t\t%3d\n", $1,$2,$3, (($3-$2)/$2)*100 }' > "$TableWithoutHeadersForAnalysisOfStatus"
cat $TableWithoutHeadersForAnalysisOfStatus >> $Table
echo "=============================================================================================================" >> $Table
# Find if there was regression
regression=$(awk '$4 < -5 { print $4 }' $TableWithoutHeadersForAnalysisOfStatus | sort -n | head -1)
# Update the status to FAIL if there was a regression, This value of status can be used in Jenkins to send email to team
if [ "$regression" ]
then
status="FAIL"
echo "STATUS=$status" >> env.properties
else
status="PASS"
echo "STATUS=$status" >> env.properties
fi
cat "$Table"
cat "$Table" > /tmp/perf_result.txt