]> Sergey Matveev's repositories - public-inbox.git/blob - t/v2-add-remove-add.t
www: rework query responses to avoid COUNT in SQLite
[public-inbox.git] / t / v2-add-remove-add.t
1 # Copyright (C) 2018 all contributors <meta@public-inbox.org>
2 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
3 use strict;
4 use warnings;
5 use Test::More;
6 use PublicInbox::MIME;
7 use File::Temp qw/tempdir/;
8
9 foreach my $mod (qw(DBD::SQLite Search::Xapian)) {
10         eval "require $mod";
11         plan skip_all => "$mod missing for v2-add-remove-add.t" if $@;
12 }
13 use_ok 'PublicInbox::V2Writable';
14 my $mainrepo = tempdir('pi-add-remove-add-XXXXXX', TMPDIR => 1, CLEANUP => 1);
15 my $ibx = {
16         mainrepo => "$mainrepo/v2",
17         name => 'test-v2writable',
18         version => 2,
19         -primary_address => 'test@example.com',
20 };
21 $ibx = PublicInbox::Inbox->new($ibx);
22 my $mime = PublicInbox::MIME->create(
23         header => [
24                 From => 'a@example.com',
25                 To => 'test@example.com',
26                 Subject => 'this is a subject',
27                 Date => 'Fri, 02 Oct 1993 00:00:00 +0000',
28                 'Message-ID' => '<a-mid@b>',
29         ],
30         body => "hello world\n",
31 );
32 my $im = PublicInbox::V2Writable->new($ibx, 1);
33 $im->{parallel} = 0;
34 ok($im->add($mime), 'message added');
35 ok($im->remove($mime), 'message added');
36 ok($im->add($mime), 'message added again');
37 $im->done;
38 my $msgs = $ibx->recent({limit => 1000});
39 is($msgs->[0]->{mid}, 'a-mid@b', 'message exists in history');
40 is(scalar @$msgs, 1, 'only one message in history');
41
42 done_testing();