public-inbox.git  about / heads / tags
an "archives first" approach to mailing lists
blob 49f254e9a93b742220001091b997d14be20ef12e 1860 bytes (raw)
$ git show stable-1.6:t/thread-index-gap.t	# shows this blob on the CLI

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
 
#!perl -w
# Copyright (C) 2020 all contributors <meta@public-inbox.org>
# License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
use strict;
use v5.10.1;
use Test::More;
use PublicInbox::TestCommon;
use PublicInbox::Eml;
use PublicInbox::InboxWritable;
use PublicInbox::Config;
use List::Util qw(shuffle);
require_mods(qw(DBD::SQLite));
require_git(2.6);

chomp(my @msgs = split(/\n\n/, <<'EOF')); # "git log" order
Subject: [bug#45000] [PATCH 1/9]
References: <20201202045335.31096-1-j@example.com>
Message-Id: <20201202045540.31248-1-j@example.com>

Subject: [bug#45000] [PATCH 0/9]
Message-Id: <20201202045335.31096-1-j@example.com>

Subject: [bug#45000] [PATCH 0/9]
References: <20201202045335.31096-1-j@example.com>
Message-ID: <86sg8o1mou.fsf@example.com>

Subject: [bug#45000] [PATCH 8/9]
Message-Id: <20201202045540.31248-8-j@example.com>
References: <20201202045540.31248-1-j@example.com>

EOF

my ($home, $for_destroy) = tmpdir();
local $ENV{HOME} = $home;
for my $msgs (['orig', reverse @msgs], ['shuffle', shuffle(@msgs)]) {
	my $desc = shift @$msgs;
	my $n = "index-cap-$desc";
	run_script([qw(-init -L basic -V2), $n, "$home/$n",
		"http://example.com/$n", "$n\@example.com"]) or
		BAIL_OUT 'init';
	my $ibx = PublicInbox::Config->new->lookup_name($n);
	my $im = PublicInbox::InboxWritable->new($ibx)->importer(0);
	for my $m (@$msgs) {
		$im->add(PublicInbox::Eml->new("$m\nFrom: x\@example.com\n\n"));
	}
	$im->done;
	my $over = $ibx->over;
	my @tid = $over->dbh->selectall_array('SELECT DISTINCT(tid) FROM over');
	is(scalar(@tid), 1, "only one thread initially ($desc)");
	$over->dbh_close;
	run_script([qw(-index --reindex --rethread), $ibx->{inboxdir}]) or
		BAIL_OUT 'rethread';
	@tid = $over->dbh->selectall_array('SELECT DISTINCT(tid) FROM over');
	is(scalar(@tid), 1, "only one thread after rethread ($desc)");
}

done_testing;

git clone https://public-inbox.org/public-inbox.git
git clone http://7fh6tueqddpjyxjmgtdiueylzoqt6pt7hec3pukyptlmohoowvhde4yd.onion/public-inbox.git