File: issue-9.t

package info (click to toggle)
perl 5.42.0-2
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 128,392 kB
  • sloc: perl: 534,963; ansic: 240,563; sh: 72,042; pascal: 6,934; xml: 2,428; yacc: 1,360; makefile: 1,197; cpp: 208; lisp: 1
file content (71 lines) | stat: -rw-r--r-- 1,727 bytes parent folder | download | duplicates (2)
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
use warnings FATAL => 'all';
use strict;

BEGIN {
    if (eval { require Test2::Tools::Tiny }) {
        print "# Using Test2::Tools::Tiny\n";
        Test2::Tools::Tiny->import();
    }
    elsif (eval { require Test::More; Test::More->can('done_testing') ? 1 : 0 }) {
        print "# Using Test::More " . Test::More->VERSION . "\n";
        Test::More->import();
    }
    else {
        print "1..0 # SKIP Neither Test2::Tools::Tiny nor a sufficient Test::More is installed\n";
        exit(0);
    }
}

use Term::Table;

my @rows;
my @cols = 1..1;

push(@rows, \@cols) for 1..1;

my $table = Term::Table->new(max_width => 4, collapse => 0, rows => \@rows);
my @table;

my $ok = eval {
    local $SIG{ALRM} = sub { die "timeout" };
    alarm 5;
    @table = $table->render;
    1;
};

ok($@ !~ m/timeout/, "Did not timeout");
ok($@ =~ m/Table is too large \(9 including 4 padding\) to fit into max-width \(4\)/, "Threw proper exception");
ok(!@table, "Did not render");



$table = Term::Table->new(max_width => 4, collapse => 0, rows => \@rows, pad => 0);

$ok = eval {
    local $SIG{ALRM} = sub { die "timeout" };
    alarm 5;
    @table = $table->render;
    1;
};

ok($@ !~ m/timeout/, "Did not timeout");
ok($@ =~ m/Table is too large \(5 including 0 padding\) to fit into max-width \(4\)/, "Threw proper exception");
ok(!@table, "Did not render");



$table = Term::Table->new(max_width => 4, collapse => 0, rows => \@rows, allow_overflow => 1);

$ok = eval {
    local $SIG{ALRM} = sub { die "timeout" };
    alarm 5;
    @table = $table->render;
    1;
};

ok($ok, "Did not die");
ok($@ !~ m/timeout/, "Did not timeout");
ok(@table, "rendered");
ok(length($table[0]) == 5, "overflow in rendering");

done_testing;