source: tests/pybin/settings.py @ d895e32

ADTast-experimentalpthread-emulation
Last change on this file since d895e32 was e173d3c, checked in by Thierry Delisle <tdelisle@…>, 2 years ago

'soft' removed old ast from tests.
Option still works but no longer has any effect.

  • Property mode set to 100644
File size: 5.6 KB
Line 
1import os
2import subprocess
3import sys
4from . import tools
5
6global original_path
7
8try :
9        original_path = os.getcwd()
10        testpath = os.path.dirname(os.path.abspath(os.path.join(os.getcwd(), sys.argv[0])))
11        sys.path.append(testpath)
12        import config
13
14        SRCDIR = os.path.abspath(config.SRCDIR)
15        BUILDDIR = os.path.abspath(config.BUILDDIR)
16        distribute = config.DISTRIBUTE
17        os.chdir(testpath)
18
19except:
20        print('ERROR: missing config.py, re-run configure script.', file=sys.stderr)
21        sys.exit(1)
22
23class Architecture:
24        KnownArchitectures = {
25                'x64'         : 'x64',
26                'x86-64'      : 'x64',
27                'x86_64'      : 'x64',
28                'x86'         : 'x86',
29                'aarch64'     : 'arm64',
30                'arm64'       : 'arm64',
31                'ARM64'       : 'arm64',
32                'i386'        : 'x86',
33                'i486'        : 'x86',
34                'i686'        : 'x86',
35                'Intel 80386' : 'x86',
36                'arm'         : 'arm32',
37                'ARM'         : 'arm32',
38                'arm32'       : 'arm32',
39                'ARM32'       : 'arm32',
40        }
41
42        CrossCompileFlags = {
43                'x64'  : 'ARCH_FLAGS=-m64',
44                'x86'  : 'ARCH_FLAGS=-m32',
45                'arm64': 'ARCH_FLAGS=',
46                'arm32': 'ARCH_FLAGS=',
47        }
48
49        def __init__(self, arch):
50                try:
51                        canonical_host = Architecture.make_canonical( config.HOSTARCH )
52                except KeyError:
53                        print("Unknown host architecture %s" % config.HOSTARCH, file=sys.stderr)
54                        sys.exit(1)
55
56                if arch:
57                        try:
58                                arch = Architecture.make_canonical( arch )
59                        except KeyError:
60                                print("Unknown architecture %s" % arch, file=sys.stderr)
61                                sys.exit(1)
62
63                if arch and arch != canonical_host:
64                        self.target = arch
65                        self.cross_compile = True
66                else:
67                        self.target = canonical_host
68                        self.cross_compile = False
69
70
71                try :
72                        self.flags = Architecture.CrossCompileFlags[self.target]
73                except KeyError:
74                        print("Cross compilation not available for architecture %s" % self.target, file=sys.stderr)
75                        sys.exit(1)
76
77                self.string = self.target
78
79        def update(self):
80                if not self.cross_compile:
81                        self.target = machine_default()
82                        self.string = self.target
83                        print("updated to %s" % self.target)
84
85        def filter(self, tests):
86                return [test for test in tests if not test.arch or self.target == test.arch]
87
88        @staticmethod
89        def make_canonical(arch):
90                return Architecture.KnownArchitectures[arch]
91
92
93class Debug:
94        def __init__(self, value):
95                self.string = "debug" if value else "no debug"
96                self.flags  = """DEBUG_FLAGS=%s""" % ("-debug -O0" if value else "-nodebug -O2")
97                self.path   = "debug" if value else "nodebug"
98
99class AST:
100        def __init__(self, ast):
101                if ast == "new":
102                        self.target = ast
103                        self.string = "New AST"
104                        self.flags  = """"""
105                elif ast == "old":
106                        self.target = ast
107                        self.string = "Old AST"
108                        self.flags  = """"""
109                elif ast == None:
110                        self.target = "new" if config.NEWAST else "old"
111                        self.string = "Default AST (%s)" % self.target
112                        self.flags  = """"""
113                else:
114                        print("""ERROR: Invalid ast configuration, must be "old", "new" or left unspecified, was %s""" % (value), file=sys.stderr)
115                        sys.exit(1)
116
117        def filter(self, tests):
118
119                return [test for test in tests if not test.astv or self.target == test.astv]
120
121class Install:
122        def __init__(self, value):
123                if value:
124                        distribute = False
125
126                self.string = "installed" if value else "in tree"
127                self.flags  = """installed=%s""" % ("yes" if value else "no")
128
129class Timeouts:
130        def __init__(self, ts, tg):
131                self.single = Timeouts.check(ts)
132                self.total  = Timeouts.check(tg)
133
134        @staticmethod
135        def check(value):
136                if value < 1:
137                        print("Timeouts must be at least 1 second", file=sys.stderr)
138                        sys.exit(1)
139
140                return value
141
142def init( options ):
143        global all_ast
144        global all_arch
145        global all_debug
146        global all_install
147        global ast
148        global arch
149        global debug
150        global archive
151        global install
152
153        global continue_
154        global dry_run
155        global generating
156        global make
157        global make_jobfds
158        global output_width
159        global timeout
160        global timeout2gdb
161
162        all_ast      = [AST(o)          for o in list(dict.fromkeys(options.ast    ))] if options.ast  else [AST(None)]
163        all_arch     = [Architecture(o) for o in list(dict.fromkeys(options.arch   ))] if options.arch else [Architecture(None)]
164        all_debug    = [Debug(o)        for o in list(dict.fromkeys(options.debug  ))]
165        all_install  = [Install(o)      for o in list(dict.fromkeys(options.install))]
166        archive      = os.path.abspath(os.path.join(original_path, options.archive_errors)) if options.archive_errors else None
167        continue_    = options.continue_
168        dry_run      = options.dry_run # must be called before tools.config_hash()
169        generating   = options.regenerate_expected
170        make         = ['make']
171        make_jobfds  = []
172        output_width = 24
173        timeout      = Timeouts(options.timeout, options.global_timeout)
174        timeout2gdb  = options.timeout_with_gdb
175
176        # if we distribute, distcc errors will fail tests, use log file for distcc
177        # don't use "'DISTCC_LOG' not in os.environ" because it can be set to ''
178        if distribute and not os.environ.get('DISTCC_LOG'):
179                os.putenv('DISTCC_LOG', os.path.join(BUILDDIR, 'distcc_error.log'))
180
181def update_make_cmd(flags):
182        global make
183        make = ['make', *flags]
184
185def update_make_fds(r, w):
186        global make_jobfds
187        make_jobfds = (r, w)
188
189def validate():
190        """Validate the current configuration and update globals"""
191
192        global distcc
193        distcc       = "DISTCC_CFA_PATH=~/.cfadistcc/%s/cfa" % tools.config_hash()
194        make_ret, out, err = tools.make( ".validate", output_file=subprocess.PIPE, error=subprocess.PIPE )
195        if make_ret != 0:
196                print("ERROR: Invalid configuration %s:%s" % (arch.string, debug.string), file=sys.stderr)
197                print("       verify returned : \n%s" % err, file=sys.stderr)
198                sys.exit(1)
199
200def prep_output(tests):
201        global output_width
202        output_width = max(map(lambda t: len(t.target()), tests))
203        # 35 is the maximum width of the name field before we get line wrapping.
204        output_width = min(output_width, 35)
Note: See TracBrowser for help on using the repository browser.