]> Sergey Matveev's repositories - public-inbox.git/commitdiff
search: reopen DB if each_smsg_by_mid fails
authorEric Wong (Contractor, The Linux Foundation) <e@80x24.org>
Fri, 23 Mar 2018 02:03:46 +0000 (02:03 +0000)
committerEric Wong (Contractor, The Linux Foundation) <e@80x24.org>
Fri, 23 Mar 2018 02:03:46 +0000 (02:03 +0000)
This gives more-up-to-date data in case and allows us
to avoid reopening in more places ourselves.

lib/PublicInbox/Search.pm
t/psgi_v2.t

index 24600ee7574e62feff60d40f46fd792e69d32747..a4e2498eb596d1cd9346b6620ffa464aa5a1ce6d 100644 (file)
@@ -417,6 +417,11 @@ sub each_smsg_by_mid {
        my $term = 'Q' . $mid;
        my $head = $db->postlist_begin($term);
        my $tail = $db->postlist_end($term);
+       if ($head == $tail) {
+               $db->reopen;
+               $head = $db->postlist_begin($term);
+               $tail = $db->postlist_end($term);
+       }
        return ($head, $tail, $db) if wantarray;
        for (; $head->nequal($tail); $head->inc) {
                my $doc_id = $head->get_docid;
index 5d089dbed5f01e3f2978aad73bcd8c21e874432c..6a2ea5bad471e25e04da410c94be9eb363833b6e 100644 (file)
@@ -50,12 +50,11 @@ $new_mid = PublicInbox::MID::mid_clean($mids[0]);
 $im->done;
 
 my $cfgpfx = "publicinbox.v2test";
-my %cfg = (
+my $cfg = {
        "$cfgpfx.address" => $ibx->{-primary_address},
        "$cfgpfx.mainrepo" => $mainrepo,
-);
-
-my $config = PublicInbox::Config->new({ %cfg });
+};
+my $config = PublicInbox::Config->new($cfg);
 my $www = PublicInbox::WWW->new($config);
 my ($res, $raw, @from_);
 test_psgi(sub { $www->call(@_) }, sub {
@@ -85,9 +84,6 @@ is($warn[0], $warn[1], 'both warnings are the same');
 my $third = PublicInbox::MID::mid_clean($mids[0]);
 $im->done;
 
-# need to reload...
-$config = PublicInbox::Config->new({ %cfg });
-$www = PublicInbox::WWW->new($config);
 test_psgi(sub { $www->call(@_) }, sub {
        my ($cb) = @_;
        $res = $cb->(GET("/v2test/$third/raw"));