/[escript]/trunk/site_scons/site_init.py
ViewVC logotype

Diff of /trunk/site_scons/site_init.py

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 3270 by caltinay, Thu Oct 14 00:30:11 2010 UTC revision 4300 by caltinay, Mon Mar 11 00:50:19 2013 UTC
# Line 1  Line 1 
1    
2  ########################################################  ##############################################################################
3  #  #
4  # Copyright (c) 2003-2010 by University of Queensland  # Copyright (c) 2003-2013 by University of Queensland
5  # Earth Systems Science Computational Center (ESSCC)  # http://www.uq.edu.au
 # http://www.uq.edu.au/esscc  
6  #  #
7  # Primary Business: Queensland, Australia  # Primary Business: Queensland, Australia
8  # Licensed under the Open Software License version 3.0  # Licensed under the Open Software License version 3.0
9  # http://www.opensource.org/licenses/osl-3.0.php  # http://www.opensource.org/licenses/osl-3.0.php
10  #  #
11  ########################################################  # Development until 2012 by Earth Systems Science Computational Center (ESSCC)
12    # Development since 2012 by School of Earth Sciences
13    #
14    ##############################################################################
15    
16  __copyright__="""Copyright (c) 2003-2010 by University of Queensland  __copyright__="""Copyright (c) 2003-2013 by University of Queensland
17  Earth Systems Science Computational Center (ESSCC)  http://www.uq.edu.au
 http://www.uq.edu.au/esscc  
18  Primary Business: Queensland, Australia"""  Primary Business: Queensland, Australia"""
19  __license__="""Licensed under the Open Software License version 3.0  __license__="""Licensed under the Open Software License version 3.0
20  http://www.opensource.org/licenses/osl-3.0.php"""  http://www.opensource.org/licenses/osl-3.0.php"""
21  __url__="https://launchpad.net/escript-finley"  __url__="https://launchpad.net/escript-finley"
22    
23  import sys, os, time, glob, fnmatch, types, py_compile, re  import sys, os, time, py_compile, re, subprocess
24    from SCons.Defaults import Chmod
25    from grouptest import *
26    
27  def findLibWithHeader(env, libs, header, paths, lang='c'):  def findLibWithHeader(env, libs, header, paths, lang='c'):
28      from SCons.Script.SConscript import Configure      from SCons.Script.SConscript import Configure
# Line 69  def findLibWithHeader(env, libs, header, Line 72  def findLibWithHeader(env, libs, header,
72      conf.Finish()      conf.Finish()
73      return inc_path, lib_path      return inc_path, lib_path
74    
75    def detectModule(env, module):
76        p=subprocess.call([env['pythoncmd'],'-c','import %s'%module])
77        if p != 0:
78            env[module] = False
79            return False
80        env[module] = True
81        return True
82    
83    def write_buildvars(env):
84        buildvars=open(os.path.join(env['libinstall'], 'buildvars'), 'w')
85        for k,v in sorted(env['buildvars'].items()):
86            buildvars.write("%s=%s\n"%(k,v))
87        buildvars.close()
88    
89    def generateTestScripts(env, TestGroups):
90        try:
91            utest=open('utest.sh','w')
92            utest.write(GroupTest.makeHeader(env['PLATFORM'], env['prefix'], False))
93            for tests in TestGroups:
94                utest.write(tests.makeString())
95            utest.close()
96            env.Execute(Chmod('utest.sh', 0o755))
97            print("Generated utest.sh.")
98            # This version contains only python tests - I want this to be usable
99            # from a binary only install if you have the test files
100            utest=open('itest.sh','w')
101            utest.write(GroupTest.makeHeader(env['PLATFORM'], env['prefix'], True))
102            for tests in TestGroups:
103              if tests.exec_cmd=='$PYTHONRUNNER ':
104                utest.write(tests.makeString())
105            utest.close()
106            env.Execute(Chmod('itest.sh', 0o755))
107            print("Generated itest.sh.")        
108        except IOError:
109            env['warnings'].append("Error attempting to write unit test script(s).")
110    
111        # delete scripts upon cleanup
112        env.Clean('target_init', 'utest.sh')
113        env.Clean('target_init', 'itest.sh')
114    
115        # Make sure that the escript wrapper is in place
116        if not os.path.isfile(os.path.join(env['bininstall'], 'run-escript')):
117            print("Copying escript wrapper.")
118            Execute(Copy(os.path.join(env['bininstall'],'run-escript'), 'bin/run-escript'))
119    
120  # Code to build .pyc from .py  # Code to build .pyc from .py
121  def build_py(target, source, env):  def build_py(target, source, env):
122      py_compile.compile(str(source[0]), str(target[0]))      try:
123      return 0         py_compile.compile(str(source[0]), str(target[0]), doraise=True)
124           return 0
125        except py_compile.PyCompileError, e:
126           print e
127           return 1
128    
129    
130  # Code to run unit_test executables  # Code to run unit_test executables
131  def runUnitTest(target, source, env):  def runUnitTest(target, source, env):
# Line 80  def runUnitTest(target, source, env): Line 133  def runUnitTest(target, source, env):
133    app = str(source[0].abspath)    app = str(source[0].abspath)
134    pn, sn= os.path.split(app)    pn, sn= os.path.split(app)
135    if not os.name== "nt":    if not os.name== "nt":
136       app = "cd "+pn+"; "+os.path.join(env['bininstall'],"escript")+" -bv "+os.path.join('.',sn)       app = "cd "+pn+"; "+os.path.join(env['bininstall'], "run-escript")+" -bv "+os.path.join('.',sn)
137    else:    else:
138        if env['usempi']:        if env['usempi']:
139            app = "cd %s & mpiexec -np %s -genvlist PYTHONPATH,OMP_NUM_THREADS,"\            app = "cd %s & mpiexec -np %s -genvlist PYTHONPATH,OMP_NUM_THREADS,"\
# Line 108  def runPyUnitTest(target, source, env): Line 161  def runPyUnitTest(target, source, env):
161         else:         else:
162             app = "cd "+ pn +" & "+sys.executable + " " + sn             app = "cd "+ pn +" & "+sys.executable + " " + sn
163     else:     else:
164       app = "cd "+pn+"; "+os.path.join(env['bininstall'],"escript")+" -ov "+sn       app = "cd "+pn+"; "+os.path.join(env['bininstall'], "run-escript")+" -ov "+sn
165     print "Executing test: ",app     print "Executing test: ",app
166     if env.Execute(app) == 0:     if env.Execute(app) == 0:
167        open(str(target[0]),'w').write("PASSED\n")        open(str(target[0]),'w').write("PASSED\n")

Legend:
Removed from v.3270  
changed lines
  Added in v.4300

  ViewVC Help
Powered by ViewVC 1.1.26