X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Fpsgi_bad_mids.t;h=70393573e0f659ea54b330bd927cb4d01152fab4;hb=256b3566e4d57a64bb349a7b896da10381a2a363;hp=5008f5be6b65aefec9b08595612e46126f4a9ad0;hpb=4cf7804c2b263e4a92447315f534f76416d4ffad;p=public-inbox.git
diff --git a/t/psgi_bad_mids.t b/t/psgi_bad_mids.t
index 5008f5be..70393573 100644
--- a/t/psgi_bad_mids.t
+++ b/t/psgi_bad_mids.t
@@ -1,27 +1,26 @@
-# Copyright (C) 2018 all contributors
+# Copyright (C) 2018-2020 all contributors
# License: AGPL-3.0+
use strict;
use warnings;
use Test::More;
-use File::Temp qw/tempdir/;
-use PublicInbox::MIME;
+use PublicInbox::Eml;
use PublicInbox::Config;
-use PublicInbox::WWW;
-my @mods = qw(DBD::SQLite Search::Xapian HTTP::Request::Common Plack::Test
- URI::Escape Plack::Builder);
-foreach my $mod (@mods) {
- eval "require $mod";
- plan skip_all => "$mod missing for psgi_bad_mids.t" if $@;
-}
+use PublicInbox::TestCommon;
+my @mods = qw(DBD::SQLite HTTP::Request::Common Plack::Test
+ URI::Escape Plack::Builder PublicInbox::WWW);
+require_git 2.6;
+require_mods(@mods);
use_ok($_) for @mods;
+use_ok 'PublicInbox::WWW';
use_ok 'PublicInbox::V2Writable';
-my $mainrepo = tempdir('pi-bad-mids-XXXXXX', TMPDIR => 1, CLEANUP => 1);
+my ($inboxdir, $for_destroy) = tmpdir();
my $cfgpfx = "publicinbox.bad-mids";
my $ibx = {
- mainrepo => $mainrepo,
+ inboxdir => $inboxdir,
name => 'bad-mids',
version => 2,
-primary_address => 'test@example.com',
+ indexlevel => 'basic',
};
$ibx = PublicInbox::Inbox->new($ibx);
my $im = PublicInbox::V2Writable->new($ibx, 1);
@@ -30,6 +29,7 @@ $im->{parallel} = 0;
my $msgs = <<'';
F1V5OR6NMF.3M649JTLO9IXD@tux.localdomain/hehe1"'/foo
+F1V5NB0PTU.3U0DCVGAJ750Z@tux&.ampersand
F1V5MIHGCU.2ABINKW6WBE8N@tux.localdomain/raw
F1V5LF9D9C.2QT5PGXZQ050E@tux.localdomain/t.atom
F1V58X3CMU.2DCCVAKQZGADV@tux.localdomain/../../../../foo
@@ -46,17 +46,17 @@ To: b\@example.com
Date: Fri, 02 Oct 1993 00:00:0$i +0000
- my $mime = PublicInbox::MIME->new(\$data);
+ my $mime = PublicInbox::Eml->new(\$data);
ok($im->add($mime), "added $mid");
$i++
}
$im->done;
-my $cfg = {
- "$cfgpfx.address" => $ibx->{-primary_address},
- "$cfgpfx.mainrepo" => $mainrepo,
-};
-my $config = PublicInbox::Config->new($cfg);
+my $cfg = <{-primary_address}
+$cfgpfx.inboxdir=$inboxdir
+EOF
+my $config = PublicInbox::Config->new(\$cfg);
my $www = PublicInbox::WWW->new($config);
test_psgi(sub { $www->call(@_) }, sub {
my ($cb) = @_;
@@ -72,9 +72,13 @@ test_psgi(sub { $www->call(@_) }, sub {
'got escaped links to all messages');
@xmids = reverse @xmids;
+ my %uxs = ( gt => '>', lt => '<' );
foreach my $i (0..$#xmids) {
- $res = $cb->(GET("/bad-mids/$xmids[$i]/raw"));
- is($res->code, 200, 'got 200 OK raw message');
+ my $uri = $xmids[$i];
+ $uri =~ s/([0-9]+);/sprintf("%c", $1)/sge;
+ $uri =~ s/&(lt|gt);/$uxs{$1}/sge;
+ $res = $cb->(GET("/bad-mids/$uri/raw"));
+ is($res->code, 200, 'got 200 OK raw message '.$uri);
like($res->content, qr/Message-ID: <\Q$mids[$i]\E>/s,
'retrieved correct message');
}