Benchmark-Harness
view release on metacpan or search on metacpan
Harness/Trace.pm view on Meta::CPAN
use strict;
use Benchmark::Harness;
package Benchmark::Harness::Trace;
use base qw(Benchmark::Harness);
use Benchmark::Harness::Constants;
use vars qw($VERSION); $VERSION = sprintf("%d.%02d", q$Revision: 1.2 $ =~ /(\d+)\.(\d+)/);
### ###########################################################################
sub Initialize {
my $self = Benchmark::Harness::Initialize(@_);
# Things we get for the ProcessInfo element:
#
# W32 Linux attr : meaning
# X X 'm' : virtual memory size (kilobytes)
# X 'r' : resident set size (kilobytes)
# X 'u' : user mode time (milliseconds)
# X 's' : kernel mode time (milliseconds)
# X 'x' : user + kernal time
# ? ? 't' : system time, since process started, from time()
# X 'p' : percent cpu used since process started
if ( $^O eq 'MSWin32' ) {
$self->{XmlTempFilename} = 'C:/TEMP/benchmark_harness';
eval 'use Win32::Process::Info';
$self->{procInfo} = Win32::Process::Info->new(undef,'NT');
*Benchmark::Harness::Handler::Trace::reportTraceInfo =
sub {
my $slf = shift;
my $proc = ($slf->[HNDLR_HARNESS]->{procInfo}->GetProcInfo({no_user_info=>1},$$))[0];
return Benchmark::Harness::Handler::reportTraceInfo($slf,
{
'm' => $proc->{WorkingSetSize}/1024,
's' => $proc->{KernelModeTime} || '0',
't' => (time() - $slf->[HNDLR_HARNESS]->{_startTime}),
'u' => $proc->{UserModeTime},
}
,@_
);
};
}
else { # Assume Linux, for now . . .
$self->{XmlTempFilename} = '/tmp/benchmark_harness';
*Benchmark::Harness::Handler::Trace::reportTraceInfo =
sub {
my $slf = shift;
my $ps = `ps -l -p $$`;
my ($pMem, $pTimeH, $pTimeM, $pTimeS) = ($ps =~ m{CMD(?:\s+\S+){9}\s+(\S+)(?:\s+\S+){2}\s+(\d+):(\d+):(\d+)}s);
my $pTime = ( $pTimeH*60 + $pTimeM*60 ) + $pTimeS;
return Benchmark::Harness::Handler::reportTraceInfo($slf,
{
'm' => $pMem
,'t' => (time() - $slf->[HNDLR_HARNESS]->{_startTime})
,'u' => $pTime
}
,@_
);
};
}
return $self;
}
package Benchmark::Harness::Handler::Trace;
use base qw(Benchmark::Harness::Handler);
use strict;
=pod
=head1 Benchmark::Harness::Trace
=head2 SYNOPSIS
A harness that records the time and sequence, and simple memory usage
of your program, at entries and exits of functions in the target program.
( run in 2.638 seconds using v1.01-cache-2.11-cpan-0bb4e1dffa6 )