summaryrefslogtreecommitdiff
path: root/cpan/podlators/t/man-empty.t
blob: 1e094c8527e3d3e615f01db4a171b5fcfc262d59 (plain)
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
#!/usr/bin/perl -w
#
# man-empty.t -- Test Pod::Man with a document that produces only errors.
#
# Copyright 2013 Russ Allbery <rra@stanford.edu>
#
# This program is free software; you may redistribute it and/or modify it
# under the same terms as Perl itself.

BEGIN {
    chdir 't' if -d 't';
    if ($ENV{PERL_CORE}) {
        @INC = '../lib';
    }
    unshift (@INC, '../blib/lib');
    $| = 1;
}

use strict;

use Test::More tests => 8;
BEGIN { use_ok ('Pod::Man') }

# Set up Pod::Man to output to a string.
my $parser = Pod::Man->new;
isa_ok ($parser, 'Pod::Man');
my $output;
$parser->output_string (\$output);

# Try a POD document where the only command is invalid.  With recent
# Pod::Simple, there will be a POD ERRORS section.  With older versions of
# Pod::Simple, we have to skip the test since it doesn't trigger this problem.
# Be sure that we don't get any warnings as well as any errors.
local $SIG{__WARN__} = sub { die $_[0] };
ok (eval { $parser->parse_string_document("=\xa0") },
    'Parsed invalid document');
is ($@, '', '...with no errors');
SKIP: {
    skip 'Pod::Simple does not produce errors for invalid commands', 1
        if $output eq q{};
    like ($output, qr{\.SH \"POD ERRORS\"},
          '...and output contains a POD ERRORS section');
}

# Try with a document containing only =cut.
ok (eval { $parser->parse_string_document("=cut") },
    'Parsed invalid document');
is ($@, '', '...with no errors');
SKIP: {
    skip 'Pod::Simple does not produce errors for invalid commands', 1
        if $output eq q{};
    like ($output, qr{\.SH \"POD ERRORS\"},
          '...and output contains a POD ERRORS section');
}