X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Fextindex-psgi.t;h=98dc2e48f313b6e0bd82274d0d0c16ed67375a0d;hb=2f8d15b1170b137a0512a4f3163b236a5dcbf0b8;hp=d47616417a525b5b48a468141d8e03a25863c0d5;hpb=d7780e12856d83b9f5c58586691e2fbe711321ed;p=public-inbox.git diff --git a/t/extindex-psgi.t b/t/extindex-psgi.t index d4761641..98dc2e48 100644 --- a/t/extindex-psgi.t +++ b/t/extindex-psgi.t @@ -11,6 +11,7 @@ require_git(2.6); require_mods(qw(json DBD::SQLite Search::Xapian HTTP::Request::Common Plack::Test URI::Escape Plack::Builder)); use_ok($_) for (qw(HTTP::Request::Common Plack::Test)); +use IO::Uncompress::Gunzip qw(gunzip); require PublicInbox::WWW; my ($ro_home, $cfg_path) = setup_public_inboxes; my ($tmpdir, $for_destroy) = tmpdir; @@ -18,16 +19,19 @@ my $home = "$tmpdir/home"; mkdir $home or BAIL_OUT $!; mkdir "$home/.public-inbox" or BAIL_OUT $!; my $pi_config = "$home/.public-inbox/config"; -cp("$ro_home/.public-inbox/config", $pi_config) or BAIL_OUT; +cp($cfg_path, $pi_config) or BAIL_OUT; my $env = { HOME => $home }; run_script([qw(-extindex --all), "$tmpdir/eidx"], $env) or BAIL_OUT; { - open my $cfgfh, '>', $pi_config or BAIL_OUT; + open my $cfgfh, '>>', $pi_config or BAIL_OUT; $cfgfh->autoflush(1); print $cfgfh <new(PublicInbox::Config->new($pi_config)); @@ -55,6 +59,30 @@ my $client = sub { $res = $cb->(GET('/all/all.mbox.gz')); is($res->code, 200, 'all.mbox.gz'); + + $res = $cb->(GET('/')); + like($res->content, qr!\Qhttp://bogus.example.com/all\E!, + '/all listed'); + $res = $cb->(GET('/?q=')); + is($res->code, 200, 'no query means all inboxes'); + $res = $cb->(GET('/?q=nonexistent')); + is($res->code, 404, 'no inboxes matched'); + unlike($res->content, qr!no inboxes, yet!, + 'we have inboxes, just no matches'); + + my $m = {}; + for my $pfx (qw(/t1 /t2), '') { + $res = $cb->(GET($pfx.'/manifest.js.gz')); + gunzip(\($res->content) => \(my $js)); + $m->{$pfx} = json_utf8->decode($js); + } + is_deeply([sort keys %{$m->{''}}], + [ sort(keys %{$m->{'/t1'}}, keys %{$m->{'/t2'}}) ], + 't1 + t2 = all'); + is_deeply([ sort keys %{$m->{'/t2'}} ], [ '/t2/git/0.git' ], + 't2 manifest'); + is_deeply([ sort keys %{$m->{'/t1'}} ], [ '/t1' ], + 't2 manifest'); }; test_psgi(sub { $www->call(@_) }, $client); %$env = (%$env, TMPDIR => $tmpdir, PI_CONFIG => $pi_config);