]> Sergey Matveev's repositories - public-inbox.git/blobdiff - lib/PublicInbox/TestCommon.pm
replace most uses of PublicInbox::MIME with Eml
[public-inbox.git] / lib / PublicInbox / TestCommon.pm
index ac14d27bc87b9ba406edd22eb475f704a8dabc39..978c3cd7bafaf4a1cc82a7a78724296453f49cbd 100644 (file)
@@ -8,30 +8,23 @@ use parent qw(Exporter);
 use Fcntl qw(FD_CLOEXEC F_SETFD F_GETFD :seek);
 use POSIX qw(dup2);
 use IO::Socket::INET;
+use PublicInbox::MIME; # temporary
 our @EXPORT = qw(tmpdir tcp_server tcp_connect require_git require_mods
-       run_script start_script key2sub xsys xqx mime_load);
+       run_script start_script key2sub xsys xqx mime_load eml_load);
 
-sub mime_load ($;&) {
-       my ($path, $cb) = @_;
-       if (open(my $fh, '<', $path)) {
-               PublicInbox::MIME->new(\(do { local $/; <$fh> }));
-       } elsif ($cb) {
-               require File::Temp;
+sub mime_load ($) {
+       my ($path) = @_;
+       open(my $fh, '<', $path) or die "open $path: $!";
+       # test should've called: require_mods('Email::MIME')
+       require PublicInbox::MIME;
+       PublicInbox::MIME->new(\(do { local $/; <$fh> }));
+}
 
-               my $mime = $cb->();
-               my ($dir) = ($path =~ m!(.+)/(?:[^/]+)\z!);
-               -d $dir or die "BUG: dir=$dir is not the dir of $path";
-               my $fh = File::Temp->new(DIR => $dir);
-               $fh->autoflush(1);
-               print $fh $mime->as_string or die "print: $!";
-               my $fn = $fh->filename;
-               rename($fn, $path) or die "link $fn => $path: $!";
-               $fh->unlink_on_destroy(0);
-               pop @_; # retry via tail recursion
-               goto &mime_load;
-       } else {
-               die "open $path: $!";
-       }
+sub eml_load ($) {
+       my ($path, $cb) = @_;
+       open(my $fh, '<', $path) or die "open $path: $!";
+       binmode $fh;
+       PublicInbox::Eml->new(\(do { local $/; <$fh> }));
 }
 
 sub tmpdir (;$) {