[projects/cleanbuild] exec --user=root fails on docker for mac somewhy
glen
glen at pld-linux.org
Sun Dec 30 21:42:02 CET 2018
commit 8f52cf50222126ef972966b7f919a3646f4b0f24
Author: Elan Ruusamäe <glen at delfi.ee>
Date: Wed Sep 26 15:17:48 2018 +0300
exec --user=root fails on docker for mac somewhy
cleanbuild-docker.sh | 20 ++++++++++++--------
1 file changed, 12 insertions(+), 8 deletions(-)
---
diff --git a/cleanbuild-docker.sh b/cleanbuild-docker.sh
index 43e550c..8183ab8 100755
--- a/cleanbuild-docker.sh
+++ b/cleanbuild-docker.sh
@@ -9,7 +9,7 @@ dir=$(pwd)
image=registry.gitlab.com/pld-linux/cleanbuild
name=cleanbuild-$package
topdir=$dir/rpm
-home=/home/services/builder
+home=/home/builder
buildsize="4G"
# cleanup first
@@ -20,6 +20,7 @@ install -d $topdir/logs
# start the container
docker run --name=$name -d \
+ -w $home \
-v $topdir:$home/rpm \
-v $dir:$home/cleanbuild \
-v $dir/cache/poldek:/var/cache/poldek \
@@ -27,8 +28,11 @@ docker run --name=$name -d \
--tmpfs $home/rpm/BUILD:rw,exec,nosuid,size=$buildsize \
$image
+# set the homedir
+docker exec --user=root -w / $name usermod -d $home builder
+
# these paths need to be accessible for builder
-docker exec --user=root $name chown builder:builder rpm rpm/logs rpm/BUILD .ccache
+docker exec --user=root -w / $name sh -c "cd $home && chown builder:builder rpm rpm/logs rpm/BUILD .ccache"
if [ ! -d $topdir/rpm-build-tools ]; then
docker exec $name builder --init-rpm-dir
@@ -37,12 +41,12 @@ fi
# fetch sources and install deps
if [ -d $topdir/packages/$package ]; then
# chown, as it might be different owner (root) modified outside container
- docker exec --user=root $name chown -R builder:builder rpm/packages/$package
+ docker exec --user=root -w / $name chown -R builder:builder $home/rpm/packages/$package
fi
docker exec $name builder -g $package
# prevent network access like pld builders do
-docker exec --user=root $name setfacl -m u:builder:--- /etc/resolv.conf
+docker exec --user=root -w / $name setfacl -m u:builder:--- /etc/resolv.conf
git_tag=$(GIT_DIR=$topdir/packages/$package/.git git describe --tags --always)
buildlog=rpm/logs/${git_tag#auto/*/}.log
@@ -52,9 +56,9 @@ while true; do
# install deps
docker exec $name builder -g -nn -R $package
# remove .la dependencies
- docker exec --user=root $name cleanbuild/cleanup-la
+ docker exec --user=root -w / $name $home/cleanbuild/cleanup-la
# reset findunusedbr state after deps install
- docker exec --user=root $name cleanbuild/findunusedbr -c / rpm/packages/$package/$package.spec
+ docker exec --user=root -w / $name $home/cleanbuild/findunusedbr -c / $home/rpm/packages/$package/$package.spec
# actual build
docker exec $name cleanbuild/teeboth $buildlog builder -nn -bb $package --define '__spec_clean_body %{nil}' && rc=$? || rc=$?
@@ -66,7 +70,7 @@ while true; do
exit 6
fi
# need root to run poldek
- docker exec --user=root $name cleanbuild/findbr $builddir $buildlog > $findbr
+ docker exec --user=root -w / $name sh -c "cd $home && cleanbuild/findbr $builddir $buildlog" > $findbr
installed_something=false
while read pkg msg; do
@@ -78,7 +82,7 @@ while true; do
# go for another try
$installed_something && continue
- docker exec --user=root $name cleanbuild/findunusedbr / rpm/packages/$package/$package.spec
+ docker exec --user=root -w / $name $home/cleanbuild/findunusedbr -c / $home/rpm/packages/$package/$package.spec
if [ $rc -eq 0 ]; then
# finished ok, cleanup
================================================================
---- gitweb:
http://git.pld-linux.org/gitweb.cgi/projects/cleanbuild.git/commitdiff/dd308d9f6069710bc67d8c27c7ae8b66e00fe2dd
More information about the pld-cvs-commit
mailing list