]> Sergey Matveev's repositories - public-inbox.git/blobdiff - t/lei-q-save.t
lei ls-search: command to list saved searches
[public-inbox.git] / t / lei-q-save.t
index 6cfac20b77c4f7425f3f78cadb201dad08cc116e..761814b4ebbe2c6a2c836ed7a01b4a99898c0308 100644 (file)
@@ -7,6 +7,8 @@ my $doc1 = eml_load('t/plack-qp.eml');
 $doc1->header_set('Date', PublicInbox::Smsg::date({ds => time - (86400 * 5)}));
 my $doc2 = eml_load('t/utf8.eml');
 $doc2->header_set('Date', PublicInbox::Smsg::date({ds => time - (86400 * 4)}));
+my $doc3 = eml_load('t/msg_iter-order.eml');
+$doc3->header_set('Date', PublicInbox::Smsg::date({ds => time - (86400 * 4)}));
 
 test_lei(sub {
        my $home = $ENV{HOME};
@@ -25,7 +27,11 @@ test_lei(sub {
        # ensure "lei up" works, since it compliments "lei q --save"
        $in = $doc2->as_string;
        lei_ok [qw(import -q -F eml -)], undef, { 0 => \$in, %$lei_opt };
-       lei_ok qw(up -q), $s[0];
+       opendir my $dh, '.' or xbail "opendir .: $!";
+       lei_ok qw(up -q md -C), $home;
+       lei_ok qw(up -q . -C), "$home/md";
+       lei_ok qw(up -q), "/$home/md";
+       chdir($dh) or xbail "fchdir . $!";
        my %after = map { $_ => 1 } glob("$home/md/cur/*");
        is(delete $after{(keys(%before))[0]}, 1, 'original message kept');
        is(scalar(keys %after), 1, 'one new message added');
@@ -38,5 +44,28 @@ test_lei(sub {
        $cfg = PublicInbox::Config->new("$s[0]/lei.saved-search");
        is_deeply $cfg->{'lei.q'}, 'd:last.week..',
                'q --stdin stores relative time';
+       my $size = -s "$home/mbcl2";
+       ok(defined($size) && $size > 0, 'results written');
+       lei_ok([qw(up mbcl2)], undef, { -C => $home, %$lei_opt });
+       is(-s "$home/mbcl2", $size, 'size unchanged on noop up');
+
+       $in = $doc3->as_string;
+       lei_ok [qw(import -q -F eml -)], undef, { 0 => \$in, %$lei_opt };
+       lei_ok([qw(up mbcl2)], undef, { -C => $home, %$lei_opt });
+       ok(-s "$home/mbcl2" > $size, 'size increased after up');
+
+       ok(!lei(qw(up -q), $home), 'up fails w/o --save');
+
+       lei_ok qw(ls-search); my @d = split(/\n/, $lei_out);
+       lei_ok qw(ls-search -z); my @z = split(/\0/, $lei_out);
+       is_deeply(\@d, \@z, '-z output matches non-z');
+       is_deeply(\@d, [ "$home/mbcl2", "$home/md/" ],
+               'ls-search output alphabetically sorted');
+       lei_ok qw(ls-search -l);
+       my $json = PublicInbox::Config->json->decode($lei_out);
+       ok($json && $json->[0]->{output}, 'JSON has output');
+       lei_ok qw(_complete lei up);
+       like($lei_out, qr!^\Q$home/mbcl2\E$!sm, 'complete got mbcl2 output');
+       like($lei_out, qr!^\Q$home/md/\E$!sm, 'complete got maildir output');
 });
 done_testing;