ktest: Only ask options needed for install
authorSteven Rostedt <srostedt@redhat.com>
Sun, 27 Nov 2011 01:56:52 +0000 (20:56 -0500)
committerSteven Rostedt <rostedt@goodmis.org>
Fri, 23 Dec 2011 02:59:30 +0000 (21:59 -0500)
If all the tests are only for build or install, do not ask
for options not needed to do the install, if the options do
not exist.

Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
tools/testing/ktest/ktest.pl

index 2b547d6683cdc6103b5939fcfdeee3681772bc8e..5d82c275e9e62b67b22ee083cae7131926170103 100755 (executable)
@@ -136,7 +136,7 @@ my $localversion;
 my $iteration = 0;
 my $successes = 0;
 
-# set when a test is something other that just building
+# set when a test is something other that just building or install
 # which would require more options.
 my $buildonly = 1;
 
@@ -343,11 +343,15 @@ sub get_ktest_configs {
 
     # options required for other than just building a kernel
     if (!$buildonly) {
+       get_ktest_config("POWER_CYCLE");
+       get_ktest_config("CONSOLE");
+    }
+
+    # options required for install and more
+    if ($buildonly != 1) {
        get_ktest_config("SSH_USER");
        get_ktest_config("BUILD_TARGET");
        get_ktest_config("TARGET_IMAGE");
-       get_ktest_config("POWER_CYCLE");
-       get_ktest_config("CONSOLE");
     }
 
     get_ktest_config("LOCALVERSION");
@@ -412,10 +416,15 @@ sub process_variables {
 sub set_value {
     my ($lvalue, $rvalue, $override, $overrides, $name) = @_;
 
-    if ($lvalue =~ /^TEST_TYPE(\[.*\])?$/ && $rvalue ne "build") {
+    if ($buildonly && $lvalue =~ /^TEST_TYPE(\[.*\])?$/ && $rvalue ne "build") {
        # Note if a test is something other than build, then we
        # will need other manditory options.
-       $buildonly = 0;
+       if ($rvalue ne "install") {
+           $buildonly = 0;
+       } else {
+           # install still limits some manditory options.
+           $buildonly = 2;
+       }
     }
 
     if (defined($opt{$lvalue})) {