diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2011-05-07 17:45:34 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2011-05-07 17:45:34 (GMT) |
commit | 4d1cd0a0a03838422805c93f680d3232673ccd00 (patch) | |
tree | f0b4e007d6126c53ef3b3e9ec3949bf6632b18e5 /Lib | |
parent | c1d520634a25fac5dea41f3af70273fc0b3a11ae (diff) | |
parent | fde86ff67381c40b81286dabc7641cbb44edc730 (diff) | |
download | cpython-4d1cd0a0a03838422805c93f680d3232673ccd00.zip cpython-4d1cd0a0a03838422805c93f680d3232673ccd00.tar.gz cpython-4d1cd0a0a03838422805c93f680d3232673ccd00.tar.bz2 |
Merge
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/ftplib.py | 3 | ||||
-rw-r--r-- | Lib/test/test_ftplib.py | 8 |
2 files changed, 10 insertions, 1 deletions
diff --git a/Lib/ftplib.py b/Lib/ftplib.py index ea91c17..af213f3 100644 --- a/Lib/ftplib.py +++ b/Lib/ftplib.py @@ -232,12 +232,13 @@ class FTP: This does not follow the procedure from the RFC to send Telnet IP and Synch; that doesn't seem to work with the servers I've tried. Instead, just send the ABOR command as OOB data.''' - line = 'ABOR' + CRLF + line = b'ABOR' + B_CRLF if self.debugging > 1: print('*put urgent*', self.sanitize(line)) self.sock.sendall(line, MSG_OOB) resp = self.getmultiline() if resp[:3] not in ('426', '225', '226'): raise error_proto(resp) + return resp def sendcmd(self, cmd): '''Send a command and return the response.''' diff --git a/Lib/test/test_ftplib.py b/Lib/test/test_ftplib.py index fa1079f..2b2c4cf 100644 --- a/Lib/test/test_ftplib.py +++ b/Lib/test/test_ftplib.py @@ -42,6 +42,8 @@ class DummyFTPHandler(asynchat.async_chat): def __init__(self, conn): asynchat.async_chat.__init__(self, conn) + # tells the socket to handle urgent data inline (ABOR command) + self.socket.setsockopt(socket.SOL_SOCKET, socket.SO_OOBINLINE, 1) self.set_terminator(b"\r\n") self.in_buffer = [] self.dtp = None @@ -158,6 +160,9 @@ class DummyFTPHandler(asynchat.async_chat): self.push('221 quit ok') self.close() + def cmd_abor(self, arg): + self.push('226 abor ok') + def cmd_stor(self, arg): self.push('125 stor ok') @@ -312,6 +317,9 @@ class TestFTPClass(TestCase): # Ensure the connection gets closed; sock attribute should be None self.assertEqual(self.client.sock, None) + def test_abort(self): + self.client.abort() + def test_retrbinary(self): def callback(data): received.append(data.decode('ascii')) |