]> Sergey Matveev's repositories - public-inbox.git/commitdiff
t/ds-leak: fix race
authorEric Wong <e@80x24.org>
Sat, 29 Jun 2019 06:34:40 +0000 (06:34 +0000)
committerEric Wong <e@80x24.org>
Sat, 29 Jun 2019 06:39:45 +0000 (06:39 +0000)
We need to ensure we run lsof on the sleep(1) process, and not
the fork of ourselves before execve(2).  This race applies when
we're using the default pure-Perl spawn() implementation.

t/ds-leak.t

index dd8446dcd1f77e0f9a2d167ab0c057c917a443bb..34ffc125ed49a8dfcc975550b4cc4acc299d3ed4 100644 (file)
@@ -15,9 +15,21 @@ if ('close-on-exec for epoll and kqueue') {
 
        PublicInbox::DS->SetLoopTimeout(0);
        PublicInbox::DS->SetPostLoopCallback(sub { 0 });
+
+       # make sure execve closes if we're using fork()
+       my ($r, $w);
+       pipe($r, $w) or die "pipe: $!";
+
        PublicInbox::DS->AddTimer(0, sub { $pid = spawn([qw(sleep 10)]) });
        PublicInbox::DS->EventLoop;
        ok($pid, 'subprocess spawned');
+
+       # wait for execve, we need to ensure lsof sees sleep(1)
+       # and not the fork of this process:
+       close $w or die "close: $!";
+       my $l = <$r>;
+       is($l, undef, 'cloexec works and sleep(1) is running');
+
        my @of = grep(/$evfd_re/, `lsof -p $pid 2>/dev/null`);
        my $err = $?;
        SKIP: {