From 44917fdd24a8bec1125caa21949476f97d8658d4 Mon Sep 17 00:00:00 2001 From: Eric Wong Date: Thu, 2 Sep 2021 10:17:56 +0000 Subject: lei_mail_sync: do not use transactions For lei-index to work in parallel with MUA access and upcoming inotify-based updates, mail_sync.sqlite3 needs to always be up-to-date to read-only worker processes (ahead of everything else). So rely on the default auto-commit behavior and hope SQLite WAL can reduce some of the overheads involved with writes. --- t/lei_mail_sync.t | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) (limited to 't') diff --git a/t/lei_mail_sync.t b/t/lei_mail_sync.t index 5daa49cd..4439b818 100644 --- a/t/lei_mail_sync.t +++ b/t/lei_mail_sync.t @@ -9,17 +9,15 @@ require_ok 'PublicInbox::LeiMailSync'; my ($dir, $for_destroy) = tmpdir(); my $lms = PublicInbox::LeiMailSync->new("$dir/t.sqlite3"); -$lms->lms_begin; -$lms->lms_commit; +$lms->lms_write_prepare; my $ro = PublicInbox::LeiMailSync->new("$dir/t.sqlite3"); is_deeply([$ro->folders], [], 'no folders, yet'); my $imap = 'imaps://bob@[::1]/INBOX;UIDVALIDITY=9'; -$lms->lms_begin; +$lms->lms_write_prepare; my $deadbeef = "\xde\xad\xbe\xef"; is($lms->set_src($deadbeef, $imap, 1), 1, 'set IMAP once'); ok($lms->set_src($deadbeef, $imap, 1) == 0, 'set IMAP idempotently'); -$lms->lms_commit; is_deeply([$ro->folders], [$imap], 'IMAP folder added'); is_deeply([$ro->folders($imap)], [$imap], 'IMAP folder with full GLOB'); is_deeply([$ro->folders('imaps://bob@[::1]/INBOX')], [$imap], @@ -30,24 +28,21 @@ is_deeply($ro->locations_for($deadbeef), my $maildir = 'maildir:/home/user/md'; my $fname = 'foo:2,S'; -$lms->lms_begin; +$lms->lms_write_prepare; ok($lms->set_src($deadbeef, $maildir, \$fname), 'set Maildir once'); ok($lms->set_src($deadbeef, $maildir, \$fname) == 0, 'set Maildir again'); -$lms->lms_commit; is_deeply($ro->locations_for($deadbeef), { $imap => [ 1 ], $maildir => [ $fname ] }, 'locations_for w/ maildir + imap'); if ('mess things up pretend old bug') { - $lms->lms_begin; + $lms->lms_write_prepare; $lms->{dbh}->do('UPDATE folders SET loc = ? WHERE loc = ?', undef, "$maildir/", $maildir); ok(delete $lms->{fmap}, 'clear folder map'); - $lms->lms_commit; - $lms->lms_begin; + $lms->lms_write_prepare; ok($lms->set_src($deadbeef, $maildir, \$fname), 'set Maildir once'); - $lms->lms_commit; }; is_deeply([sort($ro->folders)], [$imap, $maildir], 'both folders shown'); @@ -70,12 +65,11 @@ is_deeply($ro->location_stats($maildir), { 'name.count' => 1 }, is_deeply($ro->location_stats($imap), { 'uid.count' => 1, 'uid.max' => 1, 'uid.min' => 1 }, 'IMAP location stats'); -$lms->lms_begin; +$lms->lms_write_prepare; is($lms->clear_src($imap, 1), 1, 'clear_src on IMAP'); is($lms->clear_src($maildir, \$fname), 1, 'clear_src on Maildir'); ok($lms->clear_src($imap, 1) == 0, 'clear_src again on IMAP'); ok($lms->clear_src($maildir, \$fname) == 0, 'clear_src again on Maildir'); -$lms->lms_commit; is_deeply($ro->location_stats($maildir), {}, 'nothing left'); done_testing; -- cgit v1.2.3-24-ge0c7