satisfying the linter

This commit is contained in:
Ilja Orlovs 2021-10-13 11:22:06 +01:00
parent 764ecb0e48
commit fab65e5208
2 changed files with 11 additions and 9 deletions

View file

@ -179,24 +179,25 @@ class BaseFormatter:
# one
return f"{error.physical_line}{indent}^"
def _stdoutWriteHook(self, value: str) -> None:
"""An alternative to print() function that handles output terminal encoding."""
def _stdout_write_hook(self, value: str) -> None:
"""sys.stdout.write() with fallbacks."""
try:
sys.stdout.write(value)
except UnicodeEncodeError:
byteValue = value.encode(sys.stdout.encoding, 'backslashreplace')
byte_value = value.encode(sys.stdout.encoding, 'backslashreplace')
if hasattr(sys.stdout, 'buffer'):
sys.stdout.buffer.write(byteValue)
sys.stdout.buffer.write(byte_value)
else:
sys.stdout.write(byteValue.decode(sys.stdout.encoding, 'strict'))
sys.stdout.write(
byte_value.decode(sys.stdout.encoding, 'strict'))
def _write(self, output: str) -> None:
"""Handle logic of whether to use an output file or print()."""
if self.output_fd is not None:
self.output_fd.write(output + self.newline)
if self.output_fd is None or self.options.tee:
self._stdoutWriteHook(output)
self._stdoutWriteHook(self.newline)
self._stdout_write_hook(output)
self._stdout_write_hook(self.newline)
def write(self, line: Optional[str], source: Optional[str]) -> None:
"""Write the line either to the output file or stdout.

View file

@ -138,6 +138,7 @@ def test_write_produces_stdout(capsys):
@pytest.mark.parametrize('buffered_stdout', [True, False])
def test_write_hook_fallbacks(buffered_stdout):
"""Varify stdout.write() fallbacks."""
mock_line = mock.Mock(name='Mock Line')
stdout_spec = ['write', 'encoding']
@ -145,11 +146,11 @@ def test_write_hook_fallbacks(buffered_stdout):
stdout_spec.append('buffer')
with mock.patch('sys.stdout', spec=stdout_spec) as mock_stdout:
def _stdoutWriteEffect(value):
def _stdout_write_effect(value):
if value is mock_line:
raise UnicodeEncodeError('unittest-codec', u'', 42, 43, 'NOPE')
return None
mock_stdout.write.side_effect = _stdoutWriteEffect
mock_stdout.write.side_effect = _stdout_write_effect
mock_stdout.encoding = 'ascii'