Data-Roundtrip

 view release on metacpan or  search on metacpan

xt/benchmarks/01-default-unicode-escaping.t  view on Meta::CPAN

#!perl -T

use 5.008;

use strict;
use warnings;

our $VERSION='0.29';

use Data::Roundtrip qw/:all/;
use Data::Random::Structure::UTF8;

use Test::More;

use Benchmark qw/timethese cmpthese :hireswallclock/;

my $num_repeats = 50000;

print "$0 : benchmarks...\n";

srand 42;
my $randomiser = Data::Random::Structure::UTF8->new(
	'max_depth' => 5,
	'max_elements' => 20,
)  or die 'Data::Random::Structure::UTF8->new()'.": failed";
my $pv = $randomiser->generate() or die "generate(): failed";

# shamelessly ripped off App::Benchmark
cmpthese(
  timethese($num_repeats, {
	' /e/d' => \&perl2dump_escape_default,
	' /ne/d' => \&perl2dump_no_escape_default,
	'f/e/d' => \&perl2dump_filtered_escape_default,
	'f/ne/d' => \&perl2dump_filtered_no_escape_default,
	'h/e/d' => \&perl2dump_homebrew_escape_default,
	'h/ne/d' => \&perl2dump_homebrew_no_escape_default,
  }),
);
print "KEY:\n"
 ." /e/d  : perl2dump, escape, 'no-unicode-escape-permanently' not set\n"
 ." /ne/d : perl2dump, no escape, 'no-unicode-escape-permanently' not set\n"
 ."f/e/d  : perl2dump_filtered, escape, 'no-unicode-escape-permanently' not set\n"
 ."f/ne/d : perl2dump_filtered, no escape, 'no-unicode-escape-permanently' not set\n"
 ."h/e/d  : perl2dump_homebrew, escape, 'no-unicode-escape-permanently' not set\n"
 ."h/ne/d : perl2dump_homebrew, no escape, 'no-unicode-escape-permanently' not set\n"
;

plan tests => 1;
pass('benchmark : '.__FILE__);

sub perl2dump_escape_default {
	my $x = perl2dump($pv, {'dont-bloody-escape-unicode'=>0})
}
sub perl2dump_no_escape_default {
	my $x = perl2dump($pv, {'dont-bloody-escape-unicode'=>1})
}
sub perl2dump_homebrew_escape_default {
	my $x = perl2dump_homebrew($pv, {'dont-bloody-escape-unicode'=>0})
}
sub perl2dump_homebrew_no_escape_default {
	my $x = perl2dump_homebrew($pv, {'dont-bloody-escape-unicode'=>1})
}
sub perl2dump_filtered_escape_default {
	my $x = perl2dump_filtered($pv, {'dont-bloody-escape-unicode'=>0})
}
sub perl2dump_filtered_no_escape_default {
	my $x = perl2dump_filtered($pv, {'dont-bloody-escape-unicode'=>1})
}

1;
__END__



( run in 0.623 second using v1.01-cache-2.11-cpan-39bf76dae61 )