# -*- 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) 2002 Zach Lipton. All # Rights Reserved. # # Contributor(s): Zach Lipton # # Alternatively, the contents of this file may be used under the # terms of the GNU General Public License Version 2 or later (the # "GPL"), in which case the provisions of the GPL are applicable # instead of those above. If you wish to allow use of your # version of this file only under the terms of the GPL and not to # allow others to use your version of this file under the MPL, # indicate your decision by deleting the provisions above and # replace them with the notice and other provisions required by # the GPL. If you do not delete the provisions above, a recipient # may use your version of this file under either the MPL or the # GPL. # ################# #Bugzilla Test 6# ####Spelling##### use lib 't'; use Support::Files; BEGIN { # yes the indenting is off, deal with it #add the words to check here: @evilwords = qw( databasa arbitary ); $testcount = scalar(@Support::Files::testitems) * scalar(@evilwords); } use Test::More tests => $testcount; # 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; # at last, here we actually run the test... foreach my $file (@testitems) { $file =~ s/\s.*$//; # nuke everything after the first space (#comment) next if (!$file); # skip null entries if (! open (FILE, $file)) { # open the file for reading ok(0,"could not open $file for spellcheck --WARNING"); next; } foreach my $word (@evilwords) { # go through the evilwords while (my $file_line = ) { # and go through the file line by line if ($file_line =~ /$word/i) { # found an evil word $found_word = 1; last; } } if ($found_word eq 1) { ok(0,"$file: found SPELLING ERROR $word --WARNING") } if ($found_word ne 1) { ok(1,"$file does not contain the spelling error $word") } $found_word = 0; } } exit 0;