about summary refs log tree commit homepage
path: root/t
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2021-04-16 16:10:27 -0700
committerEric Wong <e@80x24.org>2021-04-16 22:24:47 -0400
commit2e4e4b0d6f30d9d4612066395ba694c7c7d61e6e (patch)
tree7478cde9a242d7828792c458c442f6e69d3331d3 /t
parentfd3b46aa0577d62553f61054270db6626ccc6759 (diff)
downloadpublic-inbox-2e4e4b0d6f30d9d4612066395ba694c7c7d61e6e.tar.gz
Somebody may want a saved search which consistently asks for
messages within a rolling time period window.  In other words,
we want to support using "lei q --save dt:last.week.." and keeps
the "dt:last.week.." relative to whenever "lei up" is run.  This
ensures relative date-time specifications get used in the future
rather than converting into an absolute date-time from the
initial "lei q" invocation.
Diffstat (limited to 't')
-rw-r--r--t/lei-q-save.t25
1 files changed, 21 insertions, 4 deletions
diff --git a/t/lei-q-save.t b/t/lei-q-save.t
index a6d579cf..6cfac20b 100644
--- a/t/lei-q-save.t
+++ b/t/lei-q-save.t
@@ -2,24 +2,41 @@
 # Copyright (C) 2021 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 PublicInbox::TestCommon;
+use PublicInbox::Smsg;
 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)}));
+
 test_lei(sub {
         my $home = $ENV{HOME};
-        lei_ok qw(import -q t/plack-qp.eml);
-        lei_ok qw(q -q --save z:0..), '-o', "$home/md/";
+        my $in = $doc1->as_string;
+        lei_ok [qw(import -q -F eml -)], undef, { 0 => \$in, %$lei_opt };
+        lei_ok qw(q -q --save z:0.. d:last.week..), '-o', "$home/md/";
         my %before = map { $_ => 1 } glob("$home/md/cur/*");
         is_deeply(eml_load((keys %before)[0]), $doc1, 'doc1 matches');
 
         my @s = glob("$home/.local/share/lei/saved-searches/md-*");
         is(scalar(@s), 1, 'got one saved search');
+        my $cfg = PublicInbox::Config->new("$s[0]/lei.saved-search");
+        is_deeply($cfg->{'lei.q'}, ['z:0..', 'd:last.week..'],
+                'store relative time, not parsed (absolute) timestamp');
 
         # ensure "lei up" works, since it compliments "lei q --save"
-        lei_ok qw(import t/utf8.eml);
-        lei_ok qw(up), $s[0];
+        $in = $doc2->as_string;
+        lei_ok [qw(import -q -F eml -)], undef, { 0 => \$in, %$lei_opt };
+        lei_ok qw(up -q), $s[0];
         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');
         is_deeply(eml_load((keys %after)[0]), $doc2, 'doc2 matches');
+
+        # check stdin
+        lei_ok [qw(q --save - -o), "mboxcl2:mbcl2" ],
+                undef, { -C => $home, %$lei_opt, 0 => \'d:last.week..'};
+        @s = glob("$home/.local/share/lei/saved-searches/mbcl2-*");
+        $cfg = PublicInbox::Config->new("$s[0]/lei.saved-search");
+        is_deeply $cfg->{'lei.q'}, 'd:last.week..',
+                'q --stdin stores relative time';
 });
 done_testing;