#!perl
use strict;
use warnings;
use File::Basename;
use Test::More 0.88;
use lib 't';
use Util qw[tmpfile rewind slurp monkey_patch dir_list parse_case
hashify connect_args clear_socket_source set_socket_source sort_headers
$CRLF $LF];
use HTTP::Tiny;
BEGIN { monkey_patch() }
for my $file ( dir_list("corpus", qr/^auth/ ) ) {
my $label = basename($file);
my $data = do { local (@ARGV,$/) = $file; <> };
my ($params, @case_pairs) = split /--+\n/, $data;
my $case = parse_case($params);
my $url = $case->{url}[0];
my $method = $case->{method}[0] || 'GET';
my %headers = hashify( $case->{headers} );
my %new_args = hashify( $case->{new_args} );
my %options;
$options{headers} = \%headers if %headers;
my $call_args = %options ? [$method, $url, \%options] : [$method, $url];
my $version = HTTP::Tiny->VERSION || 0;
my $agent = $new_args{agent} || "HTTP-Tiny/$version";
my (@socket_pairs);
while ( @case_pairs ) {
my ($expect_req, $give_res) = splice( @case_pairs, 0, 2 );
# cleanup source data
$expect_req =~ s{HTTP-Tiny/VERSION}{$agent};
s{\n}{$CRLF}g for ($expect_req, $give_res);
# setup mocking and test
my $req_fh = tmpfile();
my $res_fh = tmpfile($give_res);
push @socket_pairs, [$req_fh, $res_fh, $expect_req];
}
clear_socket_source();
set_socket_source(@$_) for @socket_pairs;
my $http = HTTP::Tiny->new(keep_alive => 0, %new_args);
my $response = $http->request(@$call_args);
my $calls = 0
+ (defined($new_args{max_redirect}) ? $new_args{max_redirect} : 5);
for my $i ( 0 .. $calls ) {
last unless @socket_pairs;
my ($req_fh, $res_fh, $expect_req) = @{ shift @socket_pairs };
my $got_req = slurp($req_fh);
is( sort_headers($got_req), sort_headers($expect_req), "$label request ($i)");
$i++;
}
my $exp_content = $case->{expected}
? join("$CRLF", @{$case->{expected}}) : '';
is ( $response->{content}, $exp_content, "$label content" );
if ( $case->{expected_url} ) {
is ( $response->{url}, $case->{expected_url}[0], "$label response URL" );
}
}
done_testing;