]> Sergey Matveev's repositories - public-inbox.git/blobdiff - t/watch_filter_rubylang.t
config: support "inboxdir" in addition to "mainrepo"
[public-inbox.git] / t / watch_filter_rubylang.t
index 325655561a5c8389dcf8736b771a7ca5bdbdf8a2..4b88d670e84382f611ad6f047d76642ab68eec36 100644 (file)
@@ -2,6 +2,7 @@
 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
 use strict;
 use warnings;
+require './t/common.perl';
 use Test::More;
 use File::Temp qw/tempdir/;
 use PublicInbox::MIME;
@@ -12,25 +13,34 @@ foreach my $mod (@mods) {
        plan skip_all => "$mod missing for watch_filter_rubylang_v2.t" if $@;
 }
 
-use_ok 'PublicInbox::V2Writable';
 use_ok 'PublicInbox::WatchMaildir';
 use_ok 'PublicInbox::Emergency';
 my $tmpdir = tempdir('watch-XXXXXX', TMPDIR => 1, CLEANUP => 1);
 local $ENV{PI_CONFIG} = "$tmpdir/pi_config";
 
-for my $v (qw(V1 V2)) {
+my @v = qw(V1);
+SKIP: {
+       if (require_git(2.6, 1)) {
+               use_ok 'PublicInbox::V2Writable';
+               push @v, 'V2';
+       } else {
+               skip 'git 2.6+ needed for V2', 40;
+       }
+}
+
+for my $v (@v) {
        my @warn;
        $SIG{__WARN__} = sub { push @warn, @_ };
        my $cfgpfx = "publicinbox.$v";
-       my $mainrepo = "$tmpdir/$v";
+       my $inboxdir = "$tmpdir/$v";
        my $maildir = "$tmpdir/md-$v";
        my $spamdir = "$tmpdir/spam-$v";
        my $addr = "test-$v\@example.com";
-       my @cmd = ('blib/script/public-inbox-init', "-$v", $v, $mainrepo,
+       my @cmd = ('blib/script/public-inbox-init', "-$v", $v, $inboxdir,
                "http://example.com/$v", $addr);
        is(system(@cmd), 0, 'public-inbox init OK');
        if ($v eq 'V1') {
-               is(system('blib/script/public-inbox-index', $mainrepo), 0);
+               is(system('blib/script/public-inbox-index', $inboxdir), 0);
        }
        PublicInbox::Emergency->new($spamdir);
 
@@ -60,15 +70,15 @@ spam
 EOF
        PublicInbox::Emergency->new($maildir)->prepare(\"$spam");
 
-       my %orig = (
-               "$cfgpfx.address" => $addr,
-               "$cfgpfx.mainrepo" => $mainrepo,
-               "$cfgpfx.watch" => "maildir:$maildir",
-               "$cfgpfx.filter" => 'PublicInbox::Filter::RubyLang',
-               "$cfgpfx.altid" => 'serial:alerts:file=msgmap.sqlite3',
-               "publicinboxwatch.watchspam" => "maildir:$spamdir",
-       );
-       my $config = PublicInbox::Config->new({%orig});
+       my $orig = <<EOF;
+$cfgpfx.address=$addr
+$cfgpfx.inboxdir=$inboxdir
+$cfgpfx.watch=maildir:$maildir
+$cfgpfx.filter=PublicInbox::Filter::RubyLang
+$cfgpfx.altid=serial:alerts:file=msgmap.sqlite3
+publicinboxwatch.watchspam=maildir:$spamdir
+EOF
+       my $config = PublicInbox::Config->new(\$orig);
        my $ibx = $config->lookup_name($v);
        ok($ibx, 'found inbox by name');
 
@@ -98,7 +108,7 @@ EOF
        }
        $w->scan('full');
 
-       $config = PublicInbox::Config->new({%orig});
+       $config = PublicInbox::Config->new(\$orig);
        $ibx = $config->lookup_name($v);
        ($tot, undef) = $ibx->search->reopen->query('b:spam');
        is($tot, 0, 'spam removed');