X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=xt%2Fperf-msgview.t;h=d99101a30de67d4ac7a28ba93c981a7a672823a2;hb=27f17d80e4e8e15b5e7d50045b1853ec7bdb4b3b;hp=22d8ce209fd01de79792fb0d89c86e478fd3117b;hpb=28caef46cadc34c53e33994597de28f8e05552c0;p=public-inbox.git
diff --git a/xt/perf-msgview.t b/xt/perf-msgview.t
index 22d8ce20..d99101a3 100644
--- a/xt/perf-msgview.t
+++ b/xt/perf-msgview.t
@@ -1,4 +1,4 @@
-# Copyright (C) 2019 all contributors
+# Copyright (C) 2019-2020 all contributors
# License: AGPL-3.0+
use strict;
use warnings;
@@ -6,7 +6,7 @@ use Test::More;
use Benchmark qw(:all);
use PublicInbox::Inbox;
use PublicInbox::View;
-require './t/common.perl';
+use PublicInbox::TestCommon;
my $inboxdir = $ENV{GIANT_INBOX_DIR} // $ENV{GIANT_PI_DIR};
plan skip_all => "GIANT_INBOX_DIR not defined for $0" unless $inboxdir;
@@ -18,7 +18,7 @@ if (require_git(2.19, 1)) {
warn
"git <2.19, cat-file lacks --unordered, locality suffers\n";
}
-
+require_mods qw(Plack::Util);
use_ok 'Plack::Util';
my $ibx = PublicInbox::Inbox->new({ inboxdir => $inboxdir, name => 'name' });
my $git = $ibx->git;
@@ -32,21 +32,29 @@ my $ctx = {
-inbox => $ibx,
www => Plack::Util::inline_object(style => sub {''}),
};
-my ($str, $mime, $res, $cmt, $type);
+my ($mime, $res, $oid, $type);
my $n = 0;
+my $obuf = '';
+my $m = 0;
+
+my $cb = sub {
+ $mime = PublicInbox::Eml->new(shift);
+ PublicInbox::View::multipart_text_as_html($mime, $ctx);
+ ++$m;
+ $obuf = '';
+};
+
my $t = timeit(1, sub {
+ $ctx->{obuf} = \$obuf;
+ $ctx->{mhref} = '../';
while (<$fh>) {
- ($cmt, $type) = split / /;
+ ($oid, $type) = split / /;
next if $type ne 'blob';
++$n;
- $str = $git->cat_file($cmt);
- $mime = PublicInbox::MIME->new($str);
- $res = PublicInbox::View::msg_html($ctx, $mime);
- $res = $res->[2];
- while (defined($res->getline)) {}
- $res->close;
+ $git->cat_async($oid, $cb);
}
+ $git->cat_async_wait;
});
-diag 'msg_html took '.timestr($t)." for $n messages";
-ok 1;
+diag 'multipart_text_as_html took '.timestr($t)." for $n <=> $m messages";
+is($m, $n, 'rendered all messages');
done_testing();