Mercurial > ~astiob > upreckon > hgweb
annotate config.py @ 123:90c002c960cb
Fixed CPU time display on UNIX
Previously, the total CPU time spent by the testee on all
test cases up to and including the current one was displayed.
| author | Oleg Oshmyan <chortos@inbox.lv> | 
|---|---|
| date | Sun, 24 Apr 2011 19:28:40 +0100 | 
| parents | 6589511f5418 | 
| children | 
| rev | line source | 
|---|---|
| 78 | 1 # Copyright (c) 2010-2011 Chortos-2 <chortos@inbox.lv> | 
| 16 | 2 | 
| 21 | 3 from __future__ import division, with_statement | 
| 4 | |
| 91 | 5 from compat import * | 
| 6 import files | |
| 7 from __main__ import options | |
| 21 | 8 | 
| 9 if files.ZipArchive: | |
| 10 try: | |
| 11 import zipimport | |
| 12 except ImportError: | |
| 13 zipimport = None | |
| 14 else: | |
| 15 zipimport = None | |
| 16 | |
| 22 | 17 import imp, os, sys, tempfile | 
| 21 | 18 | 
| 19 __all__ = 'load_problem', 'load_global', 'globalconf' | |
| 20 | |
| 74 | 21 defaults_problem = {'kind': 'batch', | 
| 22 'usegroups': False, | |
| 82 
06356af50bf9
Finished testcases reorganization and CPU time limit implementation
 Oleg Oshmyan <chortos@inbox.lv> parents: 
79diff
changeset | 23 'maxcputime': None, | 
| 
06356af50bf9
Finished testcases reorganization and CPU time limit implementation
 Oleg Oshmyan <chortos@inbox.lv> parents: 
79diff
changeset | 24 'maxwalltime': None, | 
| 21 | 25 'maxmemory': None, | 
| 96 
c3afa2b0c14c
Fixed a typo (did not affect anything)
 Oleg Oshmyan <chortos@inbox.lv> parents: 
92diff
changeset | 26 'dummies': (), | 
| 21 | 27 'testsexcluded': (), | 
| 28 'padtests': 0, | |
| 29 'paddummies': 0, | |
| 30 'taskweight': 100, | |
| 76 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 31 'groupweight': {}, | 
| 21 | 32 'pointmap': {}, | 
| 33 'stdio': False, | |
| 34 'dummyinname': '', | |
| 35 'dummyoutname': '', | |
| 36 'tester': None, | |
| 37 'maxexitcode': 0, | |
| 38 'inname': '', | |
| 39 'ansname': ''} | |
| 79 
ee8a99dcaaed
Renamed configuration variable tasknames to problems
 Oleg Oshmyan <chortos@inbox.lv> parents: 
78diff
changeset | 40 defaults_global = {'problems': None, | 
| 22 | 41 'force_zero_exitcode': True} | 
| 43 | 42 defaults_noerase = {'inname': '%.in', | 
| 43 'outname': '%.out', | |
| 44 'ansname': '%.ans'} | |
| 21 | 45 patterns = ('inname', 'outname', 'ansname', 'testcaseinname', | 
| 46 'testcaseoutname', 'dummyinname', 'dummyoutname') | |
| 47 | |
| 48 class Config(object): | |
| 49 __slots__ = 'modules', '__dict__' | |
| 50 | |
| 51 def __init__(self, *modules): | |
| 52 self.modules = modules | |
| 53 | |
| 54 def __getattr__(self, name): | |
| 55 for module in self.modules: | |
| 56 try: | |
| 57 return getattr(module, name) | |
| 58 except AttributeError: | |
| 59 pass | |
| 60 # TODO: provide a message | |
| 61 raise AttributeError(name) | |
| 16 | 62 | 
| 22 | 63 # A helper context manager | 
| 64 class ReadDeleting(object): | |
| 25 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 65 __slots__ = 'name', 'file' | 
| 22 | 66 | 
| 67 def __init__(self, name): | |
| 68 self.name = name | |
| 69 | |
| 70 def __enter__(self): | |
| 71 try: | |
| 25 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 72 self.file = open(self.name, 'rU') | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 73 return self.file | 
| 22 | 74 except: | 
| 75 try: | |
| 76 self.__exit__(None, None, None) | |
| 77 except: | |
| 78 pass | |
| 79 raise | |
| 80 | |
| 81 def __exit__(self, exc_type, exc_val, exc_tb): | |
| 25 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 82 self.file.close() | 
| 22 | 83 os.remove(self.name) | 
| 84 | |
| 21 | 85 def load_problem(problem_name): | 
| 70 
b9d5857f7b9a
Better emulation of built-ins for testconf
 Oleg Oshmyan <chortos@inbox.lv> parents: 
