| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  | #!/usr/bin/perl -w | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =head1 NAME | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test2tasks.pl - Convert QTest logs into Qt Creator task files. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =head1 SYNOPSIS | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-22 11:29:04 +01:00
										 |  |  |     test2tasks.pl [OPTIONS] < logfile > taskfile | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Options: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     -a              Use absolute file paths | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     -r <some_path>  Prefix all file names by <some_path> (Used for | 
					
						
							|  |  |  |                     creating a summarized log of a submodule repository) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | The script needs to be run in the working directory from which the test log was | 
					
						
							|  |  |  | obtained as it attempts to perform a mapping from the source file base names of | 
					
						
							|  |  |  | the test log to relative path names by searching the files. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | =cut | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use strict; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use File::Find; | 
					
						
							| 
									
										
										
										
											2011-12-22 11:29:04 +01:00
										 |  |  | use Getopt::Long; | 
					
						
							|  |  |  | use File::Spec; | 
					
						
							|  |  |  | use Cwd; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | my $optAbsolute = 0; | 
					
						
							|  |  |  | my $optRelativeTo; | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-05 14:19:56 +01:00
										 |  |  | # --------------- Detect OS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | my ($OS_LINUX, $OS_WINDOWS, $OS_MAC)  = (0, 1, 2); | 
					
						
							|  |  |  | my $os = $OS_LINUX; | 
					
						
							|  |  |  | if (index($^O, 'MSWin') >= 0) { | 
					
						
							|  |  |  |     $os = $OS_WINDOWS; | 
					
						
							|  |  |  | } elsif (index($^O, 'darwin') >= 0) { | 
					
						
							|  |  |  |    $os = $OS_MAC; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  | # -- Build a hash from source file base name to relative paths. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | my %fileHash; | 
					
						
							| 
									
										
										
										
											2011-12-22 11:29:04 +01:00
										 |  |  | my $workingDirectory = getcwd(); | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | sub handleFile | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     my $file = $_; | 
					
						
							| 
									
										
										
										
											2012-01-05 14:19:56 +01:00
										 |  |  |     return unless -f $file; | 
					
						
							|  |  |  |     return unless index($file, '.cpp') != -1 || index($file, '.h') != -1 || index($file, '.qml'); | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  | #   './file' -> 'file' | 
					
						
							| 
									
										
										
										
											2011-12-22 11:29:04 +01:00
										 |  |  |     my $name = substr($File::Find::name, 0, 1) eq '.' ? | 
					
						
							|  |  |  |                substr($File::Find::name, 2) : $File::Find::name; | 
					
						
							|  |  |  |      my $fullName = $name; | 
					
						
							|  |  |  |     if (defined $optRelativeTo) { | 
					
						
							|  |  |  |     $fullName = File::Spec->catfile($optRelativeTo, $File::Find::name); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |     $fullName = File::Spec->catfile($workingDirectory, $File::Find::name) if ($optAbsolute); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     $fullName =~ s|\\|/|g; # The task pane wants forward slashes on Windows, also. | 
					
						
							|  |  |  |     $fileHash{$file} = $fullName; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #   Main | 
					
						
							|  |  |  | if (!GetOptions("absolute" => \$optAbsolute, | 
					
						
							|  |  |  |                 "relative=s" => \$optRelativeTo)) { | 
					
						
							|  |  |  |     print "Invalid option\n"; | 
					
						
							|  |  |  |     exit (0); | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | find({ wanted => \& handleFile}, '.'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # --- Find file locations and format them with the cause of the error | 
					
						
							|  |  |  | #     from the above lines as task entry. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | my $lastLine = ''; | 
					
						
							| 
									
										
										
										
											2011-12-20 15:37:56 +01:00
										 |  |  | my ($failCount, $fatalCount) = (0, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-05 14:19:56 +01:00
										 |  |  | sub isAbsolute | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     my ($f) = @_; | 
					
						
							|  |  |  |     return $f =~ /^[a-zA-Z]:/ ? 1 : 0 if $os eq $OS_WINDOWS; | 
					
						
							|  |  |  |     return index($f, '/') == 0 ? 1 : 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  | while (my $line = <STDIN> ) { | 
					
						
							|  |  |  |     chomp($line); | 
					
						
							|  |  |  |     # --- Continuation line? | 
					
						
							| 
									
										
										
										
											2011-12-09 11:02:54 +01:00
										 |  |  |     if (substr($line, 0, 1) eq ' ' && index($line, 'Loc: [') < 0) { | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  |        $lastLine .= $line; | 
					
						
							|  |  |  |        next; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-12-09 11:02:54 +01:00
										 |  |  |     # --- extract file name based matching: | 
					
						
							|  |  |  |     #     Windows: '[..\].\tst_lancelot.cpp(258) : failure location' | 
					
						
							|  |  |  |     #     Unix:    '  Loc: [file(1596)]' | 
					
						
							|  |  |  |     if ($line =~ /^([^(]+)\((\d+)\) : failure location$/ | 
					
						
							|  |  |  |         || $line =~ /^\s*Loc:\s*\[([^(]+)\((\d+)\).*$/) { | 
					
						
							|  |  |  |         my $fullFileName = $1; | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  |         my $line = $2; | 
					
						
							| 
									
										
										
										
											2012-01-05 14:19:56 +01:00
										 |  |  |         #  -- Fix '/C:/bla' which is sometimes reported for QML errors. | 
					
						
							|  |  |  |         $fullFileName = substr($fullFileName, 1) if ($os eq $OS_WINDOWS && $fullFileName =~ /^\/[a-zA-Z]:\//); | 
					
						
							|  |  |  |         if (!isAbsolute($fullFileName)) { # Unix has absolute file names, Windows may not | 
					
						
							| 
									
										
										
										
											2011-12-09 11:02:54 +01:00
										 |  |  |             my $slashPos = rindex($fullFileName, '/'); | 
					
						
							|  |  |  |             $slashPos = rindex($fullFileName, "\\") if $slashPos < 0; | 
					
						
							| 
									
										
										
										
											2012-01-05 14:19:56 +01:00
										 |  |  |             my $fileName = $slashPos > 0 ? substr($fullFileName, $slashPos + 1) : $fullFileName; | 
					
						
							| 
									
										
										
										
											2011-12-09 11:02:54 +01:00
										 |  |  |             $fullFileName = $fileHash{$fileName}; | 
					
						
							|  |  |  |             $fullFileName = $fileName unless defined $fullFileName; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-07-26 16:35:31 +02:00
										 |  |  |         my $type = index($lastLine, 'FAIL') == 0 || index($lastLine, 'XPASS') == 0 ? | 
					
						
							|  |  |  |                    'err' : 'unknown'; | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  |         print $fullFileName, "\t", $line, "\t", $type, "\t", $lastLine,"\n"; | 
					
						
							| 
									
										
										
										
											2011-12-20 15:37:56 +01:00
										 |  |  |         $failCount++; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         if (index($line, 'QFATAL') == 0 || index($line, 'Received a fatal error.') >= 0) { | 
					
						
							|  |  |  |             print STDERR $line,"\n"; | 
					
						
							|  |  |  |             $fatalCount++; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-12-08 15:59:51 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     $lastLine = $line; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-12-20 15:37:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-22 11:29:04 +01:00
										 |  |  | print STDERR 'Done, ISSUES: ',$failCount, ', FATAL: ',$fatalCount, "\n"; |