X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Flei_xsearch.t;h=d9ddb2977c17114ae8f7ce78fabb2e5fd38375e9;hb=4eee5af6011cc8cdefb66c9729952c7eff5c0b0b;hp=f865ff436ae292a2437b7694589d5d3d9298cd1d;hpb=a1aa7a3bf55ca5aa6e12294bc1f864dba8e63269;p=public-inbox.git diff --git a/t/lei_xsearch.t b/t/lei_xsearch.t index f865ff43..d9ddb297 100644 --- a/t/lei_xsearch.t +++ b/t/lei_xsearch.t @@ -3,30 +3,24 @@ # License: AGPL-3.0+ use strict; use v5.10.1; -use Test::More; -use List::Util qw(shuffle max); +use List::Util qw(shuffle); use PublicInbox::TestCommon; use PublicInbox::Eml; -use PublicInbox::InboxWritable; require_mods(qw(DBD::SQLite Search::Xapian)); require PublicInbox::ExtSearchIdx; require_git 2.6; require_ok 'PublicInbox::LeiXSearch'; +require_ok 'PublicInbox::LeiALE'; +require_ok 'PublicInbox::LEI'; my ($home, $for_destroy) = tmpdir(); my @ibx; for my $V (1..2) { for my $i (3..6) { - my $ibx = PublicInbox::InboxWritable->new({ - inboxdir => "$home/v$V-$i", - name => "test-v$V-$i", - version => $V, - indexlevel => 'medium', - -primary_address => "v$V-$i\@example.com", - }, { nproc => int(rand(8)) + 1 }); - push @ibx, $ibx; - my $im = $ibx->importer(0); - for my $j (0..9) { - my $eml = PublicInbox::Eml->new(< 'full', + version => $V, sub { + my ($im, $ibx) = @_; + for my $j (0..9) { + my $eml = PublicInbox::Eml->new(<{-primary_address} Date: Fri, 02 Oct 1993 0$V:0$i:0$j +0000 @@ -34,14 +28,14 @@ Subject: v${V}i${i}j$j Message-ID: ${V}er ${i}on j$j -EOF - $im->add($eml); - } - $im->done; +EOM + $im->add($eml) or BAIL_OUT '->add'; + } + }); # create_inbox } } -my $first = shift @ibx; is($first->{name}, 'test-v1-3', 'first plucked'); -my $last = pop @ibx; is($last->{name}, 'test-v2-6', 'last plucked'); +my $first = shift @ibx; is($first->{name}, 'v1-3', 'first plucked'); +my $last = pop @ibx; is($last->{name}, 'v2-6', 'last plucked'); my $eidx = PublicInbox::ExtSearchIdx->new("$home/eidx"); $eidx->attach_inbox($first); $eidx->attach_inbox($last); @@ -69,13 +63,47 @@ is(scalar(@msgs), $nr, 'smsgs retrieved for all'); $mset = $lxs->recent(undef, { limit => 1 }); is($mset->size, 1, 'one result'); -my $max = max(map { $_->{docid} } @msgs); -is($lxs->smsg_for(($mset->items)[0])->{docid}, $max, - 'got highest docid'); my @ibxish = $lxs->locals; is(scalar(@ibxish), scalar(@ibx) + 1, 'got locals back'); is($lxs->search, $lxs, '->search works'); is($lxs->over, undef, '->over fails'); +{ + $lxs = PublicInbox::LeiXSearch->new; + my $v2ibx = create_inbox 'v2full', version => 2, sub { + $_[0]->add(eml_load('t/plack-qp.eml')); + }; + my $v1ibx = create_inbox 'v1medium', indexlevel => 'medium', + tmpdir => "$home/v1tmp", sub { + $_[0]->add(eml_load('t/utf8.eml')); + }; + $lxs->prepare_external($v1ibx); + $lxs->prepare_external($v2ibx); + for my $loc ($lxs->locals) { + $lxs->attach_external($loc); + } + my $mset = $lxs->mset('m:testmessage@example.com'); + is($mset->size, 1, 'got m: match on medium+full XSearch mix'); + my $mitem = ($mset->items)[0]; + my $smsg = $lxs->smsg_for($mitem) or BAIL_OUT 'smsg_for broken'; + + my $ale = PublicInbox::LeiALE::_new("$home/ale"); + my $lei = bless {}, 'PublicInbox::LEI'; + $ale->refresh_externals($lxs, $lei); + my $exp = [ $smsg->{blob}, 'blob', -s 't/utf8.eml' ]; + is_deeply([ $ale->git->check($smsg->{blob}) ], $exp, 'ale->git->check'); + + $lxs = PublicInbox::LeiXSearch->new; + $lxs->prepare_external($v2ibx); + $ale->refresh_externals($lxs, $lei); + is_deeply([ $ale->git->check($smsg->{blob}) ], $exp, + 'ale->git->check remembered inactive external'); + + rename("$home/v1tmp", "$home/v1moved") or BAIL_OUT "rename: $!"; + $ale->refresh_externals($lxs, $lei); + is($ale->git->check($smsg->{blob}), undef, + 'missing after directory gone'); +} + done_testing;