diff options
Diffstat (limited to 'tools/testing')
-rw-r--r-- | tools/testing/ktest/ktest.pl | 142 |
1 files changed, 140 insertions, 2 deletions
diff --git a/tools/testing/ktest/ktest.pl b/tools/testing/ktest/ktest.pl index f344fd0d4f28..e0ded14b5477 100644 --- a/tools/testing/ktest/ktest.pl +++ b/tools/testing/ktest/ktest.pl | |||
@@ -34,7 +34,9 @@ my $noclean; | |||
34 | my $minconfig; | 34 | my $minconfig; |
35 | my $in_bisect = 0; | 35 | my $in_bisect = 0; |
36 | my $bisect_bad = ""; | 36 | my $bisect_bad = ""; |
37 | my $in_patchcheck = 0; | ||
37 | my $run_test; | 38 | my $run_test; |
39 | my $redirect; | ||
38 | 40 | ||
39 | sub read_config { | 41 | sub read_config { |
40 | my ($config) = @_; | 42 | my ($config) = @_; |
@@ -88,13 +90,18 @@ sub dodie { | |||
88 | sub run_command { | 90 | sub run_command { |
89 | my ($command) = @_; | 91 | my ($command) = @_; |
90 | my $redirect_log = ""; | 92 | my $redirect_log = ""; |
93 | my $redirect_tee = ""; | ||
91 | 94 | ||
92 | if (defined($opt{"LOG_FILE"})) { | 95 | if (defined($opt{"LOG_FILE"})) { |
93 | $redirect_log = " >> $opt{LOG_FILE} 2>&1"; | 96 | $redirect_log = "| tee -a $opt{LOG_FILE}"; |
97 | } | ||
98 | |||
99 | if (defined($redirect)) { | ||
100 | $redirect_tee = "| tee $redirect" | ||
94 | } | 101 | } |
95 | 102 | ||
96 | doprint "$command ... "; | 103 | doprint "$command ... "; |
97 | `$command $redirect_log`; | 104 | `$command 2>&1 $redirect_tee $redirect_log > /dev/null`; |
98 | 105 | ||
99 | my $failed = $?; | 106 | my $failed = $?; |
100 | 107 | ||
@@ -311,6 +318,37 @@ sub install { | |||
311 | run_command "ssh $target rm -f /tmp/$modtar"; | 318 | run_command "ssh $target rm -f /tmp/$modtar"; |
312 | } | 319 | } |
313 | 320 | ||
321 | sub check_buildlog { | ||
322 | my ($patch) = @_; | ||
323 | |||
324 | my $buildlog = "$opt{TMP_DIR}/buildlog"; | ||
325 | my @files = `git show $patch | diffstat -l`; | ||
326 | |||
327 | open(IN, "git show $patch |") or | ||
328 | dodie "failed to show $patch"; | ||
329 | while (<IN>) { | ||
330 | if (m,^--- a/(.*),) { | ||
331 | chomp $1; | ||
332 | $files[$#files] = $1; | ||
333 | } | ||
334 | } | ||
335 | close(IN); | ||
336 | |||
337 | open(IN, $buildlog) or dodie "Can't open $buildlog"; | ||
338 | while (<IN>) { | ||
339 | if (/^\s*(.*?):.*(warning|error)/) { | ||
340 | my $err = $1; | ||
341 | foreach my $file (@files) { | ||
342 | my $fullpath = "$opt{BUILD_DIR}/$file"; | ||
343 | if ($file eq $err || $fullpath eq $err) { | ||
344 | dodie "$file built with warnings"; | ||
345 | } | ||
346 | } | ||
347 | } | ||
348 | } | ||
349 | close(IN); | ||
350 | } | ||
351 | |||
314 | sub build { | 352 | sub build { |
315 | my ($type) = @_; | 353 | my ($type) = @_; |
316 | my $defconfig = ""; | 354 | my $defconfig = ""; |
@@ -358,11 +396,18 @@ sub build { | |||
358 | run_command "$defconfig $append $make $type" or | 396 | run_command "$defconfig $append $make $type" or |
359 | dodie "failed make config"; | 397 | dodie "failed make config"; |
360 | 398 | ||
399 | # patch check will examine the log | ||
400 | if ($in_patchcheck) { | ||
401 | $redirect = "$opt{TMP_DIR}/buildlog"; | ||
402 | } | ||
403 | |||
361 | if (!run_command "$make $opt{BUILD_OPTIONS}") { | 404 | if (!run_command "$make $opt{BUILD_OPTIONS}") { |
405 | undef $redirect; | ||
362 | # bisect may need this to pass | 406 | # bisect may need this to pass |
363 | return 1 if ($in_bisect); | 407 | return 1 if ($in_bisect); |
364 | dodie "failed build"; | 408 | dodie "failed build"; |
365 | } | 409 | } |
410 | undef $redirect; | ||
366 | 411 | ||
367 | return 0; | 412 | return 0; |
368 | } | 413 | } |
@@ -602,6 +647,90 @@ sub bisect { | |||
602 | success $i; | 647 | success $i; |
603 | } | 648 | } |
604 | 649 | ||
650 | sub patchcheck { | ||
651 | my ($i) = @_; | ||
652 | |||
653 | die "PATCHCHECK_START[$i] not defined\n" | ||
654 | if (!defined($opt{"PATCHCHECK_START[$i]"})); | ||
655 | die "PATCHCHECK_TYPE[$i] not defined\n" | ||
656 | if (!defined($opt{"PATCHCHECK_TYPE[$i]"})); | ||
657 | |||
658 | my $start = $opt{"PATCHCHECK_START[$i]"}; | ||
659 | |||
660 | my $end = "HEAD"; | ||
661 | if (defined($opt{"PATCHCHECK_END[$i]"})) { | ||
662 | $end = $opt{"PATCHCHECK_END[$i]"}; | ||
663 | } | ||
664 | |||
665 | my $type = $opt{"PATCHCHECK_TYPE[$i]"}; | ||
666 | |||
667 | # Can't have a test without having a test to run | ||
668 | if ($type eq "test" && !defined($run_test)) { | ||
669 | $type = "boot"; | ||
670 | } | ||
671 | |||
672 | open (IN, "git log --pretty=oneline $end|") or | ||
673 | dodie "could not get git list"; | ||
674 | |||
675 | my @list; | ||
676 | |||
677 | while (<IN>) { | ||
678 | chomp; | ||
679 | $list[$#list+1] = $_; | ||
680 | last if (/^$start/); | ||
681 | } | ||
682 | close(IN); | ||
683 | |||
684 | if ($list[$#list] !~ /^$start/) { | ||
685 | dodie "SHA1 $start not found"; | ||
686 | } | ||
687 | |||
688 | # go backwards in the list | ||
689 | @list = reverse @list; | ||
690 | |||
691 | my $save_clean = $noclean; | ||
692 | |||
693 | $in_patchcheck = 1; | ||
694 | foreach my $item (@list) { | ||
695 | my $sha1 = $item; | ||
696 | $sha1 =~ s/^([[:xdigit:]]+).*/$1/; | ||
697 | |||
698 | doprint "\nProcessing commit $item\n\n"; | ||
699 | |||
700 | run_command "git checkout $sha1" or | ||
701 | die "Failed to checkout $sha1"; | ||
702 | |||
703 | # only clean on the first and last patch | ||
704 | if ($item eq $list[0] || | ||
705 | $item eq $list[$#list]) { | ||
706 | $noclean = $save_clean; | ||
707 | } else { | ||
708 | $noclean = 1; | ||
709 | } | ||
710 | |||
711 | if (defined($minconfig)) { | ||
712 | build "useconfig:$minconfig"; | ||
713 | } else { | ||
714 | # ?? no config to use? | ||
715 | build "oldconfig"; | ||
716 | } | ||
717 | |||
718 | check_buildlog $sha1; | ||
719 | |||
720 | next if ($type eq "build"); | ||
721 | |||
722 | get_grub_index; | ||
723 | get_version; | ||
724 | install; | ||
725 | monitor; | ||
726 | |||
727 | next if ($type eq "boot"); | ||
728 | do_run_test; | ||
729 | } | ||
730 | $in_patchcheck = 0; | ||
731 | success $i; | ||
732 | } | ||
733 | |||
605 | read_config $ARGV[0]; | 734 | read_config $ARGV[0]; |
606 | 735 | ||
607 | # mandatory configs | 736 | # mandatory configs |
@@ -656,9 +785,18 @@ for (my $i = 1; $i <= $opt{"NUM_BUILDS"}; $i++) { | |||
656 | doprint "\n\n"; | 785 | doprint "\n\n"; |
657 | doprint "RUNNING TEST $i of $opt{NUM_BUILDS} with option $opt{$type}\n\n"; | 786 | doprint "RUNNING TEST $i of $opt{NUM_BUILDS} with option $opt{$type}\n\n"; |
658 | 787 | ||
788 | my $checkout = $opt{"CHECKOUT[$i]"}; | ||
789 | if (defined($checkout)) { | ||
790 | run_command "git checkout $checkout" or | ||
791 | die "failed to checkout $checkout"; | ||
792 | } | ||
793 | |||
659 | if ($opt{$type} eq "bisect") { | 794 | if ($opt{$type} eq "bisect") { |
660 | bisect $i; | 795 | bisect $i; |
661 | next; | 796 | next; |
797 | } elsif ($opt{$type} eq "patchcheck") { | ||
798 | patchcheck $i; | ||
799 | next; | ||
662 | } | 800 | } |
663 | 801 | ||
664 | if ($opt{$type} ne "nobuild") { | 802 | if ($opt{$type} ne "nobuild") { |