about summary refs log tree commit homepage
path: root/t
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2021-03-26 06:29:37 +0200
committerEric Wong <e@80x24.org>2021-03-26 19:59:34 +0000
commit43c43f785aa53607a0dd050989da5d7fd0dcfff4 (patch)
treef9fd037a837f4e38c654d7bb450f22b9473147dc /t
parent37dfb2c0d3c60277567325c15d5695b2dee03ad1 (diff)
downloadpublic-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.t46
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;