diff options
author | Eric Wong <e@80x24.org> | 2021-03-26 06:29:37 +0200 |
---|---|---|
committer | Eric Wong <e@80x24.org> | 2021-03-26 19:59:34 +0000 |
commit | 43c43f785aa53607a0dd050989da5d7fd0dcfff4 (patch) | |
tree | f9fd037a837f4e38c654d7bb450f22b9473147dc /t | |
parent | 37dfb2c0d3c60277567325c15d5695b2dee03ad1 (diff) | |
download | public-inbox-43c43f785aa53607a0dd050989da5d7fd0dcfff4.tar.gz |
"lei q" now displays labels in JSON output, "lei mark" can add or remove labels for any messages. "lei ls-label" is supported, too. Unfortunately, "lei q" won't hande "kw:" or "L:" for external messages, they must be imported, first.
Diffstat (limited to 't')
-rw-r--r-- | t/lei-mark.t | 46 |
1 files changed, 42 insertions, 4 deletions
diff --git a/t/lei-mark.t b/t/lei-mark.t index 76995589..23f5002e 100644 --- a/t/lei-mark.t +++ b/t/lei-mark.t @@ -4,22 +4,32 @@ use strict; use v5.10.1; use PublicInbox::TestCommon; require_git 2.6; require_mods(qw(json DBD::SQLite Search::Xapian)); +my ($ro_home, $cfg_path) = setup_public_inboxes; my $check_kw = sub { my ($exp, %opt) = @_; + my $args = $opt{args} // []; my $mid = $opt{mid} // 'testmessage@example.com'; - lei_ok('q', "m:$mid"); + lei_ok('q', "m:$mid", @$args); my $res = json_utf8->decode($lei_out); is($res->[1], undef, 'only got one result'); my $msg = $opt{msg} ? " $opt{msg}" : ''; ($exp ? is_deeply($res->[0]->{kw}, $exp, "got @$exp$msg") : is($res->[0]->{kw}, undef, "got undef$msg")) or diag explain($res); + if (exists $opt{L}) { + $exp = $opt{L}; + ($exp ? is_deeply($res->[0]->{L}, $exp, "got @$exp$msg") + : is($res->[0]->{L}, undef, "got undef$msg")) or + diag explain($res); + } }; test_lei(sub { + lei_ok(qw(ls-label)); is($lei_out, '', 'no labels, yet'); lei_ok(qw(import -F eml t/utf8.eml)); - lei_ok(qw(mark -F eml t/utf8.eml +kw:flagged)); - $check_kw->(['flagged']); + lei_ok(qw(mark -F eml t/utf8.eml +kw:flagged +L:urgent)); + $check_kw->(['flagged'], L => ['urgent']); + lei_ok(qw(ls-label)); is($lei_out, "urgent\n", 'label found'); ok(!lei(qw(mark -F eml t/utf8.eml +kw:seeen)), 'bad kw rejected'); like($lei_err, qr/`seeen' is not one of/, 'got helpful error'); ok(!lei(qw(mark -F eml t/utf8.eml +k:seen)), 'bad prefix rejected'); @@ -41,7 +51,35 @@ test_lei(sub { $check_kw->(['answered'], msg => 'Maildir Status ignored'); open my $in, '<', 't/utf8.eml' or BAIL_OUT $!; - lei_ok([qw(mark -F eml - +kw:seen)], undef, { %$lei_opt, 0 => $in }); + lei_ok([qw(mark -F eml - +kw:seen +L:nope)], + undef, { %$lei_opt, 0 => $in }); $check_kw->(['answered', 'seen'], msg => 'stdin works'); + lei_ok(qw(q L:urgent)); + my $res = json_utf8->decode($lei_out); + is($res->[0]->{'m'}, 'testmessage@example.com', 'L: query works'); + lei_ok(qw(q kw:seen)); + my $r2 = json_utf8->decode($lei_out); + is_deeply($r2, $res, 'kw: query works, too') or + diag explain([$r2, $res]); + + lei_ok(qw(_complete lei mark)); + my %c = map { $_ => 1 } split(/\s+/, $lei_out); + ok($c{'+L:urgent'} && $c{'-L:urgent'} && + $c{'+L:nope'} && $c{'-L:nope'}, 'completed with labels'); + + my $mid = 'qp@example.com'; + lei_ok qw(q -f mboxrd --only), "$ro_home/t2", "mid:$mid"; + $in = $lei_out; + lei_ok [qw(mark -F mboxrd --stdin +kw:seen +L:qp)], + undef, { %$lei_opt, 0 => \$in }; + $check_kw->(['seen'], L => ['qp'], mid => $mid, + args => [ '--only', "$ro_home/t2" ], + msg => 'external-only message'); + lei_ok(qw(ls-label)); + is($lei_out, "nope\nqp\nurgent\n", 'ls-label shows qp'); + + if (0) { # TODO label+kw search w/ externals + lei_ok(qw(q L:qp), "mid:$mid", '--only', "$ro_home/t2"); + } }); done_testing; |