]> Sergey Matveev's repositories - public-inbox.git/blobdiff - t/psgi_mount.t
config: support "inboxdir" in addition to "mainrepo"
[public-inbox.git] / t / psgi_mount.t
index dae45bafe81af1f1a40ab34bced2338cd41e1a4f..aa7c863f5274421e528c4a4e79d28a48a27b41db 100644 (file)
@@ -1,4 +1,4 @@
-# Copyright (C) 2016 all contributors <meta@public-inbox.org>
+# Copyright (C) 2016-2019 all contributors <meta@public-inbox.org>
 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
 use strict;
 use warnings;
@@ -21,10 +21,10 @@ use PublicInbox::Config;
 use PublicInbox::WWW;
 use Plack::Builder;
 use Plack::App::URLMap;
-my $config = PublicInbox::Config->new({
-       "$cfgpfx.address" => $addr,
-       "$cfgpfx.mainrepo" => $maindir,
-});
+my $config = PublicInbox::Config->new(\<<EOF);
+$cfgpfx.address=$addr
+$cfgpfx.inboxdir=$maindir
+EOF
 is(0, system(qw(git init -q --bare), $maindir), "git init (main)");
 my $git = PublicInbox::Git->new($maindir);
 my $im = PublicInbox::Import->new($git, 'test', $addr);
@@ -60,19 +60,53 @@ test_psgi($app, sub {
        unlike($res->content, qr!\b\Qhttp://[^/]+/test/\E!,
                'No URLs which are not mount-aware');
 
-       # redirects
+       $res = $cb->(GET('/a/test/new.html'));
+       like($res->content, qr!git clone --mirror http://[^/]+/a/test\b!,
+               'clone URL in new.html is mount-aware');
+
        $res = $cb->(GET('/a/test/blah%40example.com/'));
        is($res->code, 200, 'OK with URLMap mount');
+       like($res->content, qr!git clone --mirror http://[^/]+/a/test\b!,
+               'clone URL in /$INBOX/$MESSAGE_ID/ is mount-aware');
+
        $res = $cb->(GET('/a/test/blah%40example.com/raw'));
        is($res->code, 200, 'OK with URLMap mount');
+       like($res->content, qr!^List-Archive: <http://[^/]+/a/test/>!m,
+               'List-Archive set in /raw mboxrd');
+       like($res->content,
+               qr!^Archived-At: <http://[^/]+/a/test/blah\@example\.com/>!m,
+               'Archived-At set in /raw mboxrd');
+
+       # redirects
        $res = $cb->(GET('/a/test/m/blah%40example.com.html'));
        is($res->header('Location'),
-               'http://localhost/a/test/blah%40example.com/',
+               'http://localhost/a/test/blah@example.com/',
                'redirect functions properly under mount');
 
        $res = $cb->(GET('/test/blah%40example.com/'));
        is($res->code, 404, 'intentional 404 with URLMap mount');
-
 });
 
+SKIP: {
+       my @mods = qw(DBI DBD::SQLite Search::Xapian IO::Uncompress::Gunzip);
+       foreach my $mod (@mods) {
+               eval "require $mod" or skip "$mod not available: $@", 2;
+       }
+       my $ibx = $config->lookup_name('test');
+       PublicInbox::SearchIdx->new($ibx, 1)->index_sync;
+       test_psgi($app, sub {
+               my ($cb) = @_;
+               my $res = $cb->(GET('/a/test/blah@example.com/t.mbox.gz'));
+               my $gz = $res->content;
+               my $raw;
+               IO::Uncompress::Gunzip::gunzip(\$gz => \$raw);
+               like($raw, qr!^List-Archive: <http://[^/]+/a/test/>!m,
+                       'List-Archive set in /t.mbox.gz mboxrd');
+               like($raw,
+                       qr!^Archived-At:\x20
+                               <http://[^/]+/a/test/blah\@example\.com/>!mx,
+                       'Archived-At set in /t.mbox.gz mboxrd');
+       });
+}
+
 done_testing();