60diff
changeset | 86 global builtins | 
| 83 | 87 try: | 
| 88 dwb = sys.dont_write_bytecode | |
| 89 sys.dont_write_bytecode = True | |
| 90 except AttributeError: | |
| 91 pass | |
| 21 | 92 metafile = files.File('/'.join((problem_name, 'testconf.py')), True, 'configuration') | 
| 93 module = None | |
| 70 
b9d5857f7b9a
Better emulation of built-ins for testconf
 Oleg Oshmyan <chortos@inbox.lv> parents: 
60diff
changeset | 94 with CompatBuiltins() as builtins: | 
| 25 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 95 if zipimport and isinstance(metafile.archive, files.ZipArchive): | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 96 try: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 97 module = zipimport.zipimporter(os.path.dirname(metafile.full_real_path)).load_module('testconf') | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 98 except zipimport.ZipImportError: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 99 pass | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 100 else: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 101 del sys.modules['testconf'] | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 102 if not module: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 103 try: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 104 with metafile.open() as f: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 105 module = imp.load_module('testconf', f, metafile.full_real_path, ('.py', 'r', imp.PY_SOURCE)) | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 106 # Handle the case when f is not a true file object but imp requires one | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 107 except ValueError: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 108 # FIXME: 2.5 lacks the delete parameter | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 109 with tempfile.NamedTemporaryFile(delete=False) as f: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 110 inputdatafname = f.name | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 111 metafile.copy(inputdatafname) | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 112 with ReadDeleting(inputdatafname) as f: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 113 module = imp.load_module('testconf', f, metafile.full_real_path, ('.py', 'r', imp.PY_SOURCE)) | 
| 21 | 114 del sys.modules['testconf'] | 
| 107 
6589511f5418
Fixed mishandling of some variables in multi-problem legacy configurations
 Oleg Oshmyan <chortos@inbox.lv> parents: 
96diff
changeset | 115 module = Config(module, globalconf) | 
| 21 | 116 if hasattr(module, 'padwithzeroestolength'): | 
| 117 if not hasattr(module, 'padtests'): | |
| 118 try: | |
| 119 module.padtests = module.padwithzeroestolength[0] | |
| 120 except TypeError: | |
| 121 module.padtests = module.padwithzeroestolength | |
| 122 if not hasattr(module, 'paddummies'): | |
| 123 try: | |
| 124 module.paddummies = module.padwithzeroestolength[1] | |
| 125 except TypeError: | |
| 126 module.paddummies = module.padwithzeroestolength | |
| 92 
17041a71bc02
maxtime is now auto-converted to maxcputime
 Oleg Oshmyan <chortos@inbox.lv> parents: 
91diff
changeset | 127 if (not hasattr(module, 'maxcputime') and | 
| 
17041a71bc02
maxtime is now auto-converted to maxcputime
 Oleg Oshmyan <chortos@inbox.lv> parents: 
91diff
changeset | 128 not hasattr(module, 'maxwalltime') and | 
| 
17041a71bc02
maxtime is now auto-converted to maxcputime
 Oleg Oshmyan <chortos@inbox.lv> parents: 
91diff
changeset | 129 hasattr(module, 'maxtime')): | 
| 
17041a71bc02
maxtime is now auto-converted to maxcputime
 Oleg Oshmyan <chortos@inbox.lv> parents: 
91diff
changeset | 130 module.maxcputime = module.maxtime | 
| 21 | 131 for name in defaults_problem: | 
| 107 
6589511f5418
Fixed mishandling of some variables in multi-problem legacy configurations
 Oleg Oshmyan <chortos@inbox.lv> parents: 
96diff
changeset | 132 setattr(module, name, getattr(module, name, defaults_problem[name])) | 
| 27 | 133 if not module.dummyinname: | 
| 134 module.dummyinname = getattr(module, 'testcaseinname', module.dummyinname) | |
| 135 if not module.dummyoutname: | |
| 136 module.dummyoutname = getattr(module, 'testcaseoutname', module.dummyoutname) | |
| 21 | 137 if not hasattr(module, 'path'): | 
| 138 if hasattr(module, 'name'): | |
| 139 module.path = module.name | |
| 140 elif sys.platform != 'win32': | |
| 141 module.path = os.path.join(os.path.curdir, problem_name) | |
| 142 else: | |
| 143 module.path = problem_name | |
| 76 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 144 for name in 'pointmap', 'groupweight': | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 145 oldmap = getattr(module, name) | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 146 if isinstance(oldmap, dict): | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 147 newmap = {} | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 148 for key in oldmap: | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 149 if not options.legacy and isinstance(key, basestring): | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 150 newmap[key] = oldmap[key] | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 151 else: | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 152 try: | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 153 for k in key: | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 154 newmap[k] = oldmap[key] | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 155 except TypeError: | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 156 newmap[key] = oldmap[key] | 
| 
0e5ae28e0b2b
Points are now weighted on a test context basis
 Oleg Oshmyan <chortos@inbox.lv> parents: 
