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 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135
|
#!/usr/bin/perl
use v5.26;
use warnings;
use Test2::V0;
use Tickit::Test;
use String::Tagged;
use Tickit::Console;
my $win = mk_window;
my $console = Tickit::Console->new;
$console->set_window( $win );
# Just timestamp, plain
{
my $tab = $console->add_tab(
name => "Tabname",
timestamp_format => "[%H:%M:%S] ",
localtime => sub { gmtime $_[0] },
);
$tab->append_line( "First line",
time => 123456789, # 1973/11/29 21:33:09
);
flush_tickit;
is_display( [ [TEXT("[21:33:09] First line")],
BLANKLINES(22),
[TEXT("[",fg=>7,bg=>4),TEXT("Tabname",fg=>14,bg=>4),TEXT("]",fg=>7,bg=>4),TEXT("",bg=>4)],
BLANKLINE() ],
'Display after tab->append_line with timestamp' );
$console->remove_tab( $tab );
}
# Just timestamp, String::Tagged
{
my $tab = $console->add_tab(
name => "Tabname",
timestamp_format => String::Tagged->new( "[%H:%M] " )
->apply_tag( 1, 2, fg => "red" )
->apply_tag( 4, 2, fg => "blue" ),
localtime => sub { gmtime $_[0] },
);
$tab->append_line( "First line",
time => 123456789, # 1973/11/29 21:33:09
);
flush_tickit;
is_display( [ [TEXT("["), TEXT("21",fg=>1), TEXT(":"), TEXT("33",fg=>4), TEXT("] First line")],
BLANKLINES(22),
[TEXT("[",fg=>7,bg=>4),TEXT("Tabname",fg=>14,bg=>4),TEXT("]",fg=>7,bg=>4),TEXT("",bg=>4)],
BLANKLINE() ],
'Display after tab->append_line with formatted timestamp' );
$console->remove_tab( $tab );
}
# Time + Datestamp, appending
{
my $tab = $console->add_tab(
name => "Tabname",
timestamp_format => "[%H:%M] ",
datestamp_format => "- day is now %Y/%m/%d -",
localtime => sub { gmtime $_[0] },
);
$tab->append_line( "First line",
time => 123456789, # 1973/11/29 21:33:09
);
$tab->append_line( "Second line",
time => 123456792, # 1973/11/29 21:33:12
);
$tab->append_line( "Third line",
time => 123498765, # 1973/11/30 09:12:45
);
flush_tickit;
is_display( [ [TEXT("- day is now 1973/11/29 -")],
[TEXT("[21:33] First line")],
[TEXT("[21:33] Second line")],
[TEXT("- day is now 1973/11/30 -")],
[TEXT("[09:12] Third line")],
BLANKLINES(18),
[TEXT("[",fg=>7,bg=>4),TEXT("Tabname",fg=>14,bg=>4),TEXT("]",fg=>7,bg=>4),TEXT("",bg=>4)],
BLANKLINE() ],
'Display after tab->append_line with datestamp' );
$console->remove_tab( $tab );
}
# Time + Datestamp, prepending
{
my $tab = $console->add_tab(
name => "Tabname",
timestamp_format => "[%H:%M] ",
datestamp_format => "- day is now %Y/%m/%d -",
localtime => sub { gmtime $_[0] },
);
$tab->prepend_line( "First line",
time => 123456789, # 1973/11/29 21:33:09
);
$tab->prepend_line( "Second line",
time => 123456787, # 1973/11/29 21:33:07
);
$tab->prepend_line( "Third line",
time => 123345678, # 1973/11/28 14:41:18
);
flush_tickit;
is_display( [ [TEXT("- day is now 1973/11/28 -")],
[TEXT("[14:41] Third line")],
[TEXT("- day is now 1973/11/29 -")],
[TEXT("[21:33] Second line")],
[TEXT("[21:33] First line")],
BLANKLINES(18),
[TEXT("[",fg=>7,bg=>4),TEXT("Tabname",fg=>14,bg=>4),TEXT("]",fg=>7,bg=>4),TEXT("",bg=>4)],
BLANKLINE() ],
'Display after tab->append_line with datestamp' );
$console->remove_tab( $tab );
}
done_testing;
|