X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Fview.t;h=4fdd15180cc45983630c6f2aa4f2b34f519f4704;hb=e158d56a54d3c6d4890aa6ac4caa28a834279af0;hp=ca456aab86073a09e779515acd7018e1e4c71df4;hpb=0ccdf0171d4ee715352feec69a1ed330326dfe1a;p=public-inbox.git diff --git a/t/view.t b/t/view.t index ca456aab..4fdd1518 100644 --- a/t/view.t +++ b/t/view.t @@ -1,10 +1,47 @@ -# Copyright (C) 2013, Eric Wong and all contributors +# Copyright (C) 2013-2015 all contributors # License: AGPLv3 or later (https://www.gnu.org/licenses/agpl-3.0.txt) 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,25 +78,12 @@ EOF body => $body, )->as_string; my $mime = Email::MIME->new($s); - my $html = PublicInbox::View->msg_html($mime); + my $html = msg_html($mime); # ghetto tests - like($html, qr!]+><\/a>> Long and wordy/, - "long quoted text is anchored"); - - # short page - my $pfx = "http://example.com/test/f"; - $mime = Email::MIME->new($s); - my $short = PublicInbox::View->msg_html($mime, $pfx); - like($short, qr! $parts, ); - my $html = PublicInbox::View->msg_html($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 @@ -113,8 +137,8 @@ EOF parts => $parts, ); - my $html = PublicInbox::View->msg_html($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"); } @@ -139,18 +163,20 @@ EOF ); my $orig = $mime->body_raw; - my $html = PublicInbox::View->msg_html($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_compressed/; - like(mid_compressed('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_compressed('foobar@wtf'), 'foobar@wtf', - 'regular MID not compressed'); + + is(id_compress('foobar-wtf'), 'foobar-wtf', + 'regular ID not compressed'); } done_testing();