74diff
changeset | 157 setattr(module, name, newmap) | 
| 21 | 158 if options.no_maxtime: | 
| 82 
06356af50bf9
Finished testcases reorganization and CPU time limit implementation
 Oleg Oshmyan <chortos@inbox.lv> parents: 
79diff
changeset | 159 module.maxcputime = module.maxwalltime = 0 | 
| 83 | 160 try: | 
| 161 sys.dont_write_bytecode = dwb | |
| 162 except NameError: | |
| 163 pass | |
| 24 
c23d81f4a1a3
Score returned by TestCase.__call__() is now normalized to 0..1
 Oleg Oshmyan <chortos@inbox.lv> parents: 
22diff
changeset | 164 for name in patterns: | 
| 
c23d81f4a1a3
Score returned by TestCase.__call__() is now normalized to 0..1
 Oleg Oshmyan <chortos@inbox.lv> parents: 
22diff
changeset | 165 if hasattr(module, name): | 
| 
c23d81f4a1a3
Score returned by TestCase.__call__() is now normalized to 0..1
 Oleg Oshmyan <chortos@inbox.lv> parents: 
22diff
changeset | 166 setattr(module, name, getattr(module, name).replace('%', problem_name)) | 
| 
c23d81f4a1a3
Score returned by TestCase.__call__() is now normalized to 0..1
 Oleg Oshmyan <chortos@inbox.lv> parents: 
22diff
changeset | 167 return module | 
| 21 | 168 | 
| 169 def load_global(): | |
| 70 
b9d5857f7b9a
Better emulation of built-ins for testconf
 Oleg Oshmyan <chortos@inbox.lv> parents: 
60diff
changeset | 170 global builtins | 
| 83 | 171 try: | 
| 172 dwb = sys.dont_write_bytecode | |
| 173 sys.dont_write_bytecode = True | |
| 174 except AttributeError: | |
| 175 pass | |
| 21 | 176 metafile = files.File('testconf.py', True, 'configuration') | 
| 177 module = None | |
| 70 
b9d5857f7b9a
Better emulation of built-ins for testconf
 Oleg Oshmyan <chortos@inbox.lv> parents: 
60diff
changeset | 178 with CompatBuiltins() as builtins: | 
| 25 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 179 if zipimport and isinstance(metafile.archive, files.ZipArchive): | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 180 try: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 181 module = zipimport.zipimporter(os.path.dirname(metafile.full_real_path)).load_module('testconf') | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 182 except zipimport.ZipImportError: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 183 pass | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 184 else: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 185 del sys.modules['testconf'] | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 186 if not module: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 187 try: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 188 with metafile.open() as f: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 189 module = imp.load_module('testconf', f, metafile.full_real_path, ('.py', 'r', imp.PY_SOURCE)) | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 190 # Handle the case when f is not a true file object but imp requires one | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 191 except ValueError: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 192 # FIXME: 2.5 lacks the delete parameter | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 193 with tempfile.NamedTemporaryFile(delete=False) as f: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 194 inputdatafname = f.name | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 195 metafile.copy(inputdatafname) | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 196 with ReadDeleting(inputdatafname) as f: | 
| 
b500e117080e
Bug fixes and overhead reduction
 Oleg Oshmyan <chortos@inbox.lv> parents: 
24diff
changeset | 197 module = imp.load_module('testconf', f, metafile.full_real_path, ('.py', 'r', imp.PY_SOURCE)) | 
| 21 | 198 del sys.modules['testconf'] | 
| 199 for name in defaults_global: | |
| 200 setattr(module, name, getattr(module, name, defaults_global[name])) | |
| 43 | 201 if not options.erase: | 
| 202 for name in defaults_noerase: | |
| 203 setattr(module, name, getattr(module, name, defaults_noerase[name])) | |
| 79 
ee8a99dcaaed
Renamed configuration variable tasknames to problems
 Oleg Oshmyan <chortos@inbox.lv> parents: 
78diff
changeset | 204 if hasattr(module, 'tasknames'): | 
| 
ee8a99dcaaed
Renamed configuration variable tasknames to problems
 Oleg Oshmyan <chortos@inbox.lv> parents: 
78diff
changeset | 205 module.problems = module.tasknames | 
| 21 | 206 global globalconf | 
| 207 globalconf = module | |
| 83 | 208 try: | 
| 209 sys.dont_write_bytecode = dwb | |
| 210 except NameError: | |
| 211 pass | |
| 21 | 212 return module | 
