-
Notifications
You must be signed in to change notification settings - Fork 81
/
Copy pathhttp_expect_100_continue.t
107 lines (75 loc) · 2.68 KB
/
http_expect_100_continue.t
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#!/usr/bin/perl
# (C) Maxim Dounin
# Tests for Expect: 100-continue support.
###############################################################################
use warnings;
use strict;
use Test::More;
BEGIN { use FindBin; chdir($FindBin::Bin); }
use lib 'lib';
use Test::Nginx;
###############################################################################
select STDERR; $| = 1;
select STDOUT; $| = 1;
my $t = Test::Nginx->new()->has(qw/http proxy/)->plan(5);
$t->write_file_expand('nginx.conf', <<'EOF');
%%TEST_GLOBALS%%
daemon off;
events {
}
http {
%%TEST_GLOBALS_HTTP%%
server {
listen 127.0.0.1:8080;
server_name localhost;
location / {
proxy_pass http://127.0.0.1:8080/local;
}
location /local {
}
}
}
EOF
$t->run();
###############################################################################
like(http_100_request('/', '1.1'), qr/ 100 /, 'expect 100 continue');
# Comparison of expectation values is case-insensitive for unquoted tokens.
like(http_100_request('/', '1.1', '100-Continue'), qr/ 100 /,
'expect 100 continue case-insensitive');
# From RFC 2616, 8.2.3 Use of the 100 (Continue) Status:
#
# - An origin server SHOULD NOT send a 100 (Continue) response if
# the request message does not include an Expect request-header
# field with the "100-continue" expectation, and MUST NOT send a
# 100 (Continue) response if such a request comes from an HTTP/1.0
# (or earlier) client.
unlike(http_100_request('/', '1.0'), qr/ 100 /, 'no 100 continue via http 1.0');
# From RFC 2616, 14.20 Expect:
#
# A server that does not understand or is unable to comply with any of
# the expectation values in the Expect field of a request MUST respond
# with appropriate error status. The server MUST respond with a 417
# (Expectation Failed) status if any of the expectations cannot be met.
#
# <..> If a server receives a request containing an
# Expect field that includes an expectation-extension that it does not
# support, it MUST respond with a 417 (Expectation Failed) status.
TODO: {
local $TODO = 'not yet';
like(http_100_request('/', '1.1', 'unknown'), qr/ 417 /, 'unknown expectation');
like(http_100_request('/', '1.1', 'token=param'), qr/ 417 /,
'unsupported expectation extension');
}
###############################################################################
sub http_100_request {
my ($url, $version, $value) = @_;
$value = '100-continue' unless defined $value;
http(<<EOF);
POST $url HTTP/$version
Host: localhost
Expect: $value
Content-Length: 0
Connection: close
EOF
}
###############################################################################