File: ithreads_args.pm

package info (click to toggle)
libapache2-mod-perl2 2.0.9~1624218-2%2Bdeb8u2
  • links: PTS, VCS
  • area: main
  • in suites: jessie
  • size: 11,912 kB
  • ctags: 4,588
  • sloc: perl: 95,064; ansic: 14,527; makefile: 49; sh: 18
file content (33 lines) | stat: -rw-r--r-- 912 bytes parent folder | download | duplicates (2)
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
# please insert nothing before this line: -*- mode: cperl; cperl-indent-level: 4; cperl-continued-statement-offset: 4; indent-tabs-mode: nil -*-
package TestPerl::ithreads_args;

# reproducing a bug in perl ithreads: [perl #34342]
# https://rt.perl.org/rt3/Ticket/Display.html?id=34342
#
# here an unshifted $r (i.e. as it leaves @_ populated causes a scalar
# leak in the thread).

use Devel::Peek;
use Apache::Test;

sub handler {   # XXX: unshifted $_[0] leaks scalar
    #Dump $_[0];
    #my $r = shift; # shift removes the leak
    my $r = $_[0];
    #Dump $r; # here PADBUSY,PADMY prevent the ithread from cloning it

    plan $r, tests => 1, need
        need_threads,
            {"perl >= 5.8.1 is required (this is $])" => ($] >= 5.008001)};

    require threads;

    warn "\n*** The following leak is expected (perl bug #34342) ***\n";
    threads->new(sub {})->join;

    ok 1;

    return 0;
}

1;