]> Sergey Matveev's repositories - public-inbox.git/blob - t/filter_rubylang.t
576cbdeb61883fc5b2439c01aaf019a80f9909d4
[public-inbox.git] / t / filter_rubylang.t
1 # Copyright (C) 2017-2019 all contributors <meta@public-inbox.org>
2 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
3 use strict;
4 use warnings;
5 use Test::More;
6 use Email::MIME;
7 use PublicInbox::TestCommon;
8 use_ok 'PublicInbox::Filter::RubyLang';
9
10 my $f = PublicInbox::Filter::RubyLang->new;
11 ok($f, 'created PublicInbox::Filter::RubyLang object');
12 my $msg = <<'EOF';
13 Subject: test
14
15 keep this
16
17 Unsubscribe: <mailto:ruby-core-request@ruby-lang.org?subject=unsubscribe>
18 <http://lists.ruby-lang.org/cgi-bin/mailman/options/ruby-core>
19 EOF
20 my $mime = Email::MIME->new($msg);
21 my $ret = $f->delivery($mime);
22 is($ret, $mime, "delivery successful");
23 is($mime->body, "keep this\n", 'normal message filtered OK');
24
25 SKIP: {
26         eval 'require DBD::SQLite';
27         skip 'DBD::SQLite missing for altid mapping', 4 if $@;
28         use_ok 'PublicInbox::Inbox';
29         my ($git_dir, $for_destroy) = tmpdir();
30         is(mkdir("$git_dir/public-inbox"), 1, "created public-inbox dir");
31         my $altid = [ "serial:ruby-core:file=msgmap.sqlite3" ];
32         my $ibx = PublicInbox::Inbox->new({ inboxdir => $git_dir,
33                                                 altid => $altid });
34         $f = PublicInbox::Filter::RubyLang->new(-inbox => $ibx);
35         $msg = <<'EOF';
36 X-Mail-Count: 12
37 Message-ID: <a@b>
38
39 EOF
40         $mime = Email::MIME->new($msg);
41         $ret = $f->delivery($mime);
42         is($ret, $mime, "delivery successful");
43         my $mm = PublicInbox::Msgmap->new($git_dir);
44         is($mm->num_for('a@b'), 12, 'MM entry created based on X-ML-Count');
45
46         $msg = <<'EOF';
47 X-Mail-Cout: 12
48 Message-ID: <b@b>
49
50 EOF
51
52         $mime = Email::MIME->new($msg);
53         $ret = $f->delivery($mime);
54         is($ret, 100, "delivery rejected without X-Mail-Count");
55 }
56
57 done_testing();