Add support for per test suite helper functions
This commit is contained in:
parent
05d83fa406
commit
b522929666
3
.gitignore
vendored
3
.gitignore
vendored
@ -21,5 +21,8 @@ massif-*
|
||||
*.ilk
|
||||
*.lib
|
||||
|
||||
# Python build artifacts:
|
||||
*.pyc
|
||||
|
||||
# CMake generates *.dir/ folders for in-tree builds (used by MSVC projects), ignore all of those:
|
||||
*.dir/
|
||||
|
@ -42,6 +42,9 @@ import shutil
|
||||
BEGIN_HEADER_REGEX = '/\*\s*BEGIN_HEADER\s*\*/'
|
||||
END_HEADER_REGEX = '/\*\s*END_HEADER\s*\*/'
|
||||
|
||||
BEGIN_SUITE_HELPERS_REGEX = '/\*\s*BEGIN_SUITE_HELPERS\s*\*/'
|
||||
END_SUITE_HELPERS_REGEX = '/\*\s*END_SUITE_HELPERS\s*\*/'
|
||||
|
||||
BEGIN_DEP_REGEX = 'BEGIN_DEPENDENCIES'
|
||||
END_DEP_REGEX = 'END_DEPENDENCIES'
|
||||
|
||||
@ -172,20 +175,21 @@ def gen_dispatch(name, deps):
|
||||
return dispatch_code
|
||||
|
||||
|
||||
def parse_suite_headers(funcs_f):
|
||||
def parse_until_pattern(funcs_f, end_regex):
|
||||
"""
|
||||
Parses function headers.
|
||||
Parses function headers or helper code until end pattern.
|
||||
|
||||
:param funcs_f: file object for .functions file
|
||||
:param end_regex: Pattern to stop parsing
|
||||
:return: Test suite headers code
|
||||
"""
|
||||
headers = '#line %d "%s"\n' % (funcs_f.line_no + 1, funcs_f.name)
|
||||
for line in funcs_f:
|
||||
if re.search(END_HEADER_REGEX, line):
|
||||
if re.search(end_regex, line):
|
||||
break
|
||||
headers += line
|
||||
else:
|
||||
raise InvalidFileFormat("file: %s - end header pattern [%s] not found!" % (funcs_f.name, END_HEADER_REGEX))
|
||||
raise InvalidFileFormat("file: %s - end pattern [%s] not found!" % (funcs_f.name, end_regex))
|
||||
|
||||
return headers
|
||||
|
||||
@ -325,6 +329,7 @@ def parse_functions(funcs_f):
|
||||
a dict with function identifiers and arguments info.
|
||||
"""
|
||||
suite_headers = ''
|
||||
suite_helpers = ''
|
||||
suite_deps = []
|
||||
suite_functions = ''
|
||||
func_info = {}
|
||||
@ -332,8 +337,11 @@ def parse_functions(funcs_f):
|
||||
dispatch_code = ''
|
||||
for line in funcs_f:
|
||||
if re.search(BEGIN_HEADER_REGEX, line):
|
||||
headers = parse_suite_headers(funcs_f)
|
||||
headers = parse_until_pattern(funcs_f, END_HEADER_REGEX)
|
||||
suite_headers += headers
|
||||
elif re.search(BEGIN_SUITE_HELPERS_REGEX, line):
|
||||
helpers = parse_until_pattern(funcs_f, END_SUITE_HELPERS_REGEX)
|
||||
suite_helpers += helpers
|
||||
elif re.search(BEGIN_DEP_REGEX, line):
|
||||
deps = parse_suite_deps(funcs_f)
|
||||
suite_deps += deps
|
||||
@ -350,7 +358,7 @@ def parse_functions(funcs_f):
|
||||
function_idx += 1
|
||||
|
||||
ifdef, endif = gen_deps(suite_deps)
|
||||
func_code = ifdef + suite_headers + suite_functions + endif
|
||||
func_code = ifdef + suite_headers + suite_helpers + suite_functions + endif
|
||||
return suite_deps, dispatch_code, func_code, func_info
|
||||
|
||||
|
||||
|
@ -280,9 +280,9 @@ class StringIOWrapper(StringIO, object):
|
||||
return line
|
||||
|
||||
|
||||
class ParseSuiteHeaders(TestCase):
|
||||
class ParseUntilPattern(TestCase):
|
||||
"""
|
||||
Test Suite for testing parse_suite_headers().
|
||||
Test Suite for testing parse_until_pattern().
|
||||
"""
|
||||
|
||||
def test_suite_headers(self):
|
||||
@ -302,7 +302,7 @@ class ParseSuiteHeaders(TestCase):
|
||||
#define ECP_PF_UNKNOWN -1
|
||||
'''
|
||||
s = StringIOWrapper('test_suite_ut.function', data, line_no=0)
|
||||
headers = parse_suite_headers(s)
|
||||
headers = parse_until_pattern(s, END_HEADER_REGEX)
|
||||
self.assertEqual(headers, expected)
|
||||
|
||||
def test_line_no(self):
|
||||
@ -323,7 +323,7 @@ class ParseSuiteHeaders(TestCase):
|
||||
#define ECP_PF_UNKNOWN -1
|
||||
''' % (offset_line_no + 1)
|
||||
s = StringIOWrapper('test_suite_ut.function', data, offset_line_no)
|
||||
headers = parse_suite_headers(s)
|
||||
headers = parse_until_pattern(s, END_HEADER_REGEX)
|
||||
self.assertEqual(headers, expected)
|
||||
|
||||
def test_no_end_header_comment(self):
|
||||
@ -337,7 +337,7 @@ class ParseSuiteHeaders(TestCase):
|
||||
|
||||
'''
|
||||
s = StringIOWrapper('test_suite_ut.function', data)
|
||||
self.assertRaises(InvalidFileFormat, parse_suite_headers, s)
|
||||
self.assertRaises(InvalidFileFormat, parse_until_pattern, s, END_HEADER_REGEX)
|
||||
|
||||
|
||||
class ParseSuiteDeps(TestCase):
|
||||
@ -620,15 +620,15 @@ class ParseFunction(TestCase):
|
||||
Test Suite for testing parse_functions()
|
||||
"""
|
||||
|
||||
@patch("generate_code.parse_suite_headers")
|
||||
def test_begin_header(self, parse_suite_headers_mock):
|
||||
@patch("generate_code.parse_until_pattern")
|
||||
def test_begin_header(self, parse_until_pattern_mock):
|
||||
"""
|
||||
Test that begin header is checked and parse_suite_headers() is called.
|
||||
Test that begin header is checked and parse_until_pattern() is called.
|
||||
:return:
|
||||
"""
|
||||
def stop(this):
|
||||
raise Exception
|
||||
parse_suite_headers_mock.side_effect = stop
|
||||
parse_until_pattern_mock.side_effect = stop
|
||||
data = '''/* BEGIN_HEADER */
|
||||
#include "mbedtls/ecp.h"
|
||||
|
||||
@ -637,13 +637,34 @@ class ParseFunction(TestCase):
|
||||
'''
|
||||
s = StringIOWrapper('test_suite_ut.function', data)
|
||||
self.assertRaises(Exception, parse_functions, s)
|
||||
parse_suite_headers_mock.assert_called_with(s)
|
||||
parse_until_pattern_mock.assert_called_with(s, END_HEADER_REGEX)
|
||||
self.assertEqual(s.line_no, 2)
|
||||
|
||||
@patch("generate_code.parse_until_pattern")
|
||||
def test_begin_helper(self, parse_until_pattern_mock):
|
||||
"""
|
||||
Test that begin helper is checked and parse_until_pattern() is called.
|
||||
:return:
|
||||
"""
|
||||
def stop(this):
|
||||
raise Exception
|
||||
parse_until_pattern_mock.side_effect = stop
|
||||
data = '''/* BEGIN_SUITE_HELPERS */
|
||||
void print_helloworld()
|
||||
{
|
||||
printf ("Hello World!\n");
|
||||
}
|
||||
/* END_SUITE_HELPERS */
|
||||
'''
|
||||
s = StringIOWrapper('test_suite_ut.function', data)
|
||||
self.assertRaises(Exception, parse_functions, s)
|
||||
parse_until_pattern_mock.assert_called_with(s, END_SUITE_HELPERS_REGEX)
|
||||
self.assertEqual(s.line_no, 2)
|
||||
|
||||
@patch("generate_code.parse_suite_deps")
|
||||
def test_begin_dep(self, parse_suite_deps_mock):
|
||||
"""
|
||||
Test that begin header is checked and parse_suite_headers() is called.
|
||||
Test that begin dep is checked and parse_suite_deps() is called.
|
||||
:return:
|
||||
"""
|
||||
def stop(this):
|
||||
@ -662,7 +683,7 @@ class ParseFunction(TestCase):
|
||||
@patch("generate_code.parse_function_deps")
|
||||
def test_begin_function_dep(self, parse_function_deps_mock):
|
||||
"""
|
||||
Test that begin header is checked and parse_suite_headers() is called.
|
||||
Test that begin dep is checked and parse_function_deps() is called.
|
||||
:return:
|
||||
"""
|
||||
def stop(this):
|
||||
@ -683,7 +704,7 @@ class ParseFunction(TestCase):
|
||||
@patch("generate_code.parse_function_deps")
|
||||
def test_return(self, parse_function_deps_mock, parse_function_code_mock):
|
||||
"""
|
||||
Test that begin header is checked and parse_suite_headers() is called.
|
||||
Test that begin case is checked and parse_function_code() is called.
|
||||
:return:
|
||||
"""
|
||||
def stop(this):
|
||||
@ -718,7 +739,7 @@ class ParseFunction(TestCase):
|
||||
|
||||
def test_parsing(self):
|
||||
"""
|
||||
Test that begin header is checked and parse_suite_headers() is called.
|
||||
Test case parsing.
|
||||
:return:
|
||||
"""
|
||||
data = '''/* BEGIN_HEADER */
|
||||
@ -811,7 +832,7 @@ void test_func2_wrapper( void ** params )
|
||||
|
||||
def test_same_function_name(self):
|
||||
"""
|
||||
Test that begin header is checked and parse_suite_headers() is called.
|
||||
Test name conflict.
|
||||
:return:
|
||||
"""
|
||||
data = '''/* BEGIN_HEADER */
|
||||
|
Loading…
Reference in New Issue
Block a user