App-JsonLogUtils

 view release on metacpan or  search on metacpan

t/cols.t  view on Meta::CPAN

use strict;
use warnings;
use Test2::V0;
use JSON::XS;
use App::JsonLogUtils qw(lines json_cols);

my @log = (
  {a => 1, b => 2, c => 3},
  {a => 1, b => 2, c => 3},
  {a => 1, b => 2, c => 3},
);

my $log = join "\n", map{ encode_json $_ } @log;

open my $fh, '<', \$log or die $!;

my $cols = json_cols 'a c', '|', lines $fh;

my @expected = (
  'a|c',
  '1|3',
  '1|3',
  '1|3',
);

foreach (@expected) {
  is <$cols>, $_, 'expected results';
}

is <$cols>, U, 'exhausted';

done_testing;



( run in 0.792 second using v1.01-cache-2.11-cpan-39bf76dae61 )