summaryrefslogtreecommitdiff
path: root/buildandrun
blob: 41a636a96cc2050fb75092be575ad13b5e6be86e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#!/usr/bin/env python

import logging
import os
import os.path
import subprocess
import sys

from optparse import OptionParser

if os.getenv('DEBUG'):
    logging.basicConfig(level=logging.DEBUG)

def recursiverm(d):
    for root, dirs, files in os.walk(d):
        for f in files:
            f = root + os.path.sep + f
            logging.debug('Removing file: %s' % f)
            os.unlink(f)

def main():
    op = OptionParser()
    op.add_option('-c', '--clean', dest='clean', action='store_true',
            help='Remove the contents of the build directory')
    opts, args = op.parse_args()
    if not args:
        print('Specify a test script')
        return


    if opts.clean:
        logging.debug('Removing build/')
        recursiverm('build')

    logging.debug('Building Cheetah')
    rc = subprocess.call(('python', 'setup.py', 'build'))

    if rc:
        logging.debug('Build failed!')
        return

    logging.debug('Adjusting PATH and PYTHONPATH')
    cwd = os.getcwd()

    libdir = None
    scriptdir = None

    for sub in os.listdir('build'):
        if sub.startswith('scripts'):
            scriptdir = os.path.sep.join((cwd, 'build', sub))
        if sub.startswith('lib'):
            libdir = os.path.sep.join((cwd, 'build', sub))

    newpath = '%s:%s' % (scriptdir, os.getenv('PATH'))
    logging.debug('Setting PATH to: %s' % newpath)
    os.putenv('PATH', newpath)
    logging.debug('Setting PYTHONPATH to: %s' % libdir)
    os.putenv('PYTHONPATH', libdir)

    rc = subprocess.call( ['python',] + args )
    if rc == -11:
        logging.error('Segmentation fault in test process. Test failed.')


if __name__ == '__main__':
    main()