reproducible_setup_pbuilder.sh 5.34 KB
Newer Older
1
2
#!/bin/bash

3
# Copyright 2014-2015 Holger Levsen <holger@layer-acht.org>
4
5
# released under the GPLv=2

6
DEBUG=false
7
8
9
. /srv/jenkins/bin/common-functions.sh
common_init "$@"

Holger Levsen's avatar
Holger Levsen committed
10
11
# common code defining db access
. /srv/jenkins/bin/reproducible_common.sh
12

13
14
# support different suites
if [ -z "$1" ] ; then
15
	SUITE="unstable"
16
17
18
19
else
	SUITE="$1"
fi

20
21
22
#
# create script to configure a pbuilder chroot
#
Holger Levsen's avatar
Holger Levsen committed
23
create_setup_tmpfile() {
24
25
	TMPFILE=$1
	shift
26
	cat >> $TMPFILE <<- EOF
27
28
29
#
# this script is run within the pbuilder environment to further customize it
#
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
echo "-----BEGIN PGP PUBLIC KEY BLOCK-----
Version: GnuPG v1.4.12 (GNU/Linux)

mQINBFQsy/gBEADKGF55qQpXxpTn7E0Vvqho82/HFB/yT9N2wD8TkrejhJ1I6hfJ
zFXD9fSi8WnNpLc6IjcaepuvvO4cpIQ8620lIuONQZU84sof8nAO0LDoMp/QdN3j
VViXRXQtoUmTAzlOBNpyb8UctAoSzPVgO3jU1Ngr1LWi36hQPvQWSYPNmbsDkGVE
unB0p8DCN88Yq4z2lDdlHgFIy0IDNixuRp/vBouuvKnpe9zyOkijV83Een0XSUsZ
jmoksFzLzjChlS5fAL3FjtLO5XJGng46dibySWwYx2ragsrNUUSkqTTmU7bOVu9a
zlnQNGR09kJRM77UoET5iSXXroK7xQ26UJkhorW2lXE5nQ97QqX7igWp2u0G74RB
e6y3JqH9W8nV+BHuaCVmW0/j+V/l7T3XGAcbjZw1A4w5kj8YGzv3BpztXxqyHQsy
piewXLTBn8dvgDqd1DLXI5gGxC3KGGZbC7v0rQlu2N6OWg2QRbcVKqlE5HeZxmGV
vwGQs/vcChc3BuxJegw/bnP+y0Ys5tsVLw+kkxM5wbpqhWw+hgOlGHKpJLNpmBxn
T+o84iUWTzpvHgHiw6ShJK50AxSbNzDWdbo7p6e0EPHG4Gj41bwO4zVzmQrFz//D
txVBvoATTZYMLF5owdCO+rO6s/xuC3s04pk7GpmDmi/G51oiz7hIhxJyhQARAQAB
tC5EZWJpYW4gUmVwcm9kdWNpYmxlIEJ1aWxkcyBBcmNoaXZlIFNpZ25pbmcgS2V5
iQI9BBMBCAAnBQJULMv4AhsDBQkFo5qABQsJCAcDBRUKCQgLBRYDAgEAAh4BAheA
AAoJEF23ymfqWaMfFsMP/3jthq65H9avuM469jHcugcd0C5b7/DS+cGQ5E4NQIGL
6tGsqv5k6Nb0MoMMEAQSmWeXRkbYYxmEkrREMNg8tPlh4NiJimH3neNfI+8fGiHY
89FH7QDrrzGfMF9oJQ9zjWZTOs3bjJ4AfS4fkQiQ6UfO7TeMyz5Cw7kz+rS1m1tu
+RgHxD+6A+XxkIZnw5we1MH0SAFoq4j3boR8QkFUNMZsy97xWYON4QLpYwKCbiwL
Q4y06YTw4A7lp+B2JKLc70yRcjbixeAFlZfbhmGITTNAl3j8+48hRLLkJ+s8eT1r
DS1UkYi2xBSNa6TVtNxbDUwVTzzxDe+b8tW2BfC7TBOX2oq6e6ebRa+ghZFVLNY1
3y+FilXGNMB7IvZ378idHYTNaiJuYXNkrd8UGunwK4NCWdZk05L9GdKeQ6DN380Y
L4QkKpINXSKjneWV7IITMFhvRZCgOVAmoHaq6kaGsl/FwHBA9I8hHXuSyvke8UMP
dmvR8ggv5wiY9NDjW55h7M+UIqEaoXws1algIKB/TWm4/RnQcrxoXBX16wyidzcv
Mb0BawlXZui0MNUSnZtxHMxrjejdvZdqtskHl9srB1QThH0jasmUqbQPxCnxMbf1
4LhIp6XlXJFF1btgfCexNmcPuqeOMMDQ+du6Hqj2Yl5GYo2McWvjpSgkt5VmQfIz
=X8YA
-----END PGP PUBLIC KEY BLOCK-----" | apt-key add -
59
echo 'deb http://reproducible.alioth.debian.org/debian/ ./' > /etc/apt/sources.list.d/reproducible.list
60
61
62
63
echo
echo "Configuring APT to ignore the Release file expiration"
echo 'Acquire::Check-Valid-Until "false";' > /etc/apt/apt.conf.d/398future
echo
Holger Levsen's avatar
Holger Levsen committed
64
apt-get update
65
apt-get -y upgrade
66
apt-get install -y $@
67
echo
68
69
apt-cache policy
echo
70
dpkg -l
71
echo
Holger Levsen's avatar
Holger Levsen committed
72
for i in \$(dpkg -l |grep ^ii |awk -F' ' '{print \$2}'); do   apt-cache madison "\$i" | head -1 | grep reproducible.alioth.debian.org || true  ; done
Holger Levsen's avatar
Holger Levsen committed
73
echo
74
EOF
Holger Levsen's avatar
Holger Levsen committed
75
76
}

