Bug 18350 (QA Followup) Add classes to elements
[koha.git] / t / 00-merge-conflict-markers.t
blob0269328d817386306a0d8ace0ca8493a34b11b65
1 # Copyright 2010 Galen Charlton
3 # This file is part of Koha.
5 # Koha is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 3 of the License, or
8 # (at your option) any later version.
10 # Koha is distributed in the hope that it will be useful, but
11 # WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with Koha; if not, see <http://www.gnu.org/licenses>.
18 use strict;
19 use warnings;
21 use Test::More;
22 use File::Spec;
23 use File::Find;
24 use IO::File;
26 find({
27     bydepth => 1,
28     no_chdir => 1,
29     wanted => sub {
30         my $file = $_;
32         return if $file =~ /\.(ico|jpg|gif|ogg|pdf|png|psd|swf|zip|.*\~)$/;
33         return unless -f $file;
35         my @name_parts = File::Spec->splitpath($file);
36         my %dirs = map { $_ => 1 } File::Spec->splitdir($name_parts[1]);
37         return if exists $dirs{'.git'};
39         my $fh = IO::File->new($file, 'r');
40         my $marker_found = 0;
41         my $line = 0;
42         while (<$fh>) {
43             $line++;
44             if (/^<<<<<</ or /^>>>>>>/) {
45                 # could check for ^=====, but that's often used in text files
46                 $marker_found = 1;
47                 last;
48             }
49         }
50         close $fh;
51         if ($marker_found) {
52             fail("$file contains merge conflict markers in line $line");
53         } else {
54             pass("$file has no merge conflict markers");
55         }
56     },
57 }, File::Spec->curdir());
58 done_testing();