]> Sergey Matveev's repositories - public-inbox.git/blobdiff - t/view.t
www_stream: add response wrapper sub
[public-inbox.git] / t / view.t
index 325f509c0660e83d6f7c03a81809fd3b6552c13b..4fdd15180cc45983630c6f2aa4f2b34f519f4704 100644 (file)
--- a/t/view.t
+++ b/t/view.t
@@ -4,7 +4,44 @@ use strict;
 use warnings;
 use Test::More;
 use Email::MIME;
-use PublicInbox::View;
+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");
+}
+
+# FIXME: make this test less fragile
+my $ctx = {
+       env => { HTTP_HOST => 'example.com', 'psgi.url_scheme' => 'http' },
+       -inbox => Plack::Util::inline_object(
+               name => 'test',
+               search => sub { undef },
+               cloneurl => sub {[]},
+               description => sub { '' }),
+};
+$ctx->{-inbox}->{-primary_address} = 'test@example.com';
+
+sub msg_html ($) {
+       my ($mime) = @_;
+
+       my $s = '';
+       my $r = PublicInbox::View::msg_html($ctx, $mime);
+       my $body = $r->[2];
+       while (defined(my $buf = $body->getline)) {
+               $s .= $buf;
+       }
+       $body->close;
+       $s;
+}
 
 # plain text
 {
@@ -41,26 +78,12 @@ EOF
                body => $body,
        )->as_string;
        my $mime = Email::MIME->new($s);
-       my $html = PublicInbox::View::msg_html(undef, $mime);
+       my $html = msg_html($mime);
 
        # ghetto tests
-       like($html, qr!<a\nhref="\.\./raw"!s, "raw link present");
+       like($html, qr!<a\nhref="raw"!s, "raw link present");
        like($html, qr/hello world\b/, "body present");
        like($html, qr/&gt; keep this inline/, "short quoted text is inline");
-       like($html, qr/<a\nid=[^>]+><\/a>&gt; Long and wordy/,
-               "long quoted text is anchored");
-
-       # short page
-       my $pfx = "../hello%40example.com/f/";
-       $mime = Email::MIME->new($s);
-       my $short = PublicInbox::View::msg_html(undef, $mime, $pfx);
-       like($short, qr!<a\nhref="\.\./hello%40example\.com/f/!s,
-               "MID link present");
-       like($short, qr/\n&gt; keep this inline/,
-               "short quoted text is inline");
-       like($short, qr/<a\nhref="\Q$pfx\E#[^>]+>Long and wordy/,
-               "long quoted text is made into a link");
-       ok(length($short) < length($html), "short page is shorter");
 }
 
 # multipart crap
@@ -85,8 +108,8 @@ EOF
                parts => $parts,
        );
 
-       my $html = PublicInbox::View::msg_html(undef, $mime);
-       like($html, qr/hi\n-+ part #2 -+\nbye\n/, "multipart split");
+       my $html = msg_html($mime);
+       like($html, qr/hi\n.*-- Attachment #2.*\nbye\n/s, "multipart split");
 }
 
 # multipart email with attached patch
@@ -114,8 +137,8 @@ EOF
                parts => $parts,
        );
 
-       my $html = PublicInbox::View::msg_html(undef, $mime);
-       like($html, qr!see attached patch\n-+ foo\.patch -+\n--- a/file\n!,
+       my $html = msg_html($mime);
+       like($html, qr!.*Attachment #2: foo\.patch --!,
                "parts split with filename");
 }
 
@@ -140,18 +163,20 @@ EOF
        );
 
        my $orig = $mime->body_raw;
-       my $html = PublicInbox::View::msg_html(undef, $mime);
+       my $html = msg_html($mime);
        like($orig, qr/hi =3D bye=/, "our test used QP correctly");
        like($html, qr/\bhi = bye\b/, "HTML output decoded QP");
 }
 
+{
+       use PublicInbox::MID qw/id_compress/;
 
-{      # XXX dirty hack
-       use PublicInbox::MID qw/mid_compress/;
-       like(mid_compress('foo%bar@wtf'), qr/\A[a-f0-9]{40}\z/,
+       # n.b: this is probably invalid since we dropped CGI for PSGI:
+       like(id_compress('foo%bar@wtf'), qr/\A[a-f0-9]{40}\z/,
                "percent always converted to sha1 to workaround buggy httpds");
-       is(mid_compress('foobar@wtf'), 'foobar@wtf',
-               'regular MID not compressed');
+
+       is(id_compress('foobar-wtf'), 'foobar-wtf',
+               'regular ID not compressed');
 }
 
 done_testing();