File: 20ngrep.t

package info (click to toggle)
liblist-keywords-perl 0.11-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 200 kB
  • sloc: perl: 467; makefile: 3
file content (51 lines) | stat: -rw-r--r-- 1,409 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
#!/usr/bin/perl

use v5.14;
use warnings;

use Test2::V0 0.000148;  # is_refcount

use List::Keywords 'ngrep';

# 2-at-a-time
{
   is( [ngrep my ($k, $v) { } ()], [], 'ngrep empty in list context');
   is( scalar(ngrep my ($k, $v) { } ()), 0, 'ngrep empty in scalar context');

   my @values;
   is( [ngrep my ($k, $v) { @values = ($k, $v); length $k == 3 } ( one => 1, two => 2, three => 3 )],
       [one => 1, two => 2],
       'ngrep in list context' );
   is( \@values, [ three => 3 ], 'ngrep code block saw correct values' );

   is( scalar(ngrep my ($k, $v) { length $k == 3 } ( one => 1, two => 2, three => 3 )), 4,
       'ngrep in scalar context' );

   is( [ngrep my ($k, $v) { @values = ($k, $v) } ( one => 1, missing => )],
       [one => 1, missing => ],
       'ngrep with short list does not invent undef' );
   is( \@values, [ missing => undef ],
       'ngrep code block still saw missing value as undef' );
}

# stack discipline
{
   is( [1, (ngrep my ($x) { 1 } 2), 3], [1, 2, 3],
      'ngrep behaves correctly as list operator' );
}

# refcounts
{
   my $arr = [];
   is_oneref( $arr, '$arr has one reference before test' );

   my $result;

   ( $result ) = ngrep my ($x) { defined $x } undef, $arr, undef;
   is_refcount( $arr, 2, '$arr has two references after ngrep my ($x) BLOCK' );

   undef $result;
   is_oneref( $arr, '$arr has one reference at end of test' );
}

done_testing;