X-Git-Url: http://www.git.stargrave.org/?p=public-inbox.git;a=blobdiff_plain;f=t%2Fpsgi_mount.t;h=7c5487f3f99ca9e1bacaafb37863bdeb786d1553;hp=48d8e5c0847f0f83cf8de211d19ebd16cca5ee2a;hb=5b96edcb1e0d825244d5a12470e0f32526262611;hpb=1bf653ad139bf7bb3d853ab0b5eae3eaa1b13a95 diff --git a/t/psgi_mount.t b/t/psgi_mount.t index 48d8e5c0..7c5487f3 100644 --- a/t/psgi_mount.t +++ b/t/psgi_mount.t @@ -1,44 +1,36 @@ -# Copyright (C) 2016-2020 all contributors +#!perl -w +# Copyright (C) 2016-2021 all contributors # License: AGPL-3.0+ use strict; -use warnings; -use Test::More; +use v5.10.1; use PublicInbox::Eml; use PublicInbox::TestCommon; +use PublicInbox::Config; my ($tmpdir, $for_destroy) = tmpdir(); -my $maindir = "$tmpdir/main.git"; -my $addr = 'test-public@example.com'; +my $v1dir = "$tmpdir/v1.git"; my $cfgpfx = "publicinbox.test"; my @mods = qw(HTTP::Request::Common Plack::Test URI::Escape Plack::Builder Plack::App::URLMap); require_mods(@mods); use_ok $_ foreach @mods; use_ok 'PublicInbox::WWW'; -use PublicInbox::Import; -use PublicInbox::Git; -use PublicInbox::Config; -my $cfg = PublicInbox::Config->new(\<new($maindir); -my $im = PublicInbox::Import->new($git, 'test', $addr); -$im->init_bare; -{ - my $mime = PublicInbox::Eml->new(< $v1dir, sub { + my ($im, $ibx) = @_; + $im->add(PublicInbox::Eml->new(< To: You -Cc: $addr +Cc: $ibx->{-primary_address} Message-Id: Subject: hihi Date: Thu, 01 Jan 1970 00:00:00 +0000 zzzzzz EOF - $im->add($mime); - $im->done; -} - +}; +my $cfg = PublicInbox::Config->new(\<{-primary_address} +$cfgpfx.inboxdir=$v1dir +EOF my $www = PublicInbox::WWW->new($cfg); my $app = builder(sub { enable('Head'); @@ -56,14 +48,9 @@ test_psgi($app, sub { unlike($res->content, qr!\b\Qhttp://[^/]+/test/\E!, 'No URLs which are not mount-aware'); - $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/_/text/mirror/')); + like($res->content, qr!git clone --mirror\s+.*?http://[^/]+/a/test\b!s, + 'clone URL in /text/mirror is mount-aware'); $res = $cb->(GET('/a/test/blah%40example.com/raw')); is($res->code, 200, 'OK with URLMap mount'); @@ -83,7 +70,6 @@ test_psgi($app, sub { SKIP: { require_mods(qw(DBD::SQLite Search::Xapian IO::Uncompress::Gunzip), 3); - my $ibx = $cfg->lookup_name('test'); require_ok 'PublicInbox::SearchIdx'; PublicInbox::SearchIdx->new($ibx, 1)->index_sync; test_psgi($app, sub {