X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=xt%2Fperf-msgview.t;h=599808390b6d9a8b70ddca4e492c04ff3bd7b143;hb=420fa1eac8cf0c73b6b0512c32206dc0b904dd45;hp=3ea92ec67f063879dc58871fe9de27c16a90c5a6;hpb=aa0e67e63e58e0ee4fc3918bde25b9c04d48954a;p=public-inbox.git
diff --git a/xt/perf-msgview.t b/xt/perf-msgview.t
index 3ea92ec6..59980839 100644
--- a/xt/perf-msgview.t
+++ b/xt/perf-msgview.t
@@ -1,4 +1,4 @@
-# Copyright (C) 2019-2020 all contributors
+# Copyright (C) 2019-2021 all contributors
# License: AGPL-3.0+
use strict;
use warnings;
@@ -29,25 +29,32 @@ select($vec, undef, undef, 60) or die "timed out waiting for --batch-check";
my $ctx = {
env => { HTTP_HOST => 'example.com', 'psgi.url_scheme' => 'https' },
- -inbox => $ibx,
+ ibx => $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 {
- my $obuf = '';
$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);
- PublicInbox::View::multipart_text_as_html($mime, $ctx);
- $obuf = '';
+ $git->cat_async($oid, $cb);
}
+ $git->cat_async_wait;
});
-diag 'multipart_text_as_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();