""" Testing suite for https://github.com/bregman-arie/devops-interview-questions written by surister Even though both check_details_tag and check_summary_tags are practically the same, due to readability and functionality it was decided to be split like that. Usage: $ python tests/syntax_lint.py """ import pathlib p = pathlib.Path(__file__).parent.parent.joinpath('README.md') with open(p, 'rb') as f: file_list = [line.rstrip() for line in f.readlines()] errors = [] def count_details(file_list): """ Counts the total amount of <details> and </details> Used for debugging purpose, not meant to be used in actual tests """ details_final_count = 0 details_count = 0 for line_number, line in enumerate(file_list): if b'<details>' in line: details_count += 1 if b'</details>' in line: details_final_count += 1 return details_count == details_final_count def count_summary(file_list): """ Counts the total amount of <details> and </details> Used for debugging purpose, not meant to be used in actual tests """ details_final_count = 0 details_count = 0 for line_number, line in enumerate(file_list): if b'<summary>' in line: details_count += 1 if b'</summary>' in line: details_final_count += 1 return details_count == details_final_count def check_details_tag(file_list): """ Check whether the structure: <details> ... </details> Is correctly followed, if not generates an error. """ after_detail = False error = False err_message = '' for line_number, line in enumerate(file_list): if b'<details>' in line and b'</details>' in line: pass else: if b'<details>' in line and after_detail: err_message = f'Missing closing detail tag round line {line_number - 1}' error = True if b'</details>' in line and not after_detail: err_message = f'Missing opening detail tag round line {line_number - 1}' error = True if b'<details>' in line: after_detail = True if b'</details>' in line and after_detail: after_detail = False if error: errors.append(err_message) error = False def check_summary_tag(file_list): """ Check whether the structure: <summary> ... </summary> Is correctly followed, if not generates an error. """ after_summary = False error = False err_message = '' for line_number, line in enumerate(file_list): if b'<summary>' in line and b'</summary>' in line: pass else: if b'<summary>' in line and after_summary: err_message = f'Missing closing summary tag around line {line_number}' error = True if b'</summary>' in line and not after_summary: err_message = f'Missing opening summary tag around line {line_number}' error = True if b'<summary>' in line: after_summary = True if b'</summary>' in line and after_summary: after_summary = False if error: errors.append(err_message) error = False if __name__ == '__main__': check_details_tag(file_list) check_summary_tag(file_list) if errors: for error in errors: print(error) exit(1) print("Tests passed successfully.")