1
0
mirror of https://github.com/systemd/systemd.git synced 2025-01-09 01:18:19 +03:00

test: create ESP and xbootldr partitions

This commit is contained in:
Yu Watanabe 2023-12-05 16:31:53 +09:00
parent 0f236e8cd6
commit 97bbb9cfbd
2 changed files with 28 additions and 9 deletions

View File

@ -27,7 +27,7 @@ check_result_qemu() {
mount_initdir mount_initdir
cryptsetup luksOpen "${LOOPDEV:?}p2" "${DM_NAME:?}" <"$TESTDIR/keyfile" cryptsetup luksOpen "${LOOPDEV:?}p4" "${DM_NAME:?}" <"$TESTDIR/keyfile"
mount "/dev/mapper/$DM_NAME" "$initdir/var" mount "/dev/mapper/$DM_NAME" "$initdir/var"
check_result_common "${initdir:?}" && ret=0 || ret=$? check_result_common "${initdir:?}" && ret=0 || ret=$?
@ -43,8 +43,8 @@ test_create_image() {
create_empty_image_rootdir create_empty_image_rootdir
echo -n test >"${TESTDIR:?}/keyfile" echo -n test >"${TESTDIR:?}/keyfile"
cryptsetup -q luksFormat --uuid="$PART_UUID" --pbkdf pbkdf2 --pbkdf-force-iterations 1000 "${LOOPDEV:?}p2" "$TESTDIR/keyfile" cryptsetup -q luksFormat --uuid="$PART_UUID" --pbkdf pbkdf2 --pbkdf-force-iterations 1000 "${LOOPDEV:?}p4" "$TESTDIR/keyfile"
cryptsetup luksOpen "${LOOPDEV}p2" "${DM_NAME:?}" <"$TESTDIR/keyfile" cryptsetup luksOpen "${LOOPDEV}p4" "${DM_NAME:?}" <"$TESTDIR/keyfile"
mkfs.ext4 -L var "/dev/mapper/$DM_NAME" mkfs.ext4 -L var "/dev/mapper/$DM_NAME"
mkdir -p "${initdir:?}/var" mkdir -p "${initdir:?}/var"
mount "/dev/mapper/$DM_NAME" "$initdir/var" mount "/dev/mapper/$DM_NAME" "$initdir/var"

View File

@ -1598,6 +1598,9 @@ create_empty_image() {
# Partition sizes are in MiBs # Partition sizes are in MiBs
local root_size=768 local root_size=768
local data_size=100 local data_size=100
local esp_size=128
local boot_size=128
local total=
if ! get_bool "$NO_BUILD"; then if ! get_bool "$NO_BUILD"; then
if meson configure "${BUILD_DIR:?}" | grep 'static-lib\|standalone-binaries' | awk '{ print $2 }' | grep -q 'true'; then if meson configure "${BUILD_DIR:?}" | grep 'static-lib\|standalone-binaries' | awk '{ print $2 }' | grep -q 'true'; then
root_size=$((root_size + 200)) root_size=$((root_size + 200))
@ -1620,28 +1623,44 @@ create_empty_image() {
data_size=$((data_size + IMAGE_ADDITIONAL_DATA_SIZE)) data_size=$((data_size + IMAGE_ADDITIONAL_DATA_SIZE))
fi fi
echo "Setting up ${IMAGE_PUBLIC:?} (${root_size} MB)" total=$((root_size + data_size + esp_size + boot_size))
echo "Setting up ${IMAGE_PUBLIC:?} (${total} MB)"
rm -f "${IMAGE_PRIVATE:?}" "$IMAGE_PUBLIC" rm -f "${IMAGE_PRIVATE:?}" "$IMAGE_PUBLIC"
# Create the blank file to use as a root filesystem # Create the blank file to use as a root filesystem
truncate -s "${root_size}M" "$IMAGE_PUBLIC" truncate -s "${total}M" "$IMAGE_PUBLIC"
LOOPDEV="$(losetup --show -P -f "$IMAGE_PUBLIC")" LOOPDEV="$(losetup --show -P -f "$IMAGE_PUBLIC")"
[[ -b "$LOOPDEV" ]] || return 1 [[ -b "$LOOPDEV" ]] || return 1
# Create two partitions - a root one and a data one (utilized by some tests) # Create two partitions - a root one and a data one (utilized by some tests)
sfdisk "$LOOPDEV" <<EOF sfdisk "$LOOPDEV" <<EOF
label: gpt label: gpt
type=0FC63DAF-8483-4772-8E79-3D69D8477DE4 name=root size=$((root_size - data_size))M bootable type=C12A7328-F81F-11D2-BA4B-00A0C93EC93B name=esp size=${esp_size}M
type=0FC63DAF-8483-4772-8E79-3D69D8477DE4 name=root size=${root_size}M bootable
type=BC13C2FF-59E6-4262-A352-B275FD6F7172 name=boot size=${boot_size}M
type=0FC63DAF-8483-4772-8E79-3D69D8477DE4 name=data type=0FC63DAF-8483-4772-8E79-3D69D8477DE4 name=data
EOF EOF
udevadm settle udevadm settle
if ! mkfs -t vfat "${LOOPDEV}p1"; then
dfatal "Failed to mkfs -t vfat ${LOOPDEV}p1"
exit 1
fi
local label=(-L systemd_boot) local label=(-L systemd_boot)
# mkfs.reiserfs doesn't know -L. so, use --label instead # mkfs.reiserfs doesn't know -L. so, use --label instead
[[ "$FSTYPE" == "reiserfs" ]] && label=(--label systemd_boot) [[ "$FSTYPE" == "reiserfs" ]] && label=(--label systemd_boot)
if ! mkfs -t "${FSTYPE}" "${label[@]}" "${LOOPDEV}p1" -q; then if ! mkfs -t "${FSTYPE}" "${label[@]}" "${LOOPDEV}p2" -q; then
dfatal "Failed to mkfs -t ${FSTYPE}" dfatal "Failed to mkfs -t ${FSTYPE} ${label[*]} ${LOOPDEV}p2 -q"
exit 1
fi
local label=(-L xbootldr)
[[ "$FSTYPE" == "reiserfs" ]] && label=(--label xbootldr)
if ! mkfs -t "${FSTYPE}" "${label[@]}" "${LOOPDEV}p3" -q; then
dfatal "Failed to mkfs -t ${FSTYPE} ${label[*]} ${LOOPDEV}p3 -q"
exit 1 exit 1
fi fi
} }
@ -1657,7 +1676,7 @@ mount_initdir() {
if ! mountpoint -q "${initdir:?}"; then if ! mountpoint -q "${initdir:?}"; then
mkdir -p "$initdir" mkdir -p "$initdir"
mount "${LOOPDEV}p1" "$initdir" mount "${LOOPDEV}p2" "$initdir"
TEST_SETUP_CLEANUP_ROOTDIR=1 TEST_SETUP_CLEANUP_ROOTDIR=1
fi fi
} }