From 646d05c25989e9f91daade966b520e1b12867a9b Mon Sep 17 00:00:00 2001 From: Tom Cook Date: Wed, 17 Nov 2021 13:08:25 +0000 Subject: [PATCH 1/2] Add some logging for failed parsing of docstrings. --- flask_swagger.py | 45 +++++++++++++++++++++++++-------------------- 1 file changed, 25 insertions(+), 20 deletions(-) diff --git a/flask_swagger.py b/flask_swagger.py index d594fdb..c6b73b8 100644 --- a/flask_swagger.py +++ b/flask_swagger.py @@ -8,12 +8,14 @@ - Added basic_path parameter """ import inspect +import logging import yaml import re import os from collections import defaultdict +logger = logging.getLogger(__name__) def _sanitize(comment): return comment.replace('\n', '
') if comment else comment @@ -47,27 +49,30 @@ def _doc_from_file(path): def _parse_docstring(obj, process_doc, from_file_keyword, base_path): - first_line, other_lines, swag = None, None, None - full_doc = inspect.getdoc(obj) - if full_doc: - if from_file_keyword is not None: - from_file = _find_from_file(full_doc, from_file_keyword, base_path) - if from_file: - full_doc_from_file = _doc_from_file(from_file) - if full_doc_from_file: - full_doc = full_doc_from_file - line_feed = full_doc.find('\n') - if line_feed != -1: - first_line = process_doc(full_doc[:line_feed]) - yaml_sep = full_doc[line_feed+1:].find('---') - if yaml_sep != -1: - other_lines = process_doc(full_doc[line_feed+1:line_feed+yaml_sep]) - swag = yaml.full_load(full_doc[line_feed+yaml_sep:]) + try: + first_line, other_lines, swag = None, None, None + full_doc = inspect.getdoc(obj) + if full_doc: + if from_file_keyword is not None: + from_file = _find_from_file(full_doc, from_file_keyword, base_path) + if from_file: + full_doc_from_file = _doc_from_file(from_file) + if full_doc_from_file: + full_doc = full_doc_from_file + line_feed = full_doc.find('\n') + if line_feed != -1: + first_line = process_doc(full_doc[:line_feed]) + yaml_sep = full_doc[line_feed+1:].find('---') + if yaml_sep != -1: + other_lines = process_doc(full_doc[line_feed+1:line_feed+yaml_sep]) + swag = yaml.full_load(full_doc[line_feed+yaml_sep:]) + else: + other_lines = process_doc(full_doc[line_feed+1:]) else: - other_lines = process_doc(full_doc[line_feed+1:]) - else: - first_line = full_doc - return first_line, other_lines, swag + first_line = full_doc + return first_line, other_lines, swag + except Exception as e: + logger.error("Failed to parse docstring for %s: %s", obj, e) def _extract_definitions(alist, level=None): From 5bbd6b7d6ad6f9ea0973ae92b3611a3f80281991 Mon Sep 17 00:00:00 2001 From: Tom Cook Date: Thu, 18 Nov 2021 09:40:28 +0000 Subject: [PATCH 2/2] Propagate exception --- flask_swagger.py | 1 + 1 file changed, 1 insertion(+) diff --git a/flask_swagger.py b/flask_swagger.py index c6b73b8..82432c0 100644 --- a/flask_swagger.py +++ b/flask_swagger.py @@ -73,6 +73,7 @@ def _parse_docstring(obj, process_doc, from_file_keyword, base_path): return first_line, other_lines, swag except Exception as e: logger.error("Failed to parse docstring for %s: %s", obj, e) + raise def _extract_definitions(alist, level=None):