Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
c1b2cb9d
Commit
c1b2cb9d
authored
May 05, 2003
by
Jeremy Hylton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
SF bug 622042: Don't expect response body from HEAD request.
Bug fix candidate.
parent
581c3677
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
25 additions
and
4 deletions
+25
-4
Lib/httplib.py
Lib/httplib.py
+11
-4
Lib/test/test_httplib.py
Lib/test/test_httplib.py
+13
-0
Misc/ACKS
Misc/ACKS
+1
-0
No files found.
Lib/httplib.py
View file @
c1b2cb9d
...
...
@@ -208,10 +208,11 @@ class HTTPResponse:
# See RFC 2616 sec 19.6 and RFC 1945 sec 6 for details.
def
__init__
(
self
,
sock
,
debuglevel
=
0
,
strict
=
0
):
def
__init__
(
self
,
sock
,
debuglevel
=
0
,
strict
=
0
,
method
=
None
):
self
.
fp
=
sock
.
makefile
(
'rb'
,
0
)
self
.
debuglevel
=
debuglevel
self
.
strict
=
strict
self
.
_method
=
method
self
.
msg
=
None
...
...
@@ -326,7 +327,8 @@ class HTTPResponse:
# does the body have a fixed length? (of zero)
if
(
status
==
204
or
# No Content
status
==
304
or
# Not Modified
100
<=
status
<
200
):
# 1xx codes
100
<=
status
<
200
or
# 1xx codes
self
.
_method
==
'HEAD'
):
self
.
length
=
0
# if the connection remains open, and we aren't using chunked, and
...
...
@@ -497,6 +499,7 @@ class HTTPConnection:
self
.
_buffer
=
[]
self
.
__response
=
None
self
.
__state
=
_CS_IDLE
self
.
_method
=
None
self
.
_set_hostport
(
host
,
port
)
if
strict
is
not
None
:
...
...
@@ -626,6 +629,8 @@ class HTTPConnection:
else
:
raise
CannotSendRequest
()
# Save the method we use, we need it later in the response phase
self
.
_method
=
method
if
not
url
:
url
=
'/'
str
=
'%s %s %s'
%
(
method
,
url
,
self
.
_http_vsn_str
)
...
...
@@ -763,9 +768,11 @@ class HTTPConnection:
if
self
.
debuglevel
>
0
:
response
=
self
.
response_class
(
self
.
sock
,
self
.
debuglevel
,
strict
=
self
.
strict
)
strict
=
self
.
strict
,
method
=
self
.
_method
)
else
:
response
=
self
.
response_class
(
self
.
sock
,
strict
=
self
.
strict
)
response
=
self
.
response_class
(
self
.
sock
,
strict
=
self
.
strict
,
method
=
self
.
_method
)
response
.
begin
()
assert
response
.
will_close
!=
_UNKNOWN
...
...
Lib/test/test_httplib.py
View file @
c1b2cb9d
...
...
@@ -78,4 +78,17 @@ def _test():
if
cookies
!=
hdr
:
raise
AssertionError
,
"multiple headers not combined properly"
# test that the library doesn't attempt to read any data
# from a head request
conn
=
httplib
.
HTTPConnection
(
"www.python.org"
)
conn
.
connect
()
conn
.
request
(
"HEAD"
,
"/"
,
headers
=
{
"Connection"
:
"keep-alive"
})
resp
=
conn
.
getresponse
()
if
resp
.
status
!=
200
:
raise
AssertionError
,
"Expected status 200, got %d"
%
resp
.
status
if
resp
.
read
()
!=
""
:
raise
AssertionError
,
"Did not expect response from HEAD request"
resp
.
close
()
conn
.
close
()
test
()
Misc/ACKS
View file @
c1b2cb9d
...
...
@@ -261,6 +261,7 @@ Michael Hudson
Jim Hugunin
Greg Humphreys
Jeremy Hylton
Mihai Ibanescu
Juan David Ibez Palomar
Tony Ingraldi
John Interrante
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment