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: Steven Rostedt <rostedt@goodmis.org>
This commit is contained in:
committed by
Steven Rostedt
parent
c5dacb88f0
commit
bc7c580377
@@ -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 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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 {
|
|||||||
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 {
|
|||||||
# 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
|
|||||||
}
|
}
|
||||||
|
|
||||||
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 {
|
|||||||
|
|
||||||
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 {
|
|||||||
|
|
||||||
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 {
|
|||||||
|
|
||||||
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 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
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++) {
|
|||||||
$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++) {
|
|||||||
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 @@
|
|||||||
# 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:
|
||||||
#
|
#
|
||||||
|
Reference in New Issue
Block a user