diff options
| author | Steven Rostedt <srostedt@redhat.com> | 2011-09-30 18:00:23 -0400 |
|---|---|---|
| committer | Steven Rostedt <rostedt@goodmis.org> | 2011-10-17 11:54:10 -0400 |
| commit | 2b803365a6fa177ea7e1f64f645be1cb5dd39d55 (patch) | |
| tree | 88065b809c9ff127329fd6e633bec2859c9719b8 /tools | |
| parent | e0a8742e3d4b7649be2ca6f22e7d45153505fc81 (diff) | |
ktest: Add option REBOOT_SUCCESS_LINE to stop waiting after a reboot
When ktest.pl reboots, it will usuall wait SLEEP_TIME seconds of idle
console before starting the next test. By setting the
REBOOT_SUCCESS_LINE, ktest will not wait SLEEP_TIME when it detects the
line while rebooting to a new kernel.
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'tools')
| -rwxr-xr-x | tools/testing/ktest/ktest.pl | 33 | ||||
| -rw-r--r-- | tools/testing/ktest/sample.conf | 10 |
2 files changed, 37 insertions, 6 deletions
diff --git a/tools/testing/ktest/ktest.pl b/tools/testing/ktest/ktest.pl index 74fb2acae18d..51ddaa5ed556 100755 --- a/tools/testing/ktest/ktest.pl +++ b/tools/testing/ktest/ktest.pl | |||
| @@ -117,6 +117,7 @@ my $timeout; | |||
| 117 | my $booted_timeout; | 117 | my $booted_timeout; |
| 118 | my $detect_triplefault; | 118 | my $detect_triplefault; |
| 119 | my $console; | 119 | my $console; |
| 120 | my $reboot_success_line; | ||
| 120 | my $success_line; | 121 | my $success_line; |
| 121 | my $stop_after_success; | 122 | my $stop_after_success; |
| 122 | my $stop_after_failure; | 123 | my $stop_after_failure; |
| @@ -612,6 +613,13 @@ sub wait_for_monitor; | |||
| 612 | sub reboot { | 613 | sub reboot { |
| 613 | my ($time) = @_; | 614 | my ($time) = @_; |
| 614 | 615 | ||
| 616 | if (defined($time)) { | ||
| 617 | start_monitor; | ||
| 618 | # flush out current monitor | ||
| 619 | # May contain the reboot success line | ||
| 620 | wait_for_monitor 1; | ||
| 621 | } | ||
| 622 | |||
| 615 | # try to reboot normally | 623 | # try to reboot normally |
| 616 | if (run_command $reboot) { | 624 | if (run_command $reboot) { |
| 617 | if (defined($powercycle_after_reboot)) { | 625 | if (defined($powercycle_after_reboot)) { |
| @@ -624,8 +632,7 @@ sub reboot { | |||
| 624 | } | 632 | } |
| 625 | 633 | ||
| 626 | if (defined($time)) { | 634 | if (defined($time)) { |
| 627 | start_monitor; | 635 | wait_for_monitor($time, $reboot_success_line); |
| 628 | wait_for_monitor $time; | ||
| 629 | end_monitor; | 636 | end_monitor; |
| 630 | } | 637 | } |
| 631 | } | 638 | } |
| @@ -706,16 +713,29 @@ sub end_monitor { | |||
| 706 | } | 713 | } |
| 707 | 714 | ||
| 708 | sub wait_for_monitor { | 715 | sub wait_for_monitor { |
| 709 | my ($time) = @_; | 716 | my ($time, $stop) = @_; |
| 717 | my $full_line = ""; | ||
| 710 | my $line; | 718 | my $line; |
| 719 | my $booted = 0; | ||
| 711 | 720 | ||
| 712 | doprint "** Wait for monitor to settle down **\n"; | 721 | doprint "** Wait for monitor to settle down **\n"; |
| 713 | 722 | ||
| 714 | # read the monitor and wait for the system to calm down | 723 | # read the monitor and wait for the system to calm down |
| 715 | do { | 724 | while (!$booted) { |
| 716 | $line = wait_for_input($monitor_fp, $time); | 725 | $line = wait_for_input($monitor_fp, $time); |
| 717 | print "$line" if (defined($line)); | 726 | last if (!defined($line)); |
| 718 | } while (defined($line)); | 727 | print "$line"; |
| 728 | $full_line .= $line; | ||
| 729 | |||
| 730 | if (defined($stop) && $full_line =~ /$stop/) { | ||
| 731 | doprint "wait for monitor detected $stop\n"; | ||
| 732 | $booted = 1; | ||
| 733 | } | ||
| 734 | |||
| 735 | if ($line =~ /\n/) { | ||
| 736 | $full_line = ""; | ||
| 737 | } | ||
| 738 | } | ||
| 719 | print "** Monitor flushed **\n"; | 739 | print "** Monitor flushed **\n"; |
| 720 | } | 740 | } |
| 721 | 741 | ||
| @@ -2836,6 +2856,7 @@ for (my $i = 1; $i <= $opt{"NUM_TESTS"}; $i++) { | |||
| 2836 | $console = set_test_option("CONSOLE", $i); | 2856 | $console = set_test_option("CONSOLE", $i); |
| 2837 | $detect_triplefault = set_test_option("DETECT_TRIPLE_FAULT", $i); | 2857 | $detect_triplefault = set_test_option("DETECT_TRIPLE_FAULT", $i); |
| 2838 | $success_line = set_test_option("SUCCESS_LINE", $i); | 2858 | $success_line = set_test_option("SUCCESS_LINE", $i); |
| 2859 | $reboot_success_line = set_test_option("REBOOT_SUCCESS_LINE", $i); | ||
| 2839 | $stop_after_success = set_test_option("STOP_AFTER_SUCCESS", $i); | 2860 | $stop_after_success = set_test_option("STOP_AFTER_SUCCESS", $i); |
| 2840 | $stop_after_failure = set_test_option("STOP_AFTER_FAILURE", $i); | 2861 | $stop_after_failure = set_test_option("STOP_AFTER_FAILURE", $i); |
| 2841 | $stop_test_after = set_test_option("STOP_TEST_AFTER", $i); | 2862 | $stop_test_after = set_test_option("STOP_TEST_AFTER", $i); |
diff --git a/tools/testing/ktest/sample.conf b/tools/testing/ktest/sample.conf index b3e0dc11fc8a..67bc4e06922c 100644 --- a/tools/testing/ktest/sample.conf +++ b/tools/testing/ktest/sample.conf | |||
| @@ -423,6 +423,14 @@ | |||
| 423 | # (default "login:") | 423 | # (default "login:") |
| 424 | #SUCCESS_LINE = login: | 424 | #SUCCESS_LINE = login: |
| 425 | 425 | ||
| 426 | # To speed up between reboots, defining a line that the | ||
| 427 | # default kernel produces that represents that the default | ||
| 428 | # kernel has successfully booted and can be used to pass | ||
| 429 | # a new test kernel to it. Otherwise ktest.pl will wait till | ||
| 430 | # SLEEP_TIME to continue. | ||
| 431 | # (default undefined) | ||
| 432 | #REBOOT_SUCCESS_LINE = login: | ||
| 433 | |||
| 426 | # In case the console constantly fills the screen, having | 434 | # In case the console constantly fills the screen, having |
| 427 | # a specified time to stop the test after success is recommended. | 435 | # a specified time to stop the test after success is recommended. |
| 428 | # (in seconds) | 436 | # (in seconds) |
| @@ -488,6 +496,8 @@ | |||
| 488 | # another test. If a reboot to the reliable kernel happens, | 496 | # another test. If a reboot to the reliable kernel happens, |
| 489 | # we wait SLEEP_TIME for the console to stop producing output | 497 | # we wait SLEEP_TIME for the console to stop producing output |
| 490 | # before starting the next test. | 498 | # before starting the next test. |
| 499 | # | ||
| 500 | # You can speed up reboot times even more by setting REBOOT_SUCCESS_LINE. | ||
| 491 | # (default 60) | 501 | # (default 60) |
| 492 | #SLEEP_TIME = 60 | 502 | #SLEEP_TIME = 60 |
| 493 | 503 | ||
