Source code for opera.util.error_codes

#!/usr/bin/env python3

"""
==============
error_codes.py
==============

Error codes for use with OPERA PGEs.
"""

from enum import IntEnum, auto, unique

CODES_PER_RANGE = 1000
"""Number of error codes allocated to each range"""

ERROR_CODE_PGE_OFFSET = 10000
"""Base offset used to distinguish error codes by PGE type"""

INFO_RANGE_START = 0
"""Starting value for the Info code range"""

DEBUG_RANGE_START = INFO_RANGE_START + CODES_PER_RANGE
"""Starting value for the Debug code range"""

WARNING_RANGE_START = DEBUG_RANGE_START + CODES_PER_RANGE
"""Starting value for the Warning code range"""

CRITICAL_RANGE_START = WARNING_RANGE_START + CODES_PER_RANGE
"""Starting value for the Critical code range"""


# noinspection PyArgumentList
[docs]@unique class ErrorCode(IntEnum): """ Error codes for OPERA PGEs. Each code is combined with the designated error code offset defined by the RunConfig to determine the final, logged error code. """ # Info - 0 to 999 OVERALL_SUCCESS = INFO_RANGE_START LOG_FILE_CREATED = auto() LOADING_RUN_CONFIG_FILE = auto() VALIDATING_RUN_CONFIG_FILE = auto() LOG_FILE_INIT_COMPLETE = auto() CREATING_WORKING_DIRECTORY = auto() DIRECTORY_SETUP_COMPLETE = auto() MOVING_LOG_FILE = auto() MOVING_OUTPUT_FILE = auto() SUMMARY_STATS_MESSAGE = auto() RUN_CONFIG_FILENAME = auto() PGE_NAME = auto() SCHEMA_FILE = auto() INPUT_FILE = auto() PROCESSING_INPUT_FILE = auto() USING_CONFIG_FILE = auto() CREATED_SAS_CONFIG = auto() CREATING_OUTPUT_FILE = auto() CREATING_CATALOG_METADATA = auto() CREATING_ISO_METADATA = auto() SAS_PROGRAM_STARTING = auto() SAS_PROGRAM_COMPLETED = auto() QA_SAS_PROGRAM_STARTING = auto() QA_SAS_PROGRAM_COMPLETED = auto() QA_SAS_PROGRAM_DISABLED = auto() RENDERING_ISO_METADATA = auto() CLOSING_LOG_FILE = auto() LOGGED_INFO_LINE = auto() UPDATING_PRODUCT_METADATA = auto() NO_ALGO_PARAM_SCHEMA_PATH = auto() # Debug - 1000 – 1999 CONFIGURATION_DETAILS = DEBUG_RANGE_START PROCESSING_DETAILS = auto() SAS_EXE_COMMAND_LINE = auto() SAS_QA_COMMAND_LINE = auto() LOGGED_DEBUG_LINE = auto() # Warning - 2000 – 2999 DATE_RANGE_MISSING = WARNING_RANGE_START NO_RENAME_FUNCTION_FOR_EXTENSION = auto() ISO_METADATA_CANT_RENDER_ONE_VARIABLE = auto() LOGGING_REQUESTED_SEVERITY_NOT_FOUND = auto() LOGGING_SOURCE_FILE_DOES_NOT_EXIST = auto() LOGGING_COULD_NOT_INCREMENT_SEVERITY = auto() LOGGING_RESYNC_FAILED = auto() LOGGED_WARNING_LINE = auto() ISO_METADATA_NO_DESCRIPTIONS = auto() # Critical - 3000 to 3999 RUN_CONFIG_VALIDATION_FAILED = CRITICAL_RANGE_START DIRECTORY_CREATION_FAILED = auto() SAS_CONFIG_CREATION_FAILED = auto() CATALOG_METADATA_CREATION_FAILED = auto() LOG_FILE_CREATION_FAILED = auto() INPUT_NOT_FOUND = auto() OUTPUT_NOT_FOUND = auto() INVALID_INPUT = auto() INVALID_OUTPUT = auto() INVALID_CATALOG_METADATA = auto() FILE_MOVE_FAILED = auto() FILENAME_VIOLATES_NAMING_CONVENTION = auto() SAS_PROGRAM_NOT_FOUND = auto() SAS_PROGRAM_FAILED = auto() QA_SAS_PROGRAM_NOT_FOUND = auto() QA_SAS_PROGRAM_FAILED = auto() ISO_METADATA_TEMPLATE_NOT_FOUND = auto() ISO_METADATA_GOT_SOME_RENDERING_ERRORS = auto() ISO_METADATA_COULD_NOT_EXTRACT_METADATA = auto() ISO_METADATA_RENDER_FAILED = auto() SAS_OUTPUT_FILE_HAS_MISSING_DATA = auto() LOGGED_CRITICAL_LINE = auto() DYNAMIC_IMPORT_FAILED = auto() GRIB_TO_NETCDF_CONVERSION_FAILED = auto() ISO_METADATA_TEMPLATE_NOT_PROVIDED_WHEN_NEEDED = auto() ISO_METADATA_DESCRIPTIONS_CONFIG_INVALID = auto() ISO_METADATA_DESCRIPTIONS_CONFIG_NOT_FOUND = auto() ISO_METADATA_NO_ENTRY_FOR_DESCRIPTION = auto()
[docs] @classmethod def describe(cls): """ Provides a listing of the available error codes and their associated integer values. """ for name, member in cls.__members__.items(): print(f'{name}: {member.value}')