tst_json_grammar.py 2.47 KB
Newer Older
eckhart's avatar
eckhart committed
1
2
3
4
5
6
7
8
#!/usr/bin/python3

"""tst_json_grammar.py - runs the unit tests for the json-grammar
"""

import os
import sys

di68kap's avatar
di68kap committed
9
LOGGING = ''
eckhart's avatar
eckhart committed
10

11
scriptpath = os.path.dirname(__file__) or '.'
12
13
14
15
for path in (os.path.join('..', '..'), '.'):
    fullpath = os.path.abspath(os.path.join(scriptpath, path))
    if fullpath not in sys.path:
        sys.path.append(fullpath)
eckhart's avatar
eckhart committed
16
17
18
19
20
21
22
23
24
25
26
27
28
29

try:
    from DHParser import dsl
    import DHParser.log
    from DHParser import testing
except ModuleNotFoundError:
    print('Could not import DHParser. Please adjust sys.path in file '
          '"%s" manually' % __file__)
    sys.exit(1)


def recompile_grammar(grammar_src, force):
    grammar_tests_dir = os.path.join(scriptpath, 'grammar_tests')
    testing.create_test_templates(grammar_src, grammar_tests_dir)
30
31
32
33
34
35
36
37
    # recompiles Grammar only if it has changed
    if not dsl.recompile_grammar(grammar_src, force=force,
            notify=lambda: print('recompiling ' + grammar_src)):
        print('\nErrors while recompiling "%s":' % grammar_src +
              '\n--------------------------------------\n\n')
        with open('json_ebnf_ERRORS.txt', encoding='utf-8') as f:
            print(f.read())
        sys.exit(1)
eckhart's avatar
eckhart committed
38
39


di68kap's avatar
di68kap committed
40
def run_grammar_tests(glob_pattern, get_grammar, get_transformer):
41
42
43
44
45
    DHParser.log.start_logging(LOGGING)
    error_report = testing.grammar_suite(
        os.path.join(scriptpath, 'grammar_tests'),
        get_grammar, get_transformer,
        fn_patterns=[glob_pattern], report='REPORT', verbose=True)
eckhart's avatar
eckhart committed
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
    return error_report


if __name__ == '__main__':
    argv = sys.argv[:]
    if len(argv) > 1 and sys.argv[1] == "--debug":
        LOGGING = True
        del argv[1]
    if (len(argv) >= 2 and (argv[1].endswith('.ebnf') or
        os.path.splitext(argv[1])[1].lower() in testing.TEST_READERS.keys())):
        # if called with a single filename that is either an EBNF file or a known
        # test file type then use the given argument
        arg = argv[1]
    else:
        # otherwise run all tests in the test directory
        arg = '*_test_*.ini'
    if arg.endswith('.ebnf'):
        recompile_grammar(arg, force=True)
    else:
        recompile_grammar(os.path.join(scriptpath, 'json.ebnf'),
                          force=False)
        sys.path.append('.')
        from jsonCompiler import get_grammar, get_transformer
di68kap's avatar
di68kap committed
69
        error_report = run_grammar_tests(arg, get_grammar, get_transformer)
eckhart's avatar
eckhart committed
70
71
72
73
74
        if error_report:
            print('\n')
            print(error_report)
            sys.exit(1)
        print('ready.\n')