]> Sergey Matveev's repositories - public-inbox.git/blobdiff - t/plack.t
wwwstatic: set "Vary: Accept-Encoding" in static gzip response
[public-inbox.git] / t / plack.t
index 443831a1513b3ecd2695320f3552d98ef6828283..ea31879285fd6d89268677a6eb6941c11fffc6e7 100644 (file)
--- a/t/plack.t
+++ b/t/plack.t
@@ -1,4 +1,4 @@
-# Copyright (C) 2014-2019 all contributors <meta@public-inbox.org>
+# Copyright (C) 2014-2020 all contributors <meta@public-inbox.org>
 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
 use strict;
 use warnings;
@@ -40,6 +40,7 @@ Message-Id: <blah\@example.com>
 Subject: hihi
 Date: Fri, 02 Oct 1993 00:00:00 +0000
 
+> quoted text
 zzzzzz
 EOF
        $im->add($mime);
@@ -48,6 +49,84 @@ EOF
        like($rev, qr/\A[a-f0-9]{40}/, "good revision committed");
        @ls = $git->qx(qw(ls-tree -r --name-only HEAD));
        chomp @ls;
+
+       # multipart with two text bodies
+       my %attr_text = (attributes => { content_type => 'text/plain' });
+       my $parts = [
+               Email::MIME->create(%attr_text, body => 'hi'),
+               Email::MIME->create(%attr_text, body => 'bye')
+       ];
+       $mime = Email::MIME->create(
+               header_str => [
+                       From => 'a@example.com',
+                       Subject => 'blargh',
+                       'Message-ID' => '<multipart@example.com>',
+                       'In-Reply-To' => '<irp@example.com>'
+               ],
+               parts => $parts,
+       );
+       $im->add($mime);
+
+       # multipart with attached patch + filename
+       $parts = [ Email::MIME->create(%attr_text, body => 'hi, see attached'),
+               Email::MIME->create(
+                       attributes => {
+                                       content_type => 'text/plain',
+                                       filename => "foo&.patch",
+                       },
+                       body => "--- a/file\n+++ b/file\n" .
+                               "@@ -49, 7 +49,34 @@\n"
+                       )
+       ];
+       $mime = Email::MIME->create(
+               header_str => [
+                       From => 'a@example.com',
+                       Subject => '[PATCH] asdf',
+                       'Message-ID' => '<patch@example.com>'
+               ],
+               parts => $parts
+       );
+       $im->add($mime);
+
+       # multipart collapsed to single quoted-printable text/plain
+       $parts = [
+               Email::MIME->create(
+                       attributes => {
+                               content_type => 'text/plain',
+                               encoding => 'quoted-printable'
+                       },
+                       body => 'hi = bye',
+               )
+       ];
+       $mime = Email::MIME->create(
+               header_str => [
+                       From => 'qp@example.com',
+                       Subject => 'QP',
+                       'Message-ID' => '<qp@example.com>',
+                       ],
+               parts => $parts,
+       );
+       like($mime->body_raw, qr/hi =3D bye=/, 'our test used QP correctly');
+       $im->add($mime);
+
+       my $crlf = <<EOF;
+From: Me
+  <me\@example.com>
+To: $addr
+Message-Id: <crlf\@example.com>
+Subject: carriage
+  return
+  in
+  long
+  subject
+Date: Fri, 02 Oct 1993 00:00:00 +0000
+
+:(
+EOF
+       $crlf =~ s/\n/\r\n/sg;
+       $im->add(Email::MIME->new($crlf));
+
+       $im->done;
 }
 
 test_psgi($app, sub {
@@ -58,6 +137,16 @@ test_psgi($app, sub {
        }
 });
 
+test_psgi($app, sub {
+       my ($cb) = @_;
+       my $res = $cb->(GET('http://example.com/test/crlf@example.com/'));
+       is($res->code, 200, 'retrieved CRLF as HTML');
+       unlike($res->content, qr/\r/, 'no CR in HTML');
+       $res = $cb->(GET('http://example.com/test/crlf@example.com/raw'));
+       is($res->code, 200, 'retrieved CRLF raw');
+       like($res->content, qr/\r/, 'CR preserved in raw message');
+});
+
 # redirect with newsgroup
 test_psgi($app, sub {
        my ($cb) = @_;
@@ -127,6 +216,8 @@ test_psgi($app, sub {
        like($body, qr/<title>test for public-inbox/,
                "set title in XML feed");
        like($body, qr/zzzzzz/, 'body included');
+       $res = $cb->(GET($pfx . '/description'));
+       like($res->content, qr/test for public-inbox/, 'got description');
 });
 
 test_psgi($app, sub {
@@ -134,8 +225,10 @@ test_psgi($app, sub {
        my $path = '/blah@example.com/';
        my $res = $cb->(GET($pfx . $path));
        is(200, $res->code, "success for $path");
-       like($res->content, qr!<title>hihi - Me</title>!,
-               "HTML returned");
+       my $html = $res->content;
+       like($html, qr!<title>hihi - Me</title>!, 'HTML returned');
+       like($html, qr!<a\nhref="raw"!s, 'raw link present');
+       like($html, qr!&gt; quoted text!s, 'quoted text inline');
 
        $path .= 'f/';
        $res = $cb->(GET($pfx . $path));
@@ -143,6 +236,19 @@ test_psgi($app, sub {
        my $location = $res->header('Location');
        like($location, qr!/blah\@example\.com/\z!,
                '/$MESSAGE_ID/f/ redirected to /$MESSAGE_ID/');
+
+       $res = $cb->(GET($pfx . '/multipart@example.com/'));
+       like($res->content,
+               qr/hi\n.*-- Attachment #2.*\nbye\n/s, 'multipart split');
+
+       $res = $cb->(GET($pfx . '/patch@example.com/'));
+       $html = $res->content;
+       like($html, qr!see attached!, 'original body');
+       like($html, qr!.*Attachment #2: foo&(?:amp|#38);\.patch --!,
+               'parts split with filename');
+
+       $res = $cb->(GET($pfx . '/qp@example.com/'));
+       like($res->content, qr/\bhi = bye\b/, "HTML output decoded QP");
 });
 
 test_psgi($app, sub {