This file documents the revision history for Perl extension HTTP::Body.
+1.08
+ - Temp files now preserve the suffix of the uploaded file. This makes
+ it possible to feed the file directly into a mime-type-determing
+ module that may rely on this suffix as part of its heuristic. (Dave
+ Rolsky)
+
1.07 2010-01-24 20:40:00
- Up IO::File dependency.
$part->{filename} = $filename;
if ( $filename ne "" ) {
- my $fh = File::Temp->new( UNLINK => 0, DIR => $self->tmpdir );
+ my $suffix = $filename =~ /[^.]+(\..+)$/ ? $1 : q{};
+
+ my $fh = File::Temp->new( UNLINK => 0, DIR => $self->tmpdir, SUFFIX => $suffix );
$part->{fh} = $fh;
$part->{tempname} = $fh->filename;
--- /dev/null
+#!perl
+
+use strict;
+use warnings;
+
+use FindBin;
+use lib "$FindBin::Bin/lib";
+
+use Test::More tests => 4;
+use Test::Deep;
+
+use Cwd;
+use HTTP::Body;
+use File::Spec::Functions;
+use IO::File;
+use PAML;
+use File::Temp qw/ tempdir /;
+
+my $path = catdir( getcwd(), 't', 'data', 'multipart' );
+
+{
+ my $uploads = uploads_for('001');
+
+ like(
+ $uploads->{upload2}{tempname}, qr/\.pl$/,
+ 'tempname preserves .pl suffix'
+ );
+
+ unlike(
+ $uploads->{upload4}{tempname}, qr/\..+$/,
+ 'tempname for upload4 has no suffix'
+ );
+}
+
+{
+ my $uploads = uploads_for('006');
+
+ like(
+ $uploads->{upload2}{tempname}, qr/\.pl$/,
+ 'tempname preserves .pl suffix with Windows filename'
+ );
+}
+
+{
+ my $uploads = uploads_for('014');
+
+ like(
+ $uploads->{upload}{tempname}, qr/\.foo\.txt$/,
+ 'tempname preserves .foo.txt suffix'
+ );
+}
+
+sub uploads_for {
+ my $number = shift;
+
+ my $headers = PAML::LoadFile( catfile( $path, "$number-headers.pml" ) );
+ my $content = IO::File->new( catfile( $path, "$number-content.dat" ) );
+ my $body = HTTP::Body->new( $headers->{'Content-Type'}, $headers->{'Content-Length'} );
+ my $tempdir = tempdir( 'XXXXXXX', CLEANUP => 1, DIR => File::Spec->tmpdir() );
+ $body->tmpdir($tempdir);
+
+ binmode $content, ':raw';
+
+ while ( $content->read( my $buffer, 1024 ) ) {
+ $body->add($buffer);
+ }
+
+ $body->cleanup(1);
+
+ return $body->upload;
+}