File: _pod.t

package info (click to toggle)
libtest-inter-perl 1.12-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 352 kB
  • sloc: perl: 1,776; sh: 22; makefile: 6
file content (91 lines) | stat: -rwxr-xr-x 1,850 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#!/usr/bin/perl

use warnings 'all';
use strict;

BEGIN {
   use Test::More;
   # Don't run tests for installs
   unless ($ENV{Test_Inter_RELEASE_TESTING}) {
      plan skip_all => 'Author tests not required for installation (set Test_Inter_RELEASE_TESTING to test)';
   }
}

# CPANTORPM-DEPREQ REQEXCL File::Basename
# CPANTORPM-DEPREQ REQEXCL Cwd
# CPANTORPM-DEPREQ REQEXCL Test::Pod

use File::Basename;
use Cwd 'abs_path';
use Test::Pod 1.00;

# Figure out the directories.  This comes from Test::Inter.

my($moddir,$testdir,$libdir);

BEGIN {
   if (-f "$0") {
      $moddir = dirname(dirname(abs_path($0)));
   } elsif (-d "./t") {
      $moddir = dirname(abs_path('.'));
   } elsif (-d "../t") {
      $moddir = dirname(abs_path('..'));
   }
   if (-d "$moddir/t") {
      $testdir = "$moddir/t";
   }
   if (-d "$moddir/lib") {
      $libdir = "$moddir/lib";
   }
}

# If there is a file _pod.ign, it should be a list of filename
# substrings to ignore (any file with any of these substrings
# will be ignored).
#
# If there is a file named _pod.dirs, then pod files will be looked
# at in those directories (instead of the default of all directories).

my @ign = ();
if (-f "$testdir/_pod.ign") {
   open(IN,"$testdir/_pod.ign");
   @ign = <IN>;
   close(IN);
   chomp(@ign);
}

my @dirs = ();
if (-f "$testdir/_pod.dirs") {
   open(IN,"$testdir/_pod.dirs");
   @dirs = <IN>;
   close(IN);
   chomp(@dirs);
}

#
# Test that the syntax of our POD documentation is valid.
#

chdir($moddir);

if (@ign) {

   my @file = all_pod_files(@dirs);
   my @test;

   FILE:
   foreach my $file (@file) {
      foreach my $ign (@ign) {
         next FILE  if ($file =~ /\Q$ign\E/);
      }
      push(@test,$file);
   }

   plan tests => scalar(@test);
   foreach my $file (@test) {
      pod_file_ok($file);
   }

} else {
   all_pod_files_ok(@dirs);
}