Previously, the kernel parameter crashkernel will be set up when kexec-tools is installed. But now it will happen only when kdump.service is enabled first. When kexec-tools is freshly installed, the kdump.service will be enabled according to the systemd policy file and later the kernel parameter crashkernel will be added only if kdump.service is enabled. Fedora disables kdump.service in the systemd policy. So enable kdump.service in the systemd preset policy manually in the test script.
In case kexec-tools has already been installed, simply enable kdump.service.
Fixes: 0ffce0ef ("Only try to reset crashkernel when kdump.service is enabled") Signed-off-by: Coiby Xu coxu@redhat.com --- tests/scripts/build-scripts/test-base-image.sh | 5 +++++ 1 file changed, 5 insertions(+)
diff --git a/tests/scripts/build-scripts/test-base-image.sh b/tests/scripts/build-scripts/test-base-image.sh index afe1a974..3797a25a 100755 --- a/tests/scripts/build-scripts/test-base-image.sh +++ b/tests/scripts/build-scripts/test-base-image.sh @@ -16,6 +16,11 @@ img_inst $TESTDIR/scripts/kexec-kdump-test/test.sh /kexec-kdump-test/test.sh img_inst $TESTDIR/scripts/kexec-kdump-test/kexec-kdump-test.service /etc/systemd/system/kexec-kdump-test.service img_run_cmd "systemctl enable kexec-kdump-test.service"
+# enable kdump.service in the systemd preset policy so the kernel parameter crashkernel +# will be added automatically when kexec-tools is freshly installed +img_run_cmd "echo 'enable kdump.service' > /usr/lib/systemd/system-preset/95-kdump.preset" +# In case kexec-tools has already been installed, simply enable kdump.serivce +img_run_cmd " rpm --quiet -q kexec-tools && systemctl enable kdump.service" img_inst_pkg $TEST_RPMS # Test script should start kdump manually to save time img_run_cmd "systemctl disable kdump.service"
The crashkernel kernel parameter failed to be configured with the error,
/lib/kdump/kdump-lib.sh: line 976: /dev/fd/63: No such file or directory
_crashkernel_add uses process substitution (<(command)) which won't work when /dev and /proc are not mounted. This patch bind-mounts /proc/ and /dev so _crashkernel_add won't return empty value.
Signed-off-by: Coiby Xu coxu@redhat.com Fixes: 64f2827a ("kdump-lib: Harden _crashkernel_add") --- tests/scripts/image-init-lib.sh | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/tests/scripts/image-init-lib.sh b/tests/scripts/image-init-lib.sh index b0af7f8c..5082ae59 100644 --- a/tests/scripts/image-init-lib.sh +++ b/tests/scripts/image-init-lib.sh @@ -178,11 +178,17 @@ mount_image() { $SUDO mount $mnt_dev $mnt [ $? -ne 0 ] && perror_exit "failed to mount device '$mnt_dev'" boot=$(get_mount_boot "$dev") + root=$(get_image_mount_root $image) if [[ -n "$boot" ]]; then - root=$(get_image_mount_root $image) $SUDO mount $boot $root/boot [ $? -ne 0 ] && perror_exit "failed to mount the bootable partition for device '$mnt_dev'" fi + + # bind-mount /proc/ and /dev to support process substitution <(command) + # Currently needed for setting up the crashkernel kernel parameter + for target in proc dev; do + $SUDO mount -o bind /$target $root/$target + done }
get_image_mount_root() {
Fixes: ec3bccdf ("Add a makedumpfile subpackage") Signed-off-by: Coiby Xu coxu@redhat.com --- tests/Makefile | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/tests/Makefile b/tests/Makefile index 45688caf..4e92aef0 100644 --- a/tests/Makefile +++ b/tests/Makefile @@ -32,6 +32,8 @@ KEXEC_TOOLS_SRC = $(filter-out $(REPO)/tests,$(wildcard $(REPO)/*)) KEXEC_TOOLS_TEST_SRC = $(wildcard $(REPO)/tests/scripts/**/*) KEXEC_TOOLS_NVR = $(shell rpm $(RPMDEFINE) -q --specfile $(REPO)/$(SPEC) 2>/dev/null | grep -m 1 . | sed -e 's#.src#.$(ARCH)#') KEXEC_TOOLS_RPM = $(BUILD_ROOT)/$(ARCH)/$(KEXEC_TOOLS_NVR).rpm +MAKEDUMPFILE_NVR = $(shell rpm $(RPMDEFINE) -q --specfile $(REPO)/$(SPEC) 2>/dev/null | grep -m 2 . | tail -1 | sed -e 's#.src#.$(ARCH)#') +MAKEDUMPFILE_RPM = $(BUILD_ROOT)/$(ARCH)/$(MAKEDUMPFILE_NVR).rpm
all: $(TEST_ROOT)/output/test-base-image
@@ -67,14 +69,14 @@ $(BUILD_ROOT)/inst-base-image: $(BUILD_ROOT)/base-image $(BUILD_ROOT)/inst-base-image \ $(TEST_ROOT)/scripts/build-scripts/base-image.sh
-$(TEST_ROOT)/output/test-base-image: $(BUILD_ROOT)/inst-base-image $(KEXEC_TOOLS_RPM) $(KEXEC_TOOLS_TEST_SRC) $(EXTRA_RPMS) +$(TEST_ROOT)/output/test-base-image: $(BUILD_ROOT)/inst-base-image $(KEXEC_TOOLS_RPM) $(MAKEDUMPFILE_RPM) $(KEXEC_TOOLS_TEST_SRC) $(EXTRA_RPMS) @echo "Building test base image" mkdir -p $(TEST_ROOT)/output $(TEST_ROOT)/scripts/build-image.sh \ $(BUILD_ROOT)/inst-base-image \ $(TEST_ROOT)/output/test-base-image \ $(TEST_ROOT)/scripts/build-scripts/test-base-image.sh \ - $(KEXEC_TOOLS_RPM) $(EXTRA_RPMS) + $(KEXEC_TOOLS_RPM) $(MAKEDUMPFILE_RPM) $(EXTRA_RPMS)
test-run: $(TEST_ROOT)/output/test-base-image ifeq ($(strip $(TEST_CASE)),)