Run demo scripts and check that they work

run_demos.py is the frontend to a framework for smoke-testing the
sample programs. It runs scripts called programs/*/*_demo.sh
("demo scripts") and check that they succeed. A typical demo script
runs one sample program or a combination of sample programs to
demonstrate their usage.

Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com>
This commit is contained in:
Gilles Peskine 2019-06-14 18:23:03 +02:00
parent 17526a0d16
commit 2fcf04f468

41
tests/scripts/run_demos.py Executable file
View file

@ -0,0 +1,41 @@
#!/usr/bin/env python3
"""Run the Mbed TLS demo scripts.
"""
import glob
import subprocess
import sys
def run_demo(demo):
"""Run the specified demo script. Return True if it succeeds."""
returncode = subprocess.call([demo])
return returncode == 0
def run_demos(demos):
"""Run the specified demos and print summary information about failures.
Return True if all demos passed and False if a demo fails.
"""
failures = []
for demo in demos:
print('#### {} ####'.format(demo))
if not run_demo(demo):
failures.append(demo)
print('{}: FAIL'.format(demo))
print('')
successes = len(demos) - len(failures)
print('{}/{} demos passed'.format(successes, len(demos)))
if failures:
print('Failures:', *failures)
return not failures
def run_all_demos():
"""Run all the available demos.
Return True if all demos passed and False if a demo fails.
"""
all_demos = glob.glob('programs/*/*_demo.sh')
return run_demos(all_demos)
if __name__ == '__main__':
if not run_all_demos():
sys.exit(1)