-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathrun_test.sh
executable file
·100 lines (89 loc) · 4.37 KB
/
run_test.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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#! /usr/bin/env bash
source `dirname $0`/common.sh
SSH_OPTS='-o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -q'
BUILD_URL="https://travis-ci.org/${TRAVIS_REPO_SLUG}/builds/${TRAVIS_BUILD_ID}"
ISSUE_REPO=${ISSUE_REPO:-"apt-package-whitelist"} # name of the repo that has issues, under "travis-ci"
GITHUB_ISSUES_URL="https://api.github.com/repos/travis-ci/${ISSUE_REPO}/issues/${ISSUE_NUMBER}"
if [[ -n $DOCKER ]]; then
echo "Copying build.sh"
cp build.sh common.sh add_sources.rb $HOME/build
docker exec $(< docker_id) chown -R travis /home/travis
docker exec -u travis $(< docker_id) mv $HOME/build/{build.sh,common.sh,add_sources.rb} $HOME
fi
echo "Running build.sh"
if [[ -n $DOCKER ]]; then
docker exec -u travis $(< docker_id) bash ${HOME}/build.sh ${PACKAGE}
else
bash ./build.sh ${PACKAGE}
fi
CHECK_RESULT=$?
if [ $CHECK_RESULT -ne $EXIT_SOURCE_NOT_FOUND ]; then
cp /var/tmp/deb-sources/packages .
fi
case $CHECK_RESULT in
$EXIT_SUCCESS)
notice "No suspicious bits found."
notice "Setting up Git"
git clone https://github.com/travis-ci/apt-package-whitelist.git
cp packages apt-package-whitelist # so make_pr.sh can find it
pushd apt-package-whitelist
env GITHUB_OAUTH_TOKEN=${GITHUB_OAUTH_TOKEN} ./make_pr.sh -y ${ISSUE_REPO} ${ISSUE_NUMBER} ${DIST}
if [ $? -eq $EXIT_NOTHING_TO_COMMIT ]; then
COMMIT=$(git blame ubuntu-${DIST} | grep ${PACKAGE} | cut -f1 -d' ' | sort | uniq | head -1)
curl -X POST -sS -H "Content-Type: application/json" -H "Authorization: token ${GITHUB_OAUTH_TOKEN}" \
-d "{ \"body\": \"***This is an automated comment.***\r\n\r\nFailed to create a commit and a PR. This usually means that there has been a commit that resolved this request.\r\nInparticular, check https://github.com/travis-ci/apt-package-whitelist/commit/${COMMIT}\" }" \
${GITHUB_ISSUES_URL}/comments
curl -X POST -sS -H "Content-Type: application/json" -H "Authorization: token ${GITHUB_OAUTH_TOKEN}" \
-d "[\"apt-whitelist-check-run\"]" \
${GITHUB_ISSUES_URL}/labels
elif [ $? -eq $EXIT_DUPLICATE_EXISTS ]; then
warn "Duplicate exists"
exit $EXIT_DUPLICATE_EXISTS
fi
popd
;;
$EXIT_SOURCE_HAS_SETUID)
warn "Found occurrences of setuid."
echo -e "\n\n"
echo -e "If these occurrences of \`setuid\`/\`seteuid\`/\`setgid\` are deemed harmless, add the following packages: $(< packages)\n"
notice "Setting up Git"
git clone https://github.com/travis-ci/apt-package-whitelist.git
cp packages apt-package-whitelist # so make_pr.sh can find it
pushd apt-package-whitelist
env GITHUB_OAUTH_TOKEN=${GITHUB_OAUTH_TOKEN} ./make_pr.sh -s -y ${ISSUE_REPO} ${ISSUE_NUMBER} ${DIST}
if [ $? -eq $EXIT_DUPLICATE_EXISTS ]; then
warn "Duplicate exists"
exit $EXIT_DUPLICATE_EXISTS
fi
cat <<-EOF > comment_payload
{
"body" : "***This is an automated comment.***\r\n\r\nRan tests and found setuid bits by purely textual search. Further analysis is required.\r\n\r\nIf these are found to be benign, examine http://github.com/travis-ci/apt-package-whitelist/compare/test-apt-package-whitelist-${ISSUE_NUMBER} and its PR.\r\n\r\nPackages found: $(< packages)\r\n\r\nSee ${BUILD_URL} for details."
}
EOF
curl -X POST -sS -H "Content-Type: application/json" -H "Authorization: token ${GITHUB_OAUTH_TOKEN}" \
-d @comment_payload \
${GITHUB_ISSUES_URL}/comments
curl -X POST -sS -H "Content-Type: application/json" -H "Authorization: token ${GITHUB_OAUTH_TOKEN}" \
-d "[\"apt-whitelist-check-run\"]" \
${GITHUB_ISSUES_URL}/labels
pushd
;;
$EXIT_SOURCE_NOT_FOUND)
warn "Source not found."
cat <<-EOF > comment_payload
{
"body" : "***This is an automated comment.***\r\n\r\nRan tests, but could not found source package. Either the source package for ${PACKAGE} does not exist, or the package needs an APT source. If you wish to add an APT source, please follow the directions on https://github.com/travis-ci/apt-source-whitelist#source-approval-process. Build results: ${BUILD_URL}."
}
EOF
curl -X POST -sS -H "Content-Type: application/json" -H "Authorization: token ${GITHUB_OAUTH_TOKEN}" \
-d @comment_payload \
${GITHUB_ISSUES_URL}/comments
curl -X POST -sS -H "Content-Type: application/json" -H "Authorization: token ${GITHUB_OAUTH_TOKEN}" \
-d "[\"apt-source-whitelist\",\"apt-whitelist-check-run\"]" \
${GITHUB_ISSUES_URL}/labels
;;
*)
warn "Something unexpected happened. Status: ${CHECK_RESULT}"
;;
esac
exit $CHECK_RESULT