]> Sergey Matveev's repositories - public-inbox.git/blobdiff - t/view.t
run update-copyrights from gnulib for 2019
[public-inbox.git] / t / view.t
index 4cee4395f7ce88926d797579d65ef5289525e41f..1de3a02cf2eaa717cd2c17f026aba87240a5b31a 100644 (file)
--- a/t/view.t
+++ b/t/view.t
@@ -1,33 +1,26 @@
-# Copyright (C) 2013-2015 all contributors <meta@public-inbox.org>
-# License: AGPLv3 or later (https://www.gnu.org/licenses/agpl-3.0.txt)
+# Copyright (C) 2013-2019 all contributors <meta@public-inbox.org>
+# License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
 use strict;
 use warnings;
 use Test::More;
 use Email::MIME;
 use Plack::Util;
 use_ok 'PublicInbox::View';
-
-my @q = (
-       'foo@bar', 'foo@bar',
-       'a b', "'a b'",
-       "a'b", "'a'\\''b'",
-);
-while (@q) {
-       my $input = shift @q;
-       my $expect = shift @q;
-       my $res = PublicInbox::View::squote_maybe($input);
-       is($res, $expect, "quote $input => $res");
-}
+use_ok 'PublicInbox::Config';
 
 # FIXME: make this test less fragile
 my $ctx = {
        env => { HTTP_HOST => 'example.com', 'psgi.url_scheme' => 'http' },
        -inbox => Plack::Util::inline_object(
                name => 'test',
+               over => sub { undef },
                search => sub { undef },
                base_url => sub { 'http://example.com/' },
                cloneurl => sub {[]},
+               nntp_url => sub {[]},
+               max_git_epoch => sub { undef },
                description => sub { '' }),
+       www => Plack::Util::inline_object(style => sub { '' }),
 };
 $ctx->{-inbox}->{-primary_address} = 'test@example.com';
 
@@ -123,7 +116,7 @@ EOF
                Email::MIME->create(
                        attributes => {
                                content_type => 'text/plain',
-                               filename => "foo.patch",
+                               filename => "foo&.patch",
                        },
                        body => "--- a/file\n+++ b/file\n" .
                                "@@ -49, 7 +49,34 @@\n",
@@ -139,7 +132,7 @@ EOF
        );
 
        my $html = msg_html($mime);
-       like($html, qr!.*Attachment #2: foo\.patch --!,
+       like($html, qr!.*Attachment #2: foo&(?:amp|#38);\.patch --!,
                "parts split with filename");
 }
 
@@ -180,4 +173,25 @@ EOF
                'regular ID not compressed');
 }
 
+{
+       my $cols = PublicInbox::View::COLS();
+       my @addr;
+       until (length(join(', ', @addr)) > ($cols * 2)) {
+               push @addr, '"l, f" <a@a>';
+               my $n = int(rand(20)) + 1;
+               push @addr, ('x'x$n).'@x';
+       }
+       my $orig = join(', ', @addr);
+       my $res = PublicInbox::View::fold_addresses($orig.'');
+       isnt($res, $orig, 'folded result');
+       unlike($res, qr/l,\n\tf/s, '"last, first" no broken');
+       my @nospc = ($res, $orig);
+       s/\s+//g for @nospc;
+       is($nospc[0], $nospc[1], 'no addresses lost in translation');
+       my $tws = PublicInbox::View::fold_addresses($orig.' ');
+       # (Email::Simple drops leading whitespace, but not trailing)
+       $tws =~ s/ \z//;
+       is($tws, $res, 'not thrown off by trailing whitespace');
+}
+
 done_testing();