xref: /openbsd/gnu/usr.bin/perl/cpan/HTTP-Tiny/t/100_get.t (revision eac174f2)
1#!perl
2
3use strict;
4use warnings;
5
6use File::Basename;
7use Test::More 0.88;
8use lib 't';
9use Util qw[tmpfile rewind slurp monkey_patch dir_list parse_case
10  hashify connect_args clear_socket_source set_socket_source sort_headers
11  $CRLF $LF];
12
13use HTTP::Tiny;
14BEGIN { monkey_patch() }
15
16for my $file ( dir_list("corpus", qr/^get/ ) ) {
17  my $label = basename($file);
18  my $data = do { local (@ARGV,$/) = $file; <> };
19  my ($params, $expect_req, $give_res) = split /--+\n/, $data;
20  my $case = parse_case($params);
21
22  my $url = $case->{url}[0];
23  my %headers = hashify( $case->{headers} );
24  my %new_args = hashify( $case->{new_args} );
25
26  my %options;
27  $options{headers} = \%headers if %headers;
28  if ( $case->{data_cb} ) {
29    $main::data = '';
30    $options{data_callback} = eval join "\n", @{$case->{data_cb}};
31    die unless ref( $options{data_callback} ) eq 'CODE';
32  }
33
34  my $version = HTTP::Tiny->VERSION || 0;
35  my $agent = $new_args{agent} || "HTTP-Tiny/$version";
36
37  # cleanup source data
38  $expect_req =~ s{HTTP-Tiny/VERSION}{$agent};
39  s{\n}{$CRLF}g for ($expect_req, $give_res);
40
41  # setup mocking and test
42  my $res_fh = tmpfile($give_res);
43  my $req_fh = tmpfile();
44
45  my $http = HTTP::Tiny->new(keep_alive => 0, %new_args);
46  clear_socket_source();
47  set_socket_source($req_fh, $res_fh);
48
49  (my $url_basename = $url) =~ s{.*/}{};
50
51  my @call_args = %options ? ($url, \%options) : ($url);
52  my $response  = $http->get(@call_args);
53
54  my ($got_host, $got_port) = connect_args();
55  my ($exp_host, $exp_port) = (
56    ($new_args{proxy} || $url ) =~ m{^http://([^:/]+?):?(\d*)/}g
57  );
58  $exp_host ||= 'localhost';
59  $exp_port ||= 80;
60
61  my $got_req = slurp($req_fh);
62
63  is ($got_host, $exp_host, "$label host $exp_host");
64  is ($got_port, $exp_port, "$label port $exp_port");
65  is( sort_headers($got_req), sort_headers($expect_req), "$label request data");
66
67  my ($rc) = $give_res =~ m{\S+\s+(\d+)}g;
68  # maybe override
69  $rc = $case->{expected_rc}[0] if defined $case->{expected_rc};
70
71  is( $response->{status}, $rc, "$label response code $rc" )
72    or diag $response->{content};
73
74  if ( substr($rc,0,1) eq '2' ) {
75    ok( $response->{success}, "$label success flag true" );
76  }
77  else {
78    ok( ! $response->{success}, "$label success flag false" );
79  }
80
81  is ( $response->{url}, $url, "$label response URL" );
82
83  if (defined $case->{expected_headers}) {
84    my %expected = hashify( $case->{expected_headers} );
85    is_deeply($response->{headers}, \%expected, "$label expected headers");
86  }
87
88  my $check_expected = $case->{expected_like}
89    ?  sub {
90        my ($text, $msg) = @_;
91        like( $text, "/".$case->{expected_like}[0]."/", $msg );
92      }
93    : sub {
94        my ($text, $msg) = @_;
95        my $exp_content =
96          $case->{expected} ? join("$CRLF", @{$case->{expected}}, '') : '';
97        is ( $text, $exp_content, $msg );
98      }
99    ;
100
101
102
103  if ( $options{data_callback} ) {
104    $check_expected->( $main::data, "$label cb got content" );
105    is ( $response->{content}, '', "$label resp content empty" );
106  }
107  else {
108    $check_expected->( $response->{content}, "$label content" );
109  }
110
111  ok ( ! exists $response->{redirects}, "$label redirects array doesn't exist")
112    or diag explain $response->{redirects};
113}
114
115done_testing;
116