From 88ca242c88688fa4e46cf8f1108915a1c821ae9b Mon Sep 17 00:00:00 2001 From: Daniel Lenski Date: Mon, 25 Mar 2024 07:01:21 -0700 Subject: [PATCH] Handle raw_bits==None correctly in repr() MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This should fix #36. Also adds tests to verify that `BarCode.parse()` results in a working `__repr__`, whether or not the "Raw bits:" section appears in the ZXing CLR output. However, I can't actually reproduce this condition using the "normal" entry point of `BarCodeReader.decode()` → `BarCode.parse()` on the latest version. --- test/test_all.py | 17 +++++++++++------ zxing/__init__.py | 2 +- 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/test/test_all.py b/test/test_all.py index 60497b8..ab1005f 100644 --- a/test/test_all.py +++ b/test/test_all.py @@ -6,6 +6,7 @@ from nose2.tools.decorators import with_setup from nose2.tools.such import helper +from nose2.tools import params import unittest import zxing @@ -98,30 +99,34 @@ def test_decoding_multiple(): '{}: Expected {!r} but got {!r}'.format(filename, expected_format, dec.format)) -def test_parsing(): - dec = zxing.BarCode.parse(""" +@params(False, True) +def test_parsing(with_raw_bits): + stdout = (""" file:///tmp/default%20file.png (format: FAKE_DATA, type: TEXT): Raw result: Élan|\tthe barcode is taking off Parsed result: Élan -\tthe barcode is taking off +\tthe barcode is taking off""") + (""" Raw bits: - f00f00cafe + f00f00cafe""" if with_raw_bits else "") + (""" Found 4 result points: Point 0: (24.0,18.0) Point 1: (21.0,196.0) Point 2: (201.0,198.0) Point 3: (205.23952,21.0) -""".encode()) +""") + dec = zxing.BarCode.parse(stdout.encode()) assert dec.uri == 'file:///tmp/default%20file.png' assert dec.path == '/tmp/default file.png' assert dec.format == 'FAKE_DATA' assert dec.type == 'TEXT' assert dec.raw == 'Élan|\tthe barcode is taking off' - assert dec.raw_bits == bytes.fromhex('f00f00cafe') + assert dec.raw_bits == (bytes.fromhex('f00f00cafe') if with_raw_bits else b'') assert dec.parsed == 'Élan\n\tthe barcode is taking off' assert dec.points == [(24.0, 18.0), (21.0, 196.0), (201.0, 198.0), (205.23952, 21.0)] + r = repr(dec) + assert r.startswith('BarCode(') and r.endswith(')') def test_wrong_formats(): diff --git a/zxing/__init__.py b/zxing/__init__.py index 49675a4..27421a4 100644 --- a/zxing/__init__.py +++ b/zxing/__init__.py @@ -233,6 +233,6 @@ def path(self): def __repr__(self): return '{}(raw={!r}, parsed={!r}, raw_bits={!r}, {}={!r}, format={!r}, type={!r}, points={!r})'.format( - self.__class__.__name__, self.raw, self.parsed, self.raw_bits.hex(), + self.__class__.__name__, self.raw, self.parsed, self.raw_bits.hex() if self.raw_bits else None, 'path' if self.path else 'uri', self.path or self.uri, self.format, self.type, self.points)