X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=t%2Foptional_memleak.t;h=499c365b1be9df571ff65e29ff57b57b0551274d;hp=646332a43b6844354aae5afe88437c4bd7c1335c;hb=e91462552b2ba10034c82a4c981fe63dfeb57a6e;hpb=8a1b06bea91f32966b5f067d6502209e0338827f diff --git a/t/optional_memleak.t b/t/optional_memleak.t index 646332a..499c365 100644 --- a/t/optional_memleak.t +++ b/t/optional_memleak.t @@ -14,13 +14,10 @@ use Catalyst::Test 'TestApp'; eval "use Proc::ProcessTable"; plan skip_all => 'Proc::ProcessTable required for this test' if $@; -eval "use HTTP::Body 0.03"; -plan skip_all => 'HTTP::Body >= 0.03 required for this test' if $@; - use JSON::MaybeXS qw(decode_json); our $t = Proc::ProcessTable->new( cache_ttys => 1 ); -our ( $initial, $final ) = ( 0, 0 ); +our ( $initial, $final ) = ( 0, 0 ); my $test_data = do { open my $fh, '<:raw', "$FindBin::Bin/optional_stress.json" or die "$!"; local $/; @@ -41,7 +38,7 @@ if ( $user_test ) { else { map { $total_tests += scalar @{ $tests->{$_} } } keys %{$tests}; plan tests => $total_tests; - + foreach my $test_group ( keys %{$tests} ) { foreach my $test ( @{ $tests->{$test_group} } ) { run_test( $test ); @@ -51,40 +48,40 @@ else { sub run_test { my $uri = shift || die 'No URI given for test'; - + print "TESTING $uri\n"; - + # make a few requests to set initial memory size for ( 1 .. 3 ) { request( $uri ); } - + $initial = size_of($$); print "Initial Size: $initial\n"; - + for ( 1 .. 500 ) { request( $uri ); } - + $final = size_of($$); print "Final Size: $final\n"; - + if ( $final > $initial ) { print "Leaked: " . ($final - $initial) . "K\n"; } - + is( $final, $initial, "'$uri' memory is not leaking" ); } sub size_of { my $pid = shift; - + foreach my $p ( @{ $t->table } ) { if ( $p->pid == $pid ) { return $p->rss; } } - + die "Pid $pid not found?"; }