source: tests/pybin/settings.py @ ea10f64

Last change on this file since ea10f64 was 950c58e, checked in by Andrew Beach <ajbeach@…>, 15 months ago

The invariant flags on the test script were set up incorrectly. They should do as documented now and be on by default now.

  • Property mode set to 100644
File size: 4.9 KB
RevLine 
[f85bc15]1import os
[a45fc7b]2import subprocess
[f3b9efc]3import sys
[5b993e0]4from . import tools
[bacc36c]5
[dcfedca]6global original_path
7
[f85bc15]8try :
[dcfedca]9        original_path = os.getcwd()
[afe8882]10        testpath = os.path.dirname(os.path.abspath(os.path.join(os.getcwd(), sys.argv[0])))
11        sys.path.append(testpath)
[552f5cb]12        import config
[f85bc15]13
[552f5cb]14        SRCDIR = os.path.abspath(config.SRCDIR)
15        BUILDDIR = os.path.abspath(config.BUILDDIR)
[d65f92c]16        distribute = config.DISTRIBUTE
[afe8882]17        os.chdir(testpath)
18
[f85bc15]19except:
20        print('ERROR: missing config.py, re-run configure script.', file=sys.stderr)
21        sys.exit(1)
22
[bacc36c]23class Architecture:
[f3b9efc]24        KnownArchitectures = {
[41af19c]25                'x64'         : 'x64',
26                'x86-64'      : 'x64',
27                'x86_64'      : 'x64',
28                'x86'         : 'x86',
[9509a412]29                'aarch64'     : 'arm64',
30                'arm64'       : 'arm64',
31                'ARM64'       : 'arm64',
[41af19c]32                'i386'        : 'x86',
33                'i486'        : 'x86',
34                'i686'        : 'x86',
35                'Intel 80386' : 'x86',
[9509a412]36                'arm'         : 'arm32',
37                'ARM'         : 'arm32',
38                'arm32'       : 'arm32',
39                'ARM32'       : 'arm32',
[f3b9efc]40        }
41
[575a6e5]42        CrossCompileFlags = {
[9509a412]43                'x64'  : 'ARCH_FLAGS=-m64',
44                'x86'  : 'ARCH_FLAGS=-m32',
45                'arm64': 'ARCH_FLAGS=',
46                'arm32': 'ARCH_FLAGS=',
[575a6e5]47        }
48
[f3b9efc]49        def __init__(self, arch):
[575a6e5]50                try:
[5bf1f3e]51                        canonical_host = Architecture.make_canonical( config.HOSTARCH )
[575a6e5]52                except KeyError:
[d82892a]53                        print("Unknown host architecture %s" % config.HOSTARCH, file=sys.stderr)
[575a6e5]54                        sys.exit(1)
55
[f3b9efc]56                if arch:
57                        try:
[5bf1f3e]58                                arch = Architecture.make_canonical( arch )
[f3b9efc]59                        except KeyError:
[d82892a]60                                print("Unknown architecture %s" % arch, file=sys.stderr)
[f3b9efc]61                                sys.exit(1)
[575a6e5]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
[47c1928]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)
[575a6e5]76
[f3b9efc]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
[136f86b]85        def filter(self, tests):
86                return [test for test in tests if not test.arch or self.target == test.arch]
[f3b9efc]87
[64cf022]88        @staticmethod
89        def make_canonical(arch):
[f3b9efc]90                return Architecture.KnownArchitectures[arch]
91
[bacc36c]92
[f3b9efc]93class Debug:
94        def __init__(self, value):
95                self.string = "debug" if value else "no debug"
[a45fc7b]96                self.flags  = """DEBUG_FLAGS=%s""" % ("-debug -O0" if value else "-nodebug -O2")
[d65f92c]97                self.path   = "debug" if value else "nodebug"
[bacc36c]98
[a5121bf]99class Install:
100        def __init__(self, value):
[d65f92c]101                if value:
102                        distribute = False
103
[abec2f8]104                self.string = "installed" if value else "in tree"
[158b026]105                self.flags  = """installed=%s""" % ("yes" if value else "no")
[a5121bf]106
[afe8882]107class Timeouts:
108        def __init__(self, ts, tg):
109                self.single = Timeouts.check(ts)
110                self.total  = Timeouts.check(tg)
111
[64cf022]112        @staticmethod
113        def check(value):
[afe8882]114                if value < 1:
115                        print("Timeouts must be at least 1 second", file=sys.stderr)
116                        sys.exit(1)
117
118                return value
119
[bacc36c]120def init( options ):
[136f86b]121        global all_arch
122        global all_debug
123        global all_install
[bacc36c]124        global arch
[99581ee]125        global debug
[6daaee3]126        global archive
[99581ee]127        global install
[a5ea261]128        global invariant
[99581ee]129
[136f86b]130        global continue_
[bacc36c]131        global dry_run
132        global generating
[6daaee3]133        global make
[fc01219]134        global make_jobfds
[5bf1f3e]135        global output_width
[6daaee3]136        global timeout
[d658183]137        global timeout2gdb
[bacc36c]138
[41af19c]139        all_arch     = [Architecture(o) for o in list(dict.fromkeys(options.arch   ))] if options.arch else [Architecture(None)]
[136f86b]140        all_debug    = [Debug(o)        for o in list(dict.fromkeys(options.debug  ))]
141        all_install  = [Install(o)      for o in list(dict.fromkeys(options.install))]
[6daaee3]142        archive      = os.path.abspath(os.path.join(original_path, options.archive_errors)) if options.archive_errors else None
[950c58e]143        invariant    = options.invariant
[136f86b]144        continue_    = options.continue_
[8209e70]145        dry_run      = options.dry_run # must be called before tools.config_hash()
[5bf1f3e]146        generating   = options.regenerate_expected
[6daaee3]147        make         = ['make']
[fc01219]148        make_jobfds  = []
[5bf1f3e]149        output_width = 24
[6daaee3]150        timeout      = Timeouts(options.timeout, options.global_timeout)
[d658183]151        timeout2gdb  = options.timeout_with_gdb
[bacc36c]152
[17bc05b]153        # if we distribute, distcc errors will fail tests, use log file for distcc
154        # don't use "'DISTCC_LOG' not in os.environ" because it can be set to ''
[d65f92c]155        if distribute and not os.environ.get('DISTCC_LOG'):
156                os.putenv('DISTCC_LOG', os.path.join(BUILDDIR, 'distcc_error.log'))
[f85bc15]157
[fc01219]158def update_make_cmd(flags):
[bacc36c]159        global make
[fc01219]160        make = ['make', *flags]
[bacc36c]161
[fc01219]162def update_make_fds(r, w):
163        global make_jobfds
164        make_jobfds = (r, w)
[28582b2]165
166def validate():
[136f86b]167        """Validate the current configuration and update globals"""
168
169        global distcc
170        distcc       = "DISTCC_CFA_PATH=~/.cfadistcc/%s/cfa" % tools.config_hash()
[cc9b520]171        make_ret, out, err = tools.make( ".validate", output_file=subprocess.PIPE, error=subprocess.PIPE )
[28582b2]172        if make_ret != 0:
[575a6e5]173                print("ERROR: Invalid configuration %s:%s" % (arch.string, debug.string), file=sys.stderr)
[cc9b520]174                print("       verify returned : \n%s" % err, file=sys.stderr)
[28582b2]175                sys.exit(1)
176
[d3c1c6a]177def prep_output(tests):
[5bf1f3e]178        global output_width
179        output_width = max(map(lambda t: len(t.target()), tests))
[767a8ef]180        # 35 is the maximum width of the name field before we get line wrapping.
181        output_width = min(output_width, 35)
Note: See TracBrowser for help on using the repository browser.