Commit be0b080b authored by bugreport%peshkin.net's avatar bugreport%peshkin.net

Bug 163494 - runtests.sh needs a switch to include optional modules

Tests now detect optional modules and only exclude optional files if optional module dependencies are not met. Also major indent cleanup r=timeless
parent 35d4b47b
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
# Rights Reserved. # Rights Reserved.
# #
# Contributor(s): Zach Lipton <zach@zachlipton.com> # Contributor(s): Zach Lipton <zach@zachlipton.com>
# Joel Peshkin <bugreport@peshkin.net>
# #
# Alternatively, the contents of this file may be used under the # Alternatively, the contents of this file may be used under the
# terms of the GNU General Public License Version 2 or later (the # terms of the GNU General Public License Version 2 or later (the
...@@ -34,34 +35,55 @@ ...@@ -34,34 +35,55 @@
package Support::Files; package Support::Files;
# exclude_deps is a hash of arrays listing the files to be excluded
# if a module is not available
#
@additional_files = ('syncshadowdb','processmail'); @additional_files = ('syncshadowdb','processmail');
@exclude_files = ('importxml.pl'); %exclude_deps = (
'XML::Parser' => ['importxml.pl'],
);
# XXX - this file should be rewritten to use File::Find or similar # XXX - this file should be rewritten to use File::Find or similar
$file = '*'; $file = '*';
@files = (glob($file), glob('Bugzilla/*.pm')); @files = (glob($file), glob('Bugzilla/*.pm'));
sub have_pkg {
my ($pkg) = @_;
my ($msg, $vnum, $vstr);
no strict 'refs';
eval { my $p; ($p = $pkg . ".pm") =~ s!::!/!g; require $p; };
return !($@);
}
@exclude_files = ();
foreach $dep (keys(%exclude_deps)) {
if (!have_pkg($dep)) {
push @exclude_files, @{$exclude_deps{$dep}};
}
}
sub isTestingFile { sub isTestingFile {
my ($file) = @_; my ($file) = @_;
my $exclude; my $exclude;
foreach $exclude (@exclude_files) { foreach $exclude (@exclude_files) {
if ($file eq $exclude) { return undef; } # get rid of excluded files. if ($file eq $exclude) { return undef; } # get rid of excluded files.
} }
if ($file =~ /\.cgi$|\.pl$|\.pm$/) { if ($file =~ /\.cgi$|\.pl$|\.pm$/) {
return 1; return 1;
} }
my $additional; my $additional;
foreach $additional (@additional_files) { foreach $additional (@additional_files) {
if ($file eq $additional) { return 1; } if ($file eq $additional) { return 1; }
} }
return undef; return undef;
} }
foreach $currentfile (@files) { foreach $currentfile (@files) {
if (isTestingFile($currentfile)) { if (isTestingFile($currentfile)) {
push(@testitems,$currentfile); push(@testitems,$currentfile);
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment