97b3b962a9
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2242185
grep (3.8) warnings when running the unit tests or running
"kdumpctl reset-crashkernel" on >= F39,
# unit tests
Examples:
1) kdumpctl _find_kernel_path_by_release() returns the kernel path for the given release
When call _find_kernel_path_by_release vmlinuz-6.2.11-200.fc37.x86_64
1.1) WARNING: There was output to stderr but not found expectation
stderr: grep: warning: stray \ before /
# spec/kdumpctl_general_spec.sh:169-172
# kdumpctl reset-crashkernel
grep: warning: stray \ before /
kdump: Updated crashkernel=1G-4G:192M,4G-64G:256M,64G-:512M for kernel=/boot/vmlinuz-6.6.8-200.fc39.x86_64. Please reboot the system for the change to take effect.
This warning can be reproduced by
echo 'kernel="/boot/vmlinuz-6.4.6-200.fc38.x86_64"' | grep -E "^kernel=.*$_release(\/\w+)?\"$"
This patch removes unneeded backslash. It also adds a test for
systemd-boot path. And for simplification, Parameters:dynamic is now
used to generate test data dynamically.
Fixes: 8af05dc4
("kdumpctl: Add support for systemd-boot paths")
Signed-off-by: Coiby Xu <coxu@redhat.com>
Reviewed-by: Philipp Rudo <prudo@redhat.com>
216 lines
6.0 KiB
Bash
216 lines
6.0 KiB
Bash
#!/bin/bash
|
|
Describe 'kdumpctl'
|
|
Include ./kdumpctl
|
|
|
|
Describe 'get_grub_kernel_boot_parameter()'
|
|
grubby() {
|
|
%text
|
|
#|index=1
|
|
#|kernel="/boot/vmlinuz-5.14.14-200.fc34.x86_64"
|
|
#|args="crashkernel=11M nvidia-drm.modeset=1 crashkernel=100M ro rhgb quiet crcrashkernel=200M crashkernel=32T-64T:128G,64T-102400T:180G fadump=on"
|
|
#|root="UUID=45fdf703-3966-401b-b8f7-cf056affd2b0"
|
|
}
|
|
DUMMY_PARAM=/boot/vmlinuz
|
|
|
|
Context "when given a kernel parameter in different positions"
|
|
# Test the following cases:
|
|
# - the kernel parameter in the end
|
|
# - the kernel parameter in the first
|
|
# - the kernel parameter is crashkernel (suffix of crcrashkernel)
|
|
# - the kernel parameter that does not exist
|
|
# - the kernel parameter doesn't have a value
|
|
Parameters
|
|
# parameter answer
|
|
fadump on
|
|
nvidia-drm.modeset 1
|
|
crashkernel 32T-64T:128G,64T-102400T:180G
|
|
aaaa ""
|
|
ro ""
|
|
End
|
|
|
|
It 'should retrieve the value succesfully'
|
|
When call get_grub_kernel_boot_parameter "$DUMMY_PARAM" "$2"
|
|
The output should equal "$3"
|
|
End
|
|
End
|
|
|
|
It 'should retrive the last value if multiple <parameter=value> entries exist'
|
|
When call get_grub_kernel_boot_parameter "$DUMMY_PARAM" crashkernel
|
|
The output should equal '32T-64T:128G,64T-102400T:180G'
|
|
End
|
|
|
|
It 'should fail when called with kernel_path=ALL'
|
|
When call get_grub_kernel_boot_parameter ALL ro
|
|
The status should be failure
|
|
The error should include "kernel_path=ALL invalid"
|
|
End
|
|
End
|
|
|
|
Describe 'get_dump_mode_by_fadump_val()'
|
|
|
|
Context 'when given valid fadump values'
|
|
Parameters
|
|
"#1" on fadump
|
|
"#2" nocma fadump
|
|
"#3" "" kdump
|
|
"#4" off kdump
|
|
End
|
|
It "should return the dump mode correctly"
|
|
When call get_dump_mode_by_fadump_val "$2"
|
|
The output should equal "$3"
|
|
The status should be success
|
|
End
|
|
End
|
|
|
|
It 'should complain given invalid fadump value'
|
|
When call get_dump_mode_by_fadump_val /boot/vmlinuz
|
|
The status should be failure
|
|
The error should include 'invalid fadump'
|
|
End
|
|
|
|
End
|
|
|
|
Describe "read_proc_environ_var()"
|
|
environ_test_file=$(mktemp -t spec_test_environ_test_file.XXXXXXXXXX)
|
|
cleanup() {
|
|
rm -rf "$environ_test_file"
|
|
}
|
|
AfterAll 'cleanup'
|
|
echo -ne "container=bwrap-osbuild\x00SSH_AUTH_SOCK=/tmp/ssh-XXXXXXEbw33A/agent.1794\x00SSH_AGENT_PID=1929\x00env=test_env" >"$environ_test_file"
|
|
Parameters
|
|
container bwrap-osbuild
|
|
SSH_AUTH_SOCK /tmp/ssh-XXXXXXEbw33A/agent.1794
|
|
env test_env
|
|
not_exist ""
|
|
End
|
|
It 'should read the environ variable value as expected'
|
|
When call read_proc_environ_var "$1" "$environ_test_file"
|
|
The output should equal "$2"
|
|
The status should be success
|
|
End
|
|
End
|
|
|
|
Describe "_is_osbuild()"
|
|
environ_test_file=$(mktemp -t spec_test_environ_test_file.XXXXXXXXXX)
|
|
# shellcheck disable=SC2034
|
|
# override the _OSBUILD_ENVIRON_PATH variable
|
|
_OSBUILD_ENVIRON_PATH="$environ_test_file"
|
|
Parameters
|
|
'container=bwrap-osbuild' success
|
|
'' failure
|
|
End
|
|
It 'should be able to tell if it is the osbuild environment'
|
|
echo -ne "$1" >"$environ_test_file"
|
|
When call _is_osbuild
|
|
The status should be "$2"
|
|
The stderr should equal ""
|
|
End
|
|
End
|
|
|
|
Describe "_get_dracut_arg"
|
|
dracut_args='-o "foo bar baz" -t 1 --test="a b c" --omit bla'
|
|
Parameters
|
|
-o --omit 2 "foo bar baz bla"
|
|
-e --empty 0 ""
|
|
-t "" 1 "1"
|
|
"" --test 1 "a b c"
|
|
"" "" 0 ""
|
|
End
|
|
It "should parse the dracut_args correctly"
|
|
When call _get_dracut_arg "$1" "$2" "$dracut_args"
|
|
The status should equal $3
|
|
The output should equal "$4"
|
|
End
|
|
End
|
|
|
|
Describe "is_dracut_mod_omitted()"
|
|
KDUMP_CONFIG_FILE=$(mktemp -t kdump_conf.XXXXXXXXXX)
|
|
cleanup() {
|
|
rm -f "$kdump_conf"
|
|
}
|
|
AfterAll 'cleanup'
|
|
|
|
Parameters:dynamic
|
|
for opt in '-o ' '--omit ' '--omit='; do
|
|
for val in \
|
|
'foo' \
|
|
'"foo"' \
|
|
'"foo bar baz"' \
|
|
'"bar foo baz"' \
|
|
'"bar baz foo"'; do
|
|
%data success foo "$opt$val"
|
|
%data success foo "-a x $opt$val -i y"
|
|
%data failure xyz "$opt$val"
|
|
%data failure xyz "-a x $opt$val -i y"
|
|
done
|
|
done
|
|
%data success foo "-o xxx -o foo"
|
|
%data failure foo "-a x -i y"
|
|
End
|
|
It "shall return $1 for module $2 and dracut_args '$3'"
|
|
echo "dracut_args $3" > $KDUMP_CONFIG_FILE
|
|
parse_config
|
|
When call is_dracut_mod_omitted $2
|
|
The status should be $1
|
|
End
|
|
End
|
|
|
|
Describe '_find_kernel_path_by_release()'
|
|
# When the array length changes, the Parameters:dynamic should change as well
|
|
kernel_paths=(/boot/vmlinuz-6.2.11-200.fc37.x86_64
|
|
/boot/vmlinuz-5.14.0-316.el9.aarch64+64k
|
|
/boot/vmlinuz-5.14.0-322.el9.aarch64
|
|
/boot/efi/36b54597c46383/6.4.0-0.rc0.20230427git6e98b09da931.5.fc39.aarch64/linux)
|
|
|
|
kernels=(vmlinuz-6.2.11-200.fc37.x86_64
|
|
vmlinuz-5.14.0-316.el9.aarch64+64k
|
|
vmlinuz-5.14.0-322.el9.aarch64
|
|
6.4.0-0.rc0.20230427git6e98b09da931.5.fc39.aarch64)
|
|
|
|
grubby() {
|
|
for key in "${!kernel_paths[@]}"; do
|
|
echo "kernel=\"${kernel_paths[$key]}\""
|
|
done
|
|
}
|
|
|
|
Parameters:dynamic
|
|
# Due to a bug [1] in shellspec, hardcode the loop number instead of using the
|
|
# array length
|
|
# [1] https://github.com/shellspec/shellspec/issues/259
|
|
for key in {0..3}; do
|
|
%data "${kernels[$key]}" "${kernel_paths[$key]}"
|
|
done
|
|
End
|
|
|
|
It 'returns the kernel path for the given release'
|
|
When call _find_kernel_path_by_release "$1"
|
|
The output should equal "$2"
|
|
End
|
|
End
|
|
|
|
Describe 'parse_config()'
|
|
KDUMP_CONFIG_FILE=$(mktemp -t kdump_conf.XXXXXXXXXX)
|
|
cleanup() {
|
|
rm -f "$KDUMP_CONFIG_FILE"
|
|
}
|
|
AfterAll 'cleanup'
|
|
|
|
It 'should not be happy with unkown option in kdump.conf'
|
|
echo blabla > "$KDUMP_CONFIG_FILE"
|
|
When call parse_config
|
|
The status should be failure
|
|
The stderr should include 'Invalid kdump config option blabla'
|
|
End
|
|
|
|
Parameters:value aarch64 ppc64le s390x x86_64
|
|
|
|
It 'should be happy with the default kdump.conf'
|
|
./gen-kdump-conf.sh "$1" > "$KDUMP_CONFIG_FILE"
|
|
When call parse_config
|
|
The status should be success
|
|
End
|
|
|
|
End
|
|
|
|
End
|