X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Flei-q-remote-import.t;h=800670610f5129ab2d9f027e5243ac8b849bba68;hb=d98abf13946beaf685804e4ec2d79019129415b9;hp=4088b6ada1567ed97f7d6f98ba3e0a2e160c474d;hpb=3104d7492aa4aee07455dcad7449f786188afdf5;p=public-inbox.git diff --git a/t/lei-q-remote-import.t b/t/lei-q-remote-import.t index 4088b6ad..80067061 100644 --- a/t/lei-q-remote-import.t +++ b/t/lei-q-remote-import.t @@ -2,8 +2,7 @@ # Copyright (C) 2021 all contributors # License: AGPL-3.0+ use strict; use v5.10.1; use PublicInbox::TestCommon; -require_git 2.6; -require_mods(qw(json DBD::SQLite Search::Xapian)); +require_mods(qw(lei -httpd)); use PublicInbox::MboxReader; my ($ro_home, $cfg_path) = setup_public_inboxes; my $sock = tcp_server; @@ -36,7 +35,8 @@ test_lei({ tmpdir => $tmpdir }, sub { is_deeply($slurp_emls->($o), $exp1, 'got results after remote search'); unlink $o or BAIL_OUT $!; lei_ok(@cmd); - ok(-f $o && -s _, 'output exists after import but is not empty'); + ok(-f $o && -s _, 'output exists after import but is not empty') or + diag $lei_err; is_deeply($slurp_emls->($o), $exp1, 'got results w/o remote search'); unlink $o or BAIL_OUT $!; @@ -58,5 +58,44 @@ test_lei({ tmpdir => $tmpdir }, sub { unlink "$o.lock" or BAIL_OUT $!; lei_ok(@cmd, '--lock=dotlock,timeout=0.000001', \'succeeds after lock removal'); + + my $ibx = create_inbox 'local-external', indexlevel => 'medium', sub { + my ($im) = @_; + $im->add(eml_load('t/utf8.eml')) or BAIL_OUT '->add'; + }; + lei_ok(qw(add-external -q), $ibx->{inboxdir}); + lei_ok(qw(q -q -o), "mboxrd:$o", '--only', $url, + 'm:testmessage@example.com'); + is($lei_err, '', 'no warnings or errors'); + ok(-s $o, 'got result from remote external'); + my $exp = eml_load('t/utf8.eml'); + is_deeply($slurp_emls->($o), [$exp], 'got expected result'); + lei_ok(qw(q --no-external -o), "mboxrd:/dev/stdout", + 'm:testmessage@example.com'); + is($lei_out, '', 'message not imported when in local external'); + + open $fh, '>', $o or BAIL_OUT; + print $fh <<'EOF' or BAIL_OUT; +From a@z Mon Sep 17 00:00:00 2001 +From: nobody@localhost +Date: Sat, 13 Mar 2021 18:23:01 +0600 +Message-ID: +Status: OR + +whatever +EOF + close $fh or BAIL_OUT; + lei_ok(qw(q -o), "mboxrd:$o", 'm:testmessage@example.com'); + is_deeply($slurp_emls->($o), [$exp], + 'got expected result after clobber') or diag $lei_err; + lei_ok(qw(q -o mboxrd:/dev/stdout m:never-before-seen@example.com)); + like($lei_out, qr/seen\@example\.com>\nStatus: RO\n\nwhatever/sm, + '--import-before imported totally unseen message'); + + lei_ok(qw(q --save z:0.. -o), "$ENV{HOME}/md", '--only', $url); + my @f = glob("$ENV{HOME}/md/*/*"); + lei_ok('up', "$ENV{HOME}/md"); + is_deeply(\@f, [ glob("$ENV{HOME}/md/*/*") ], + 'lei up remote dedupe works on maildir'); }); done_testing;