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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
|
#!/bin/bash
# Copyright 2014-2015 Holger Levsen <holger@layer-acht.org>
# released under the GPLv=2
common_cleanup() {
echo "$(date -u) - $0 stopped running as $TTT, which will now be removed."
rm -f $TTT
}
#
# run ourself with the same parameter as we are running
# but run a copy from /tmp so that the source can be updated
# (Running shell scripts fail weirdly when overwritten when running,
# this hack makes it possible to overwrite long running scripts
# anytime...)
#
common_init() {
# check whether this script has been started from /tmp already
if [ "${0:0:5}" != "/tmp/" ] ; then
# check that we are not root
if [ $(id -u) -eq 0 ] ; then
echo "Do not run this as root."
exit 1
fi
# mktemp some place for us...
TTT=$(mktemp --tmpdir=/tmp jenkins-script-XXXXXXXX)
# prepare cleanup
trap common_cleanup INT TERM EXIT
# cp $0 to /tmp and run it from there
cp $0 $TTT
chmod +x $TTT
echo "===================================================================================="
echo
echo "$(date -u) - running $0 ($JOB_NAME) on $(hostname) now."
echo
echo "To learn to understand this, clone git.debian.org/git/qa/jenkins.debian.net.git"
echo "and then have a look at the files README, INSTALL, CONTRIBUTING and maybe TODO."
echo
echo "This invocation of this script, which is located in bin/$(basename $0), has been called using \"$@\" as arguments."
echo
echo "===================================================================================="
echo "$(date -u) - start running \"$0\" (md5sum $(md5sum $0|cut -d ' ' -f1)) as \"$TTT\" on $(hostname)."
echo
# this is the "hack": call ourself as a copy in /tmp again
# (setsid is not related to this hack. see commit log for 24deda5a8 it.)
/srv/jenkins/bin/setsid.py $TTT "$@"
exit $?
# cleanup is done automatically via trap
else
# this directory resides on tmpfs, so it might be gone after reboots...
mkdir -p /srv/workspace/chroots
# default settings used for the jenkins.debian.net environment
if [ -z "$LC_ALL" ]; then
export LC_ALL=C.UTF-8
fi
if [ -z "$MIRROR" ]; then
case $HOSTNAME in
jenkins|jenkins-test-vm|profitbricks-build?-amd64) export MIRROR=http://ftp.de.debian.org/debian ;;
bpi0|cbxi4pro0|hb0|wbq0|odxu4*|wbd0|rpi2*|ff2*|opi2a) export MIRROR=http://ftp.us.debian.org/debian ;;
*) echo "unsupported host, exiting." ; exit 1 ;;
esac
fi
if [ -z "$http_proxy" ]; then
case $HOSTNAME in
jenkins|jenkins-test-vm|profitbricks-build?-amd64) export http_proxy="http://localhost:3128" ;;
bpi0|cbxi4pro0|hb0|wbq0|odxu4*|wbd0|rpi2*|ff2*|opi2a) export http_proxy="http://10.0.0.15:8000/" ;;
*) echo "unsupported host, exiting." ; exit 1 ;;
esac
fi
if [ -z "$CHROOT_BASE" ]; then
export CHROOT_BASE=/chroots
fi
if [ -z "$SCHROOT_BASE" ]; then
export SCHROOT_BASE=/schroots
fi
if [ ! -d "$SCHROOT_BASE" ]; then
echo "Directory $SCHROOT_BASE does not exist, aborting."
exit 1
fi
# use these settings in the scripts in the (s)chroots too
export SCRIPT_HEADER="#!/bin/bash
if $DEBUG ; then
set -x
fi
set -e
export DEBIAN_FRONTEND=noninteractive
export LC_ALL=$LC_ALL
export http_proxy=$http_proxy
export MIRROR=$MIRROR"
# be more verbose, maybe
if $DEBUG ; then
export
set -x
fi
set -e
fi
}
publish_changes_to_userContent() {
echo "Extracting contents from .deb files..."
CHANGES=$1
CHANNEL=$2
SRCPKG=$(basename $CHANGES | cut -d "_" -f1)
if [ -z "$SRCPKG" ] ; then
exit 1
fi
VERSION=$(basename $CHANGES | cut -d "_" -f2)
TARGET="/var/lib/jenkins/userContent/$SRCPKG"
NEW_CONTENT=$(mktemp -d -t new-content-XXXXXXXX)
for DEB in $(dcmd --deb $CHANGES) ; do
dpkg --extract $DEB ${NEW_CONTENT} 2>/dev/null
done
rm -rf $TARGET
mkdir $TARGET
mv ${NEW_CONTENT}/usr/share/doc/${SRCPKG}-* $TARGET/
rm -r ${NEW_CONTENT}
if [ -z "$3" ] ; then
touch "$TARGET/${VERSION}"
FROM=""
else
touch "$TARGET/${VERSION}_$3"
FROM=" from $3"
fi
MESSAGE="https://jenkins.debian.net/userContent/$SRCPKG/ has been updated${FROM}."
echo
echo $MESSAGE
echo
if [ ! -z "$CHANNEL" ] ; then
kgb-client --conf /srv/jenkins/kgb/$CHANNEL.conf --relay-msg "$MESSAGE"
fi
}
cleanup_schroot_sessions() {
echo
local RESULT=""
for loop in $(seq 0 40) ; do
# first, check if no process using "schroot" is running, if thats the case, loop through all schroot sessions:
# arch sessions are ignored, because they are handled properly
pgrep -f "schroot --directory" || for i in $(schroot --all-sessions -l |grep -v "session:archlinux"||true) ; do
# then, check that schroot is still not run, and then delete the session
if [ -z $i ] ; then
continue
fi
pgrep -f "schroot --directory" || schroot -e -c $i
done
RESULT=$(schroot --all-sessions -l|grep -v "session:archlinux"||true)
if [ -z "$RESULT" ] ; then
echo "No schroot sessions in use atm..."
echo
break
fi
echo "$(date -u) - schroot session cleanup loop $loop"
sleep 15
done
echo
}
|