1 # Copyright (C) 2017-2018 all contributors <meta@public-inbox.org>
2 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
5 use bytes (); # only for bytes::length
7 use File::Temp qw/tempdir/;
8 use PublicInbox::MID qw(mids);
10 eval { require Search::Xapian };
11 plan skip_all => "Search::Xapian missing for search" if $@;
12 require PublicInbox::SearchIdx;
13 my $tmpdir = tempdir('pi-search-thr-index.XXXXXX', TMPDIR => 1, CLEANUP => 1);
14 my $git_dir = "$tmpdir/a.git";
16 is(0, system(qw(git init -q --bare), $git_dir), "git init (main)");
17 my $rw = PublicInbox::SearchIdx->new($git_dir, 1);
18 ok($rw, "search indexer created");
36 # nb. using internal API, fragile!
37 my $xdb = $rw->begin_txn_lazy;
40 foreach (reverse split(/\n\n/, $data)) {
42 my $mime = Email::MIME->new(\$_);
43 $mime->header_set('From' => 'bw@g');
44 $mime->header_set('To' => 'git@vger.kernel.org');
45 my $bytes = bytes::length($mime->as_string);
46 my $mid = mids($mime->header_obj)->[0];
47 my $doc_id = $rw->add_message($mime, $bytes, ++$num, 'ignored', $mid);
49 ok($doc_id, 'message added: '. $mid);
54 my $dbh = $rw->{over}->connect;
55 foreach my $mid (@mids) {
56 my $msgs = $rw->{over}->get_thread($mid);
57 is(3, scalar(@$msgs), "got all messages from $mid");
58 foreach my $m (@$msgs) {
59 my $tid = $dbh->selectrow_array(<<'', undef, $m->{num});
60 SELECT tid FROM over WHERE num = ? LIMIT 1
66 is(scalar keys %tids, 1, 'all messages have the same tid');
70 $xdb = $rw->begin_txn_lazy;
72 my $mime = Email::MIME->new(<<'');
76 To: git@vger.kernel.org
78 my $dbh = $rw->{over}->connect;
80 my $reidx = $rw->{over}->next_by_mid('1-bw@g', \$id, \$prev);
82 my $num = $reidx->{num};
83 my $tid0 = $dbh->selectrow_array(<<'', undef, $num);
84 SELECT tid FROM over WHERE num = ? LIMIT 1
86 my $bytes = bytes::length($mime->as_string);
87 my $mid = mids($mime->header_obj)->[0];
88 my $doc_id = $rw->add_message($mime, $bytes, $num, 'ignored', $mid);
89 ok($doc_id, 'message reindexed'. $mid);
90 is($doc_id, $num, "article number unchanged: $num");
92 my $tid1 = $dbh->selectrow_array(<<'', undef, $num);
93 SELECT tid FROM over WHERE num = ? LIMIT 1
95 is($tid1, $tid0, 'tid unchanged on reindex');