aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJack Lloyd <[email protected]>2017-09-29 12:32:59 -0400
committerJack Lloyd <[email protected]>2017-09-29 12:32:59 -0400
commitd839b27c7f7b81ab44c4044f1de66dfd9ef205c4 (patch)
tree03d9555a3ae436a061fb6ab0f619393e719aa579 /src
parentfd95d06f4e050a2efc3cb79c69f1ea3d04bacb27 (diff)
Build script work
[ci skip]
Diffstat (limited to 'src')
-rwxr-xr-xsrc/scripts/build_tests.py40
1 files changed, 29 insertions, 11 deletions
diff --git a/src/scripts/build_tests.py b/src/scripts/build_tests.py
index c83eb7cdd..20160c587 100755
--- a/src/scripts/build_tests.py
+++ b/src/scripts/build_tests.py
@@ -1,4 +1,4 @@
-#!/usr/bin/python3
+#!/usr/bin/python
"""
This configures and builds with many different sub-configurations
@@ -11,6 +11,7 @@ There is probably no reason for you to run this. Unless you want to.
Botan is released under the Simplified BSD License (see license.txt)
"""
+import optparse # pylint: disable=deprecated-module
import sys
import subprocess
@@ -24,6 +25,7 @@ def get_module_list(configure_py):
modules = [s.decode('ascii') for s in stdout.split()]
modules.remove('bearssl') # can't test
+ modules.remove('tpm') # can't test
modules.remove('base') # can't remove
return modules
@@ -38,19 +40,22 @@ def get_concurrency():
def try_to_run(cmdline):
print("Running %s ... " % (' '.join(cmdline)))
+ sys.stdout.flush()
+
cmd = subprocess.Popen(cmdline, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
(stdout, stderr) = cmd.communicate()
- if cmd.returncode != 0:
+ failed = (cmd.returncode != 0)
+
+ if failed:
print("FAILURE")
print(stdout.decode('ascii'))
print(stderr.decode('ascii'))
+ sys.stdout.flush()
- sys.stdout.flush()
-
- return (cmd.returncode == 0)
+ return failed
-def run_test_build(configure_py, modules, include, run_tests = False):
+def run_test_build(configure_py, modules, include, run_tests=False):
config = [configure_py]
if include:
@@ -75,26 +80,39 @@ def main(args):
# TODO take configure.py and botan-test paths via options
+ parser = optparse.OptionParser()
+
+ parser.add_option('--run-tests', default=False, action='store_true')
+
+ (options, args) = parser.parse_args(args)
+
+ run_tests = options.run_tests
+
configure_py = './configure.py'
modules = get_module_list(configure_py)
- cant_disable = ['block', 'hash', 'hex', 'mac', 'modes', 'rng', 'stream', 'utils']
+ cant_disable = ['block', 'hash', 'hex', 'mac', 'modes', 'rng', 'stream', 'utils', 'cpuid', 'entropy']
always_include = ['sha2_32', 'sha2_64', 'aes']
+ failed = []
+
for module in sorted(modules):
- continue
- if module in always_include or module in cant_disable:
+ if (module in always_include) or (module in cant_disable):
continue # already testing it
extra = []
if module == 'auto_rng':
extra.append('dev_random')
- run_test_build(configure_py, [module] + always_include + extra, True)
+ if run_test_build(configure_py, [module] + always_include + extra, run_tests) is False:
+ failed.append(module)
for module in sorted(modules):
if module in cant_disable or module in always_include:
continue
- run_test_build(configure_py, [module], False)
+ if run_test_build(configure_py, [module], run_tests) is False:
+ failed.append(module)
+
+ print("Failed building with %s", ' '.join(failed))
if __name__ == '__main__':