# -*- Mode: perl; indent-tabs-mode: nil -*- # # The contents of this file are subject to the Mozilla Public # License Version 1.1 (the "License"); you may not use this file # except in compliance with the License. You may obtain a copy of # the License at http://www.mozilla.org/MPL/ # # Software distributed under the License is distributed on an "AS # IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or # implied. See the License for the specific language governing # rights and limitations under the License. # # The Original Code are the Bugzilla Tests. # # The Initial Developer of the Original Code is Zach Lipton # Portions created by Zach Lipton are # Copyright (C) 2001 Zach Lipton. All # Rights Reserved. # # Contributor(s): Zach Lipton <zach@zachlipton.com> ################# #Bugzilla Test 1# ###Compilation### use strict; use lib 't'; use Support::Files; use Test::More tests => scalar(@Support::Files::testitems); # Need this to get the available driver information use DBI; my @DBI_drivers = DBI->available_drivers; # Bugzilla requires Perl 5.8.1 now. Checksetup will tell you this if you run it, but # it tests it in a polite/passive way that won't make it fail at compile time. We'll # slip in a compile-time failure if it's missing here so a tinderbox on < 5.8.1 won't # pass and mistakenly let people think Bugzilla works on any perl below 5.8.1. require 5.008001; # Capture the TESTOUT from Test::More or Test::Builder for printing errors. # This will handle verbosity for us automatically. my $fh; { local $^W = 0; # Don't complain about non-existent filehandles if (-e \*Test::More::TESTOUT) { $fh = \*Test::More::TESTOUT; } elsif (-e \*Test::Builder::TESTOUT) { $fh = \*Test::Builder::TESTOUT; } else { $fh = \*STDOUT; } } my @testitems = @Support::Files::testitems; my $perlapp = "\"$^X\""; # Test the scripts by compiling them foreach my $file (@testitems) { $file =~ s/\s.*$//; # nuke everything after the first space (#comment) next if (!$file); # skip null entries # Skip mod_perl.pl in all cases. It doesn't compile correctly from the command line. if ($file eq 'mod_perl.pl') { ok(1, "Skipping mod_perl.pl"); next; } # Check that we have a DBI module to support the DB, if this is a database # module (but not Schema) if ($file =~ m#Bugzilla/DB/([^/]+)\.pm$# && $file ne "Bugzilla/DB/Schema.pm") { if (!grep(lc($_) =~ /$1/i, @DBI_drivers)) { ok(1,$file." - Skipping, as the DBD module not installed"); next; } } open (FILE,$file); my $bang = <FILE>; close (FILE); my $T = ""; if ($bang =~ m/#!\S*perl\s+-.*T/) { $T = "T"; } my $command = "$perlapp -c$T $file 2>&1"; my $loginfo=`$command`; #print '@@'.$loginfo.'##'; if ($loginfo =~ /syntax ok$/im) { # Special hack due to CPAN.pm on Windows with Cygwin installed throwing # strings of the form "Set up gcc environment - 3.4.4 (cygming special, # gdc 0.12, using dmd 0.125)". See bug 416047 for details. if ($^O =~ /MSWin32/i && grep($_ eq $file, 'install-module.pl', 'Bugzilla/Install/CPAN.pm')) { $loginfo =~ s/^Set up gcc environment.*?\n//; } if ($loginfo ne "$file syntax OK\n") { ok(0,$file." --WARNING"); print $fh $loginfo; } else { ok(1,$file); } } else { ok(0,$file." --ERROR"); print $fh $loginfo; } } exit 0;