mirror of
https://github.com/jtesta/ssh-audit.git
synced 2025-01-26 01:49:31 +01:00
Use safer UTF-8 decoding (with replace) and add related tests.
This commit is contained in:
parent
66bd6c3ef0
commit
4bbb1f4d11
@ -40,12 +40,12 @@ else:
|
||||
try:
|
||||
# pylint: disable=unused-import
|
||||
from typing import List, Tuple, Optional, Callable, Union, Any
|
||||
except ImportError:
|
||||
except ImportError: # pragma: nocover
|
||||
pass
|
||||
try:
|
||||
from colorama import init as colorama_init
|
||||
colorama_init()
|
||||
except ImportError:
|
||||
except ImportError: # pragma: nocover
|
||||
pass
|
||||
|
||||
|
||||
@ -572,7 +572,7 @@ class ReadBuf(object):
|
||||
def read_list(self):
|
||||
# type: () -> List[text_type]
|
||||
list_size = self.read_int()
|
||||
return self.read(list_size).decode().split(',')
|
||||
return self.read(list_size).decode('utf-8', 'replace').split(',')
|
||||
|
||||
def read_string(self):
|
||||
# type: () -> binary_type
|
||||
@ -607,7 +607,7 @@ class ReadBuf(object):
|
||||
|
||||
def read_line(self):
|
||||
# type: () -> text_type
|
||||
return self._buf.readline().rstrip().decode('utf-8')
|
||||
return self._buf.readline().rstrip().decode('utf-8', 'replace')
|
||||
|
||||
|
||||
class WriteBuf(object):
|
||||
|
@ -9,6 +9,7 @@ class TestBuffer(object):
|
||||
def init(self, ssh_audit):
|
||||
self.rbuf = ssh_audit.ReadBuf
|
||||
self.wbuf = ssh_audit.WriteBuf
|
||||
self.utf8rchar = b'\xef\xbf\xbd'
|
||||
|
||||
def _b(self, v):
|
||||
v = re.sub(r'\s', '', v)
|
||||
@ -75,6 +76,12 @@ class TestBuffer(object):
|
||||
assert w(p[0]) == self._b(p[1])
|
||||
assert r(self._b(p[1])) == p[0]
|
||||
|
||||
def test_list_nonutf8(self):
|
||||
r = lambda x: self.rbuf(x).read_list()
|
||||
src = self._b('00 00 00 04 de ad be ef')
|
||||
dst = [(b'\xde\xad' + self.utf8rchar + self.utf8rchar).decode('utf-8')]
|
||||
assert r(src) == dst
|
||||
|
||||
def test_line(self):
|
||||
w = lambda x: self.wbuf().write_line(x).write_flush()
|
||||
r = lambda x: self.rbuf(x).read_line()
|
||||
@ -83,6 +90,12 @@ class TestBuffer(object):
|
||||
assert w(p[0]) == self._b(p[1])
|
||||
assert r(self._b(p[1])) == p[0]
|
||||
|
||||
def test_line_nonutf8(self):
|
||||
r = lambda x: self.rbuf(x).read_line()
|
||||
src = self._b('de ad be af')
|
||||
dst = (b'\xde\xad' + self.utf8rchar + self.utf8rchar).decode('utf-8')
|
||||
assert r(src) == dst
|
||||
|
||||
def test_bitlen(self):
|
||||
class Py26Int(int):
|
||||
def bit_length(self):
|
||||
|
Loading…
Reference in New Issue
Block a user