source: tests/pybin/settings.py@ cce4648

ADT ast-experimental pthread-emulation qualifiedEnum
Last change on this file since cce4648 was cc9b520, checked in by Thierry Delisle <tdelisle@…>, 4 years ago

Clean-up error handling in test scripts

  • Property mode set to 100644
File size: 5.5 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 = """AST_FLAGS=-XCFA,--new-ast"""
105 elif ast == "old":
106 self.target = ast
107 self.string = "Old AST"
108 self.flags = """AST_FLAGS=-XCFA,--old-ast"""
109 elif ast == None:
110 self.target = "new" if config.NEWAST else "old"
111 self.string = "Default AST (%s)" % self.target
112 self.flags = """AST_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))
Note: See TracBrowser for help on using the repository browser.