]> Sergey Matveev's repositories - public-inbox.git/blob - t/qspawn.t
qspawn: decode $? for user-friendliness
[public-inbox.git] / t / qspawn.t
1 # Copyright (C) 2016-2019 all contributors <meta@public-inbox.org>
2 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
3 use Test::More;
4 use_ok 'PublicInbox::Qspawn';
5
6 {
7         my $cmd = [qw(sh -c), 'echo >&2 err; echo out'];
8         my $qsp = PublicInbox::Qspawn->new($cmd, {}, { 2 => 1 });
9         my $res;
10         $qsp->psgi_qx({}, undef, sub { $res = ${$_[0]} });
11         is($res, "err\nout\n", 'captured stderr and stdout');
12 }
13
14 my $limiter = PublicInbox::Qspawn::Limiter->new(1);
15 {
16         my $x = PublicInbox::Qspawn->new([qw(true)]);
17         my $run = 0;
18         $x->start($limiter, sub {
19                 my ($rpipe) = @_;
20                 is(0, sysread($rpipe, my $buf, 1), 'read zero bytes');
21                 ok(!$x->finish, 'no error on finish');
22                 $run = 1;
23         });
24         is($run, 1, 'callback ran alright');
25 }
26
27 {
28         my $x = PublicInbox::Qspawn->new([qw(false)]);
29         my $run = 0;
30         $x->start($limiter, sub {
31                 my ($rpipe) = @_;
32                 is(0, sysread($rpipe, my $buf, 1), 'read zero bytes from false');
33                 my $err = $x->finish;
34                 ok($err, 'error on finish');
35                 $run = 1;
36         });
37         is($run, 1, 'callback ran alright');
38 }
39
40 foreach my $cmd ([qw(sleep 1)], [qw(sh -c), 'sleep 1; false']) {
41         my $s = PublicInbox::Qspawn->new($cmd);
42         my @run;
43         $s->start($limiter, sub {
44                 my ($rpipe) = @_;
45                 push @run, 'sleep';
46                 is(0, sysread($rpipe, my $buf, 1), 'read zero bytes');
47         });
48         my $n = 0;
49         my @t = map {
50                 my $i = $n++;
51                 my $x = PublicInbox::Qspawn->new([qw(true)]);
52                 $x->start($limiter, sub {
53                         my ($rpipe) = @_;
54                         push @run, $i;
55                 });
56                 [$x, $i]
57         } (0..2);
58
59         if ($cmd->[-1] =~ /false\z/) {
60                 ok($s->finish, 'got error on false after sleep');
61         } else {
62                 ok(!$s->finish, 'no error on sleep');
63         }
64         ok(!$_->[0]->finish, "true $_->[1] succeeded") foreach @t;
65         is_deeply([qw(sleep 0 1 2)], \@run, 'ran in order');
66 }
67
68 done_testing();
69
70 1;