-
-
Notifications
You must be signed in to change notification settings - Fork 620
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add a build step to measure the scan perfomance
This step will measure the scan performance difference against the master version. Change-Id: I1b9196ef3348350cf818471f55d9024d14064ac6 Signed-off-by: Cosmin Cojocar <ccojocar@google.com>
- Loading branch information
Showing
3 changed files
with
50 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
#!/bin/bash | ||
|
||
BIN="gosec" | ||
BUILD_DIR="/tmp/securego" | ||
|
||
# Scan the current folder and measure the duration. | ||
function scan() { | ||
local scan_cmd=$1 | ||
s=$(date +%s%3N) | ||
$scan_cmd -quiet ./... | ||
e=$(date +%s%3N) | ||
res=$(expr $e - $s) | ||
echo $res | ||
} | ||
|
||
# Build the master reference version. | ||
mkdir -p ${BUILD_DIR} | ||
git clone --quiet https://github.com/securego/gosec.git ${BUILD_DIR} >/dev/null | ||
make -C ${BUILD_DIR} >/dev/null | ||
|
||
# Scan once with the main reference. | ||
duration_master=$(scan "${BUILD_DIR}/${BIN}") | ||
echo "gosec reference time: ${duration_master}ms" | ||
|
||
# Build the current version. | ||
make -C . >/dev/null | ||
|
||
# Scan once with the current version. | ||
duration=$(scan "./${BIN}") | ||
echo "gosec time: ${duration}ms" | ||
|
||
# Compute the difference of the execution time. | ||
diff=$(($duration - $duration_master)) | ||
if [[ diff -lt 0 ]]; then | ||
diff=$(($diff * -1)) | ||
fi | ||
echo "diff: ${diff}ms" | ||
perf=$((100 - ($duration * 100) / $duration_master)) | ||
echo "perf diff: ${perf}%" | ||
|
||
# Fail the build if there is a performance degradation of more than 10%. | ||
if [[ $perf -lt -10 ]]; then | ||
exit 1 | ||
fi |