-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathscan.sh
executable file
·85 lines (73 loc) · 2.09 KB
/
scan.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#!/bin/bash
#
# media-tools
# Copyright (C) 2019-2021 Olivier Korach
# mailto:olivier.korach AT gmail DOT com
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 3 of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program; if not, write to the Free Software Foundation,
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
dolint=true
tests=pytest
skiptests=0
while [ $# -ne 0 ]
do
case "$1" in
-nolint)
dolint=false
;;
-unittest)
tests=unittest
;;
-skiptests)
skiptests=1
;;
*)
scanOpts="$scanOpts $1"
;;
esac
shift
done
buildDir="build"
owaspDependencyReport="$buildDir/dependency-check-report.json"
[ ! -d $buildDir ] && mkdir $buildDir
rm -rf -- ${buildDir:?"."}/* .coverage */__pycache__ */*.pyc # mediatools/__pycache__ tests/__pycache__
if [ $skiptests -eq 0 ]; then
./run_tests.sh
else
echo "Skipping tests"
fi
if [ "$dolint" != "false" ]; then
./run_linters.sh
fi
dependency-check --scan . --format JSON --prettyPrint --out $owaspDependencyReport
version=$(grep MEDIA_TOOLS_VERSION mediatools/version.py | cut -d "=" -f 2 | cut -d "'" -f 2)
pr_branch=""
for o in $scanOpts
do
key="$(echo $o | cut -d '=' -f 1)"
if [ "$key" = "-Dsonar.pullrequest.key" ]; then
pr_branch="-Dsonar.pullrequest.branch=foo"
fi
done
echo "Running: sonar-scanner \
-Dsonar.projectVersion=$version \
-Dsonar.dependencyCheck.jsonReportPath=$owaspDependencyReport \
$pr_branch \
$scanOpts"
sonar-scanner \
-Dsonar.projectVersion=$version \
-Dsonar.dependencyCheck.jsonReportPath=$owaspDependencyReport \
$pr_branch \
$scanOpts