mirror of
https://github.com/systemd/systemd.git
synced 2024-10-30 14:55:37 +03:00
98f654fdea
machinectl fails since 21935150a0
as it's now
mounting onto a file descriptor in a target namespace, without joining the
target's PID namespace.
Note that it's not enough to setns CLONE_NEWPID, but a double-fork is required
as well, as implemented by namespace_fork().
Add a test case to TEST-13-NSPAWN to cover this use case.
68 lines
1.5 KiB
Bash
Executable File
68 lines
1.5 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
set -e
|
|
set -u
|
|
set -o pipefail
|
|
|
|
root="${1:?Usage $0 container-root}"
|
|
mkdir -p "$root"
|
|
mkdir "$root/bin"
|
|
cp $(type -P busybox) "$root/bin"
|
|
|
|
os_release=$(test -e /etc/os-release && echo /etc/os-release || echo /usr/lib/os-release)
|
|
ID_LIKE=$(awk -F= '$1=="ID_LIKE" { print $2 ;}' $os_release)
|
|
if [[ "$ID_LIKE" = *"suse"* ]]; then
|
|
mkdir -p "$root/lib"
|
|
mkdir -p "$root/lib64"
|
|
for lib in $(find /lib*/ld*); do
|
|
[[ -d $root/$(dirname $lib) ]] || mkdir -p $root/$(dirname $lib)
|
|
cp $lib $root/$lib
|
|
done
|
|
fi
|
|
|
|
mkdir -p "$root/usr/lib"
|
|
touch "$root/usr/lib/os-release"
|
|
|
|
ln -s busybox "$root/bin/sh"
|
|
ln -s busybox "$root/bin/cat"
|
|
ln -s busybox "$root/bin/tr"
|
|
ln -s busybox "$root/bin/ps"
|
|
ln -s busybox "$root/bin/ip"
|
|
ln -s busybox "$root/bin/seq"
|
|
ln -s busybox "$root/bin/sleep"
|
|
ln -s busybox "$root/bin/test"
|
|
|
|
mkdir -p "$root/sbin"
|
|
cat <<'EOF' >"$root/sbin/init"
|
|
#!/bin/sh
|
|
|
|
printf "ps aufx:\n"
|
|
ps aufx
|
|
|
|
printf "/proc/1/cmdline:\n"
|
|
printf "%s\n\n" "$(tr '\0' ' ' </proc/1/cmdline)"
|
|
|
|
printf "/proc/1/environ:\n"
|
|
printf "%s\n\n" "$(tr '\0' '\n' </proc/1/environ)"
|
|
|
|
printf "/proc/1/mountinfo:\n"
|
|
cat /proc/self/mountinfo
|
|
printf "\n"
|
|
|
|
printf "/proc/1/cgroup:\n"
|
|
printf "%s\n\n" "$(cat /proc/1/cgroup)"
|
|
|
|
printf "/proc/1/uid_map:\n"
|
|
printf "%s\n\n" "$(cat /proc/1/uid_map)"
|
|
|
|
printf "/proc/1/setgroups:\n"
|
|
printf "%s\n\n" "$(cat /proc/1/setgroups)"
|
|
|
|
printf "/proc/1/gid_map:\n"
|
|
printf "%s\n\n" "$(cat /proc/1/gid_map)"
|
|
|
|
printf "ip link:\n"
|
|
ip link
|
|
EOF
|
|
chmod +x "$root/sbin/init"
|