Coverage for id_contexts/sa_id_card.py : 40%

Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
""" ---------------------------------------------------------------------- Authors: Jan-Justin van Tonder ---------------------------------------------------------------------- This file contains the logic for South African ID card context. ---------------------------------------------------------------------- """
from id_contexts.id_context import FieldType, LineType from id_contexts.sa_id import SAID from hutts_utils.hutts_logger import logger
class SAIDCard(SAID): """ A class that represents an ID context for a South African ID card. It supplies some of the concrete information, such as the match contexts, to the classes higher up in inheritance hierarchy and implements abstract methods defined by its parent. """ def __init__(self): """ Initialises the SAIDCard object. """ # Logging for debugging purposes. # Specify initial list of contexts for string image_processing when populating # the ID information dictionary to send as output. 'field': 'identity_number', 'find': 'identity number', 'field_type': FieldType.NUMERIC_ONLY, 'line_type': LineType.TITLED_NEWLINE, 'multi_line': False }, { 'field': 'surname', 'find': 'surname', 'field_type': FieldType.TEXT_ONLY, 'to_uppercase': False, 'line_type': LineType.TITLED_NEWLINE, 'multi_line': True, 'multi_line_end': 'names', }, { 'field': 'names', 'find': 'names', 'field_type': FieldType.TEXT_ONLY, 'to_uppercase': False, 'line_type': LineType.TITLED_NEWLINE, 'multi_line': True, 'multi_line_end': 'sex', }, { 'field': 'sex', 'find': 'sex', 'field_type': FieldType.TEXT_ONLY, 'to_uppercase': True, 'line_type': LineType.TITLED_NEWLINE, 'multi_line': False }, { 'field': 'date_of_birth', 'find': 'date of birth', 'field_type': FieldType.MIXED, 'to_uppercase': False, 'line_type': LineType.TITLED_NEWLINE, 'multi_line': False }, { 'field': 'country_of_birth', 'find': 'country of birth', 'field_type': FieldType.TEXT_ONLY, 'to_uppercase': True, 'line_type': LineType.TITLED_NEWLINE, 'multi_line': False }, { 'field': 'status', 'find': 'status', 'field_type': FieldType.TEXT_ONLY, 'to_uppercase': False, 'line_type': LineType.TITLED_NEWLINE, 'multi_line': False }, { 'field': 'nationality', 'find': 'nationality', 'field_type': FieldType.TEXT_ONLY, 'to_uppercase': True, 'line_type': LineType.TITLED_NEWLINE, 'multi_line': False }] # Initialise parent.
def _get_idiosyncratic_match(self, match_context, id_string_list, current_index): """ Identifies and returns matches that are specific to the current ID context.
Authors: Jan-Justin van Tonder
Args: match_context (dict): A dictionary object that provides context for the information that is to be extracted. id_string_list (list): An ID string that has been broken down into a list of individual lines. current_index (int): The current index within the ID string list.
Returns: (str): A string containing the match value of a context-specific case. (None): Used to indicate that no special case was identified. """ # No special cases to consider. |