77

78
#
Holger Levsen's avatar
Holger Levsen committed
79
# setup pbuilder for reproducible builds
80
#
81
setup_pbuilder() {
82
	SUITE=$1
83
	shift
84
85
	NAME=$1
	shift
86
87
	PACKAGES="$@"						# from our repo
	EXTRA_PACKAGES="locales-all fakeroot disorderfs"	# from sid
Holger Levsen's avatar
Holger Levsen committed
88
	echo "$(date -u) - creating /var/cache/pbuilder/${NAME}.tgz now..."
89
90
	TMPFILE=$(mktemp --tmpdir=$TEMPDIR pbuilder-XXXXXXXXX)
	LOG=$(mktemp --tmpdir=$TEMPDIR pbuilder-XXXXXXXX)
Holger Levsen's avatar
Holger Levsen committed
91
	if [ "$SUITE" = "experimental" ] ; then
92
		SUITE=unstable
93
94
		echo "echo 'deb $MIRROR experimental main' > /etc/apt/sources.list.d/experimental.list" > ${TMPFILE}
		echo "echo 'deb-src $MIRROR experimental main' >> /etc/apt/sources.list.d/experimental.list" >> ${TMPFILE}
95
	fi
96
	# use host apt proxy configuration for pbuilder too
97
98
99
100
	if [ ! -z "$http_proxy" ] ; then
		echo "echo '$(cat /etc/apt/apt.conf.d/80proxy)' > /etc/apt/apt.conf.d/80proxy" >> ${TMPFILE}
		pbuilder_http_proxy="--http-proxy $http_proxy"
	fi
101
	# setup base.tgz
102
	sudo pbuilder --create $pbuilder_http_proxy --basetgz /var/cache/pbuilder/${NAME}-new.tgz --distribution $SUITE --extrapackages "$EXTRA_PACKAGES"
103
104
	# apply further customisations, eg. install $PACKAGES from our repo
	create_setup_tmpfile ${TMPFILE} "${PACKAGES}"
105
106
107
108
	if [ "$DEBUG" = "true" ] ; then
		cat "$TMPFILE"
	fi
	sudo pbuilder --execute $pbuilder_http_proxy --save-after-exec --basetgz /var/cache/pbuilder/${NAME}-new.tgz -- ${TMPFILE} | tee ${LOG}
109
	# finally, confirm things are as they should be
110
111
112
	echo
	echo "Now let's see whether the correct packages where installed..."
	for PKG in ${PACKAGES} ; do
113
		egrep "http://reproducible.alioth.debian.org/debian(/|) ./ Packages" ${LOG} \
114
			| grep -v grep | grep "${PKG} " \
115
			|| ( echo ; echo "Package ${PKG} is not installed at all or probably rather not in our version, so removing the chroot and exiting now." ; sudo rm -v /var/cache/pbuilder/${NAME}-new.tgz ; rm $TMPFILE $LOG ; exit 1 )
116
117
	done
	sudo mv /var/cache/pbuilder/${NAME}-new.tgz /var/cache/pbuilder/${NAME}.tgz
118
119
	# create stamp file to record initial creation date minus some hours so the file will be older than 24h when checked in <24h...
	touch -d "$(date -u -d '6 hours ago' '+%Y-%m-%d %H:%M')" /var/log/jenkins/${NAME}.tgz.stamp
120
	rm ${TMPFILE} ${LOG}
Holger Levsen's avatar
Holger Levsen committed
121
122
}

123
124
125
#
# main
#
126
127
BASETGZ=/var/cache/pbuilder/$SUITE-$ARCH-reproducible-base.tgz
STAMP=/var/log/jenkins/$SUITE-$ARCH-reproducible-base.tgz.stamp
Holger Levsen's avatar
Holger Levsen committed
128
OLDSTAMP=$(find $STAMP -mtime +1 -exec ls -lad {} \; || echo "nostamp")
129
130
131
132
133
134
if [ -n "$OLDSTAMP" ] || [ ! -f $BASETGZ ] || [ ! -f $STAMP ] ; then
	if [ ! -f $BASETGZ ] ; then
		echo "No $BASETGZ exists, creating a new one..."
	else
		echo "$BASETGZ outdated, creating a new one..."
	fi
135
	setup_pbuilder $SUITE-$ARCH $SUITE-$ARCH-reproducible-base dpkg dpkg-dev
136
else
Holger Levsen's avatar
Holger Levsen committed
137
	echo "$BASETGZ not old enough, doing nothing..."
138
139
fi
echo