Commit bc7c5803 authored by Steven Rostedt's avatar Steven Rostedt Committed by Steven Rostedt

ktest: Add options SWITCH_TO_GOOD and SWITCH_TO_TEST

For machines that do no use grub, it may be needed to update an
external image (tftp) before doing a reboot into either the
test image or the known good image.

The option SWITCH_TO_GOOD is added, where if it is defined, the
command that is specified as its value will be executed before
doing a reboot into a known good image.

The option SWITCH_TO_TEST is added, where if it is defined, the
command that is specified as its value will be executed before
doing a reboot into the test image.
Signed-off-by: default avatarSteven Rostedt <rostedt@goodmis.org>
parent c5dacb88
...@@ -79,6 +79,8 @@ my $reboot_script; ...@@ -79,6 +79,8 @@ my $reboot_script;
my $power_cycle; my $power_cycle;
my $reboot; my $reboot;
my $reboot_on_error; my $reboot_on_error;
my $switch_to_good;
my $switch_to_test;
my $poweroff_on_error; my $poweroff_on_error;
my $die_on_failure; my $die_on_failure;
my $powercycle_after_reboot; my $powercycle_after_reboot;
...@@ -964,6 +966,17 @@ sub reboot { ...@@ -964,6 +966,17 @@ sub reboot {
} }
} }
sub reboot_to_good {
my ($time) = @_;
if (defined($switch_to_good)) {
run_command $switch_to_good;
return;
}
reboot $time;
}
sub do_not_reboot { sub do_not_reboot {
my $i = $iteration; my $i = $iteration;
...@@ -980,7 +993,7 @@ sub dodie { ...@@ -980,7 +993,7 @@ sub dodie {
if ($reboot_on_error && !do_not_reboot) { if ($reboot_on_error && !do_not_reboot) {
doprint "REBOOTING\n"; doprint "REBOOTING\n";
reboot; reboot_to_good;
} elsif ($poweroff_on_error && defined($power_off)) { } elsif ($poweroff_on_error && defined($power_off)) {
doprint "POWERING OFF\n"; doprint "POWERING OFF\n";
...@@ -1116,7 +1129,7 @@ sub fail { ...@@ -1116,7 +1129,7 @@ sub fail {
# no need to reboot for just building. # no need to reboot for just building.
if (!do_not_reboot) { if (!do_not_reboot) {
doprint "REBOOTING\n"; doprint "REBOOTING\n";
reboot $sleep_time; reboot_to_good $sleep_time;
} }
my $name = ""; my $name = "";
...@@ -1269,6 +1282,10 @@ sub wait_for_input ...@@ -1269,6 +1282,10 @@ sub wait_for_input
} }
sub reboot_to { sub reboot_to {
if (defined($switch_to_test)) {
run_command $switch_to_test;
}
if ($reboot_type eq "grub") { if ($reboot_type eq "grub") {
run_ssh "'(echo \"savedefault --default=$grub_number --once\" | grub --batch)'"; run_ssh "'(echo \"savedefault --default=$grub_number --once\" | grub --batch)'";
reboot; reboot;
...@@ -1754,7 +1771,7 @@ sub success { ...@@ -1754,7 +1771,7 @@ sub success {
if ($i != $opt{"NUM_TESTS"} && !do_not_reboot) { if ($i != $opt{"NUM_TESTS"} && !do_not_reboot) {
doprint "Reboot and wait $sleep_time seconds\n"; doprint "Reboot and wait $sleep_time seconds\n";
reboot $sleep_time; reboot_to_good $sleep_time;
} }
} }
...@@ -1935,7 +1952,7 @@ sub run_git_bisect { ...@@ -1935,7 +1952,7 @@ sub run_git_bisect {
sub bisect_reboot { sub bisect_reboot {
doprint "Reboot and sleep $bisect_sleep_time seconds\n"; doprint "Reboot and sleep $bisect_sleep_time seconds\n";
reboot $bisect_sleep_time; reboot_to_good $bisect_sleep_time;
} }
# returns 1 on success, 0 on failure, -1 on skip # returns 1 on success, 0 on failure, -1 on skip
...@@ -2528,7 +2545,7 @@ sub config_bisect { ...@@ -2528,7 +2545,7 @@ sub config_bisect {
sub patchcheck_reboot { sub patchcheck_reboot {
doprint "Reboot and sleep $patchcheck_sleep_time seconds\n"; doprint "Reboot and sleep $patchcheck_sleep_time seconds\n";
reboot $patchcheck_sleep_time; reboot_to_good $patchcheck_sleep_time;
} }
sub patchcheck { sub patchcheck {
...@@ -3145,7 +3162,7 @@ sub make_min_config { ...@@ -3145,7 +3162,7 @@ sub make_min_config {
} }
doprint "Reboot and wait $sleep_time seconds\n"; doprint "Reboot and wait $sleep_time seconds\n";
reboot $sleep_time; reboot_to_good $sleep_time;
} }
success $i; success $i;
...@@ -3314,6 +3331,8 @@ for (my $i = 1; $i <= $opt{"NUM_TESTS"}; $i++) { ...@@ -3314,6 +3331,8 @@ for (my $i = 1; $i <= $opt{"NUM_TESTS"}; $i++) {
$no_install = set_test_option("NO_INSTALL", $i); $no_install = set_test_option("NO_INSTALL", $i);
$reboot_script = set_test_option("REBOOT_SCRIPT", $i); $reboot_script = set_test_option("REBOOT_SCRIPT", $i);
$reboot_on_error = set_test_option("REBOOT_ON_ERROR", $i); $reboot_on_error = set_test_option("REBOOT_ON_ERROR", $i);
$switch_to_good = set_test_option("SWITCH_TO_GOOD", $i);
$switch_to_test = set_test_option("SWITCH_TO_TEST", $i);
$poweroff_on_error = set_test_option("POWEROFF_ON_ERROR", $i); $poweroff_on_error = set_test_option("POWEROFF_ON_ERROR", $i);
$die_on_failure = set_test_option("DIE_ON_FAILURE", $i); $die_on_failure = set_test_option("DIE_ON_FAILURE", $i);
$power_off = set_test_option("POWER_OFF", $i); $power_off = set_test_option("POWER_OFF", $i);
...@@ -3472,7 +3491,7 @@ for (my $i = 1; $i <= $opt{"NUM_TESTS"}; $i++) { ...@@ -3472,7 +3491,7 @@ for (my $i = 1; $i <= $opt{"NUM_TESTS"}; $i++) {
if ($opt{"POWEROFF_ON_SUCCESS"}) { if ($opt{"POWEROFF_ON_SUCCESS"}) {
halt; halt;
} elsif ($opt{"REBOOT_ON_SUCCESS"} && !do_not_reboot) { } elsif ($opt{"REBOOT_ON_SUCCESS"} && !do_not_reboot) {
reboot; reboot_to_good;
} }
doprint "\n $successes of $opt{NUM_TESTS} tests were successful\n\n"; doprint "\n $successes of $opt{NUM_TESTS} tests were successful\n\n";
......
...@@ -468,6 +468,27 @@ ...@@ -468,6 +468,27 @@
# The test will not modify that file. # The test will not modify that file.
#REBOOT_TYPE = grub #REBOOT_TYPE = grub
# If you are using a machine that doesn't boot with grub, and
# perhaps gets its kernel from a remote server (tftp), then
# you can use this option to update the target image with the
# test image.
#
# You could also do the same with POST_INSTALL, but the difference
# between that option and this option is that POST_INSTALL runs
# after the install, where this one runs just before a reboot.
# (default undefined)
#SWITCH_TO_TEST = cp ${OUTPUT_DIR}/${BUILD_TARGET} ${TARGET_IMAGE}
# If you are using a machine that doesn't boot with grub, and
# perhaps gets its kernel from a remote server (tftp), then
# you can use this option to update the target image with the
# the known good image to reboot safely back into.
#
# This option holds a command that will execute before needing
# to reboot to a good known image.
# (default undefined)
#SWITCH_TO_GOOD = ssh ${SSH_USER}/${MACHINE} cp good_image ${TARGET_IMAGE}
# The min config that is needed to build for the machine # The min config that is needed to build for the machine
# A nice way to create this is with the following: # A nice way to create this is with the following:
# #
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment