Commit babc6881 authored by Berker Peksag's avatar Berker Peksag

Issue #23439: Add missing entries to http.client.__all__.

Also, document the LineTooLong exception since it can be raised by
the members of public API (e.g. http.client.HTTPResponse).

Patch by Martin Panter.
parent 56dee1e4
...@@ -169,6 +169,12 @@ The following exceptions are raised as appropriate: ...@@ -169,6 +169,12 @@ The following exceptions are raised as appropriate:
status code that we don't understand. status code that we don't understand.
.. exception:: LineTooLong
A subclass of :exc:`HTTPException`. Raised if an excessively long line
is received in the HTTP protocol from the server.
The constants defined in this module are: The constants defined in this module are:
.. data:: HTTP_PORT .. data:: HTTP_PORT
......
...@@ -74,12 +74,14 @@ import socket ...@@ -74,12 +74,14 @@ import socket
import collections import collections
from urllib.parse import urlsplit from urllib.parse import urlsplit
# HTTPMessage, parse_headers(), and the HTTP status code constants are
# intentionally omitted for simplicity
__all__ = ["HTTPResponse", "HTTPConnection", __all__ = ["HTTPResponse", "HTTPConnection",
"HTTPException", "NotConnected", "UnknownProtocol", "HTTPException", "NotConnected", "UnknownProtocol",
"UnknownTransferEncoding", "UnimplementedFileMode", "UnknownTransferEncoding", "UnimplementedFileMode",
"IncompleteRead", "InvalidURL", "ImproperConnectionState", "IncompleteRead", "InvalidURL", "ImproperConnectionState",
"CannotSendRequest", "CannotSendHeader", "ResponseNotReady", "CannotSendRequest", "CannotSendHeader", "ResponseNotReady",
"BadStatusLine", "error", "responses"] "BadStatusLine", "LineTooLong", "error", "responses"]
HTTP_PORT = 80 HTTP_PORT = 80
HTTPS_PORT = 443 HTTPS_PORT = 443
......
...@@ -708,7 +708,22 @@ class BasicTest(TestCase): ...@@ -708,7 +708,22 @@ class BasicTest(TestCase):
self.assertTrue(response.closed) self.assertTrue(response.closed)
self.assertTrue(conn.sock.file_closed) self.assertTrue(conn.sock.file_closed)
class OfflineTest(TestCase): class OfflineTest(TestCase):
def test_all(self):
# Documented objects defined in the module should be in __all__
expected = {"responses"} # White-list documented dict() object
# HTTPMessage, parse_headers(), and the HTTP status code constants are
# intentionally omitted for simplicity
blacklist = {"HTTPMessage", "parse_headers"}
for name in dir(client):
if name in blacklist:
continue
module_object = getattr(client, name)
if getattr(module_object, "__module__", None) == "http.client":
expected.add(name)
self.assertCountEqual(client.__all__, expected)
def test_responses(self): def test_responses(self):
self.assertEqual(client.responses[client.NOT_FOUND], "Not Found") self.assertEqual(client.responses[client.NOT_FOUND], "Not Found")
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment