Initial commit with fixtures
- add fixtures for hardware and underlay
- add fuel-devops template tcpcloud-default.yaml
* Migration of fixtures is not finished yet
diff --git a/tcp_tests/helpers/log_step.py b/tcp_tests/helpers/log_step.py
new file mode 100644
index 0000000..64ec7aa
--- /dev/null
+++ b/tcp_tests/helpers/log_step.py
@@ -0,0 +1,70 @@
+# 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__))