blob: 64ec7aa1f4a889757a28a94716b61960d41a1b73 [file] [log] [blame]
# Copyright 2016 Mirantis, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import re
from tcp_tests import logger
LOG = logger.logger
def parse_test_doc(docstring):
test_case = {}
parse_regex = re.compile(r'(?P<title>^(.*\S.*\n)+)+'
r'(?P<empty_line1>\s*\n)'
r'\s*Scenario:\s*\n(?P<scenario>(.+\n)+)'
r'(?P<empty_line2>\s*(\n|$))?'
r'(\s*Duration:\s+(?P<duration>\d+).*\n)?')
doc_match = re.match(parse_regex, docstring)
if not doc_match:
LOG.error("Can't parse test docstring, unknown format!")
return test_case
test_case['title'] = re.sub(r'[\n\s]+', # replace multiple spaces and
' ', # line breaks by single space
doc_match.group('title')
).strip()
test_case['steps'] = []
for raw_step in re.split(r'\s+\d+\.\s*', doc_match.group('scenario')):
if not raw_step:
# start or end of the string
continue
test_case['steps'].append(
re.sub(r'[\n\s]+', # replace multiple spaces and
' ', # line breaks by single space
raw_step
).strip()
)
# TODO(apanchenko): now it works only with 'seconds'
duration = doc_match.group('duration') or 1000
test_case['duration'] = int(duration)
return test_case
def log_step(func, step_num):
if not func.__doc__:
LOG.error("Can't show step #{0}: docstring for method {1} not "
"found!".format(step_num, func.__name__))
test_case_steps = parse_test_doc(func.__doc__)['steps']
try:
LOG.info(" *** [STEP#{0}] {1} ***".format(
step_num,
test_case_steps[step_num - 1]))
except IndexError:
LOG.error("Can't show step #{0}: docstring for method {1} does't "
"contain it!".format(step_num, func.__name__))