X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Fpsgi_attach.t;h=0dde9323dc3943a265284be192abf63022caa48b;hb=5d8dbb4aca5afcc6b98a4d951f03003fb7eaf356;hp=885a31bf89f09c40e99c4eaf9803c70ca5463c53;hpb=3d41aa23f35501ca92aab8aa42980fa73f7fa74f;p=public-inbox.git diff --git a/t/psgi_attach.t b/t/psgi_attach.t index 885a31bf..0dde9323 100644 --- a/t/psgi_attach.t +++ b/t/psgi_attach.t @@ -1,42 +1,36 @@ -# Copyright (C) 2016-2018 all contributors +# Copyright (C) 2016-2020 all contributors # License: AGPL-3.0+ use strict; use warnings; use Test::More; use Email::MIME; -use File::Temp qw/tempdir/; -my $tmpdir = tempdir('psgi-attach-XXXXXX', TMPDIR => 1, CLEANUP => 1); +use PublicInbox::TestCommon; +my ($tmpdir, $for_destroy) = tmpdir(); my $maindir = "$tmpdir/main.git"; my $addr = 'test-public@example.com'; my $cfgpfx = "publicinbox.test"; -my @mods = qw(HTTP::Request::Common Plack::Test URI::Escape); -foreach my $mod (@mods) { - eval "require $mod"; - plan skip_all => "$mod missing for plack.t" if $@; -} +my @mods = qw(HTTP::Request::Common Plack::Builder Plack::Test URI::Escape); +require_mods(@mods); use_ok $_ foreach @mods; +use_ok 'PublicInbox::WWW'; use PublicInbox::Import; use PublicInbox::Git; use PublicInbox::Config; -use PublicInbox::WWW; use_ok 'PublicInbox::WwwAttach'; -use Plack::Builder; -my $config = PublicInbox::Config->new({ - "$cfgpfx.address" => $addr, - "$cfgpfx.mainrepo" => $maindir, -}); -is(0, system(qw(git init -q --bare), $maindir), "git init (main)"); +my $config = PublicInbox::Config->new(\<new($maindir); my $im = PublicInbox::Import->new($git, 'test', $addr); +$im->init_bare; { - open my $fh, '<', '/dev/urandom' or die "unable to open urandom: $!\n"; - sysread($fh, my $buf, 8); - is(8, length($buf), 'read some random data'); my $qp = "abcdef=g\n==blah\n"; - my $b64 = 'b64'.$buf."\n"; + my $b64 = "b64\xde\xad\xbe\xef\n"; my $txt = "plain\ntext\npass\nthrough\n"; my $dot = "dotfile\n"; + my $mime = mime_load 't/psgi_attach.eml', sub { my $parts = [ Email::MIME->create( attributes => { @@ -65,14 +59,11 @@ my $im = PublicInbox::Import->new($git, 'test', $addr); }, body => $dot), ]; - my $mime = Email::MIME->create( + Email::MIME->create( parts => $parts, header_str => [ From => 'root@z', 'Message-Id' => '', Subject => 'hi'] - ); - $mime = $mime->as_string; - $mime =~ s/\r\n/\n/g; # normalize to LF only - $mime = Email::MIME->new($mime); + )}; # mime_load sub $im->add($mime); $im->done; @@ -111,7 +102,6 @@ my $im = PublicInbox::Import->new($git, 'test', $addr); ok(length($dot_res) >= length($dot), 'dot almost matches'); $res = $cb->(GET('/test/Z%40B/4-any-filename.txt')); is($res->content, $dot_res, 'user-specified filename is OK'); - }); } done_testing();