Fix: Crash in barcode ASN reading when the file type isn't supported (#5261)

* Fixes a random crash in the barcode ASN reading so it doesn't try to access a not created temp dir

* Don't parse the barcodes twice, store the result instead
This commit is contained in:
Trenton H 2024-01-05 21:08:24 -08:00 committed by GitHub
parent a82e3771ae
commit bd35030c59
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 9 additions and 3 deletions

View File

@ -90,6 +90,9 @@ class BarcodeReader:
"""
asn = None
if not self.supported_mime_type:
return None
# Ensure the barcodes have been read
self.detect()
@ -215,7 +218,7 @@ class BarcodeReader:
# This file is really borked, allow the consumption to continue
# but it may fail further on
except Exception as e: # pragma: no cover
logger.warning(
logger.exception(
f"Exception during barcode scanning: {e}",
)

View File

@ -152,10 +152,13 @@ def consume_file(
return "File successfully split"
# try reading the ASN from barcode
if settings.CONSUMER_ENABLE_ASN_BARCODE and reader.asn is not None:
if (
settings.CONSUMER_ENABLE_ASN_BARCODE
and (located_asn := reader.asn) is not None
):
# Note this will take precedence over an API provided ASN
# But it's from a physical barcode, so that's good
overrides.asn = reader.asn
overrides.asn = located_asn
logger.info(f"Found ASN in barcode: {overrides.asn}")
template_overrides = Consumer().get_workflow_overrides(