Docker/oci and thus gitlab-runner, default to a root user inside the namespace, even if its an unprivileged one. This can cause issues and let permission bugs sneak in, as we are functionally root when running the build. Switch the build jobs to run with our new "containeruser" so we avoid much of it. Our user is still in the wheel/sudo group but that's fine as long we don't elevate the privileges unintentionally. Noticeably for the time being, we will need to chown the CI_PROJECT_DIR checkout as the gitlab runner might try to reuse pre-existing and cached volumes of the project checkout. Additionally we need to change the ccache path, so we will avoid the existing cache owned by "root". Close https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/2433 Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8763>
19 lines
646 B
Bash
19 lines
646 B
Bash
#! /bin/bash
|
|
|
|
set -eux
|
|
|
|
# Avoid the cache being owned by root
|
|
# and make sure its readable to anyone
|
|
sudo mkdir -p /var/cache/subprojects/
|
|
sudo chown containeruser:containeruser --recursive /var/cache/subprojects/
|
|
sudo chmod --recursive a+r /var/cache/subprojects/
|
|
|
|
# Path where cbuild checks out the repo
|
|
cd /tmp/clone/
|
|
sudo chmod --recursive a+r /tmp/clone
|
|
sudo chown containeruser:containeruser --recursive /tmp/clone
|
|
# get gstreamer and make all subprojects available
|
|
git submodule update --init --depth=1
|
|
meson subprojects download
|
|
./ci/scripts/handle-subprojects-cache.py --build --cache-dir /var/cache/subprojects/ /tmp/clone/subprojects/
|