blob: 6d86a9bf2304cb82219d48b774f4715be4eb5f82 [file] [log] [blame]
Gilles Peskine2fcf04f2019-06-14 18:23:03 +02001#!/usr/bin/env python3
2"""Run the Mbed TLS demo scripts.
3"""
Gilles Peskine9fdc6572020-04-26 22:51:05 +02004import argparse
Gilles Peskine2fcf04f2019-06-14 18:23:03 +02005import glob
6import subprocess
7import sys
8
Gilles Peskine9fdc6572020-04-26 22:51:05 +02009def run_demo(demo, quiet=False):
Gilles Peskine2fcf04f2019-06-14 18:23:03 +020010 """Run the specified demo script. Return True if it succeeds."""
Gilles Peskine9fdc6572020-04-26 22:51:05 +020011 args = {}
12 if quiet:
13 args['stdout'] = subprocess.DEVNULL
14 args['stderr'] = subprocess.DEVNULL
15 returncode = subprocess.call([demo], **args)
Gilles Peskine2fcf04f2019-06-14 18:23:03 +020016 return returncode == 0
17
Gilles Peskine9fdc6572020-04-26 22:51:05 +020018def run_demos(demos, quiet=False):
Gilles Peskine2fcf04f2019-06-14 18:23:03 +020019 """Run the specified demos and print summary information about failures.
20
21 Return True if all demos passed and False if a demo fails.
22 """
23 failures = []
24 for demo in demos:
Gilles Peskine9fdc6572020-04-26 22:51:05 +020025 if not quiet:
26 print('#### {} ####'.format(demo))
27 success = run_demo(demo, quiet=quiet)
Gilles Peskine198d87a2020-04-26 22:33:48 +020028 if not success:
Gilles Peskine2fcf04f2019-06-14 18:23:03 +020029 failures.append(demo)
Gilles Peskine9fdc6572020-04-26 22:51:05 +020030 if not quiet:
31 print('{}: FAIL'.format(demo))
32 if not quiet:
33 print('')
Gilles Peskine2fcf04f2019-06-14 18:23:03 +020034 successes = len(demos) - len(failures)
35 print('{}/{} demos passed'.format(successes, len(demos)))
36 if failures:
37 print('Failures:', *failures)
38 return not failures
39
Gilles Peskine9fdc6572020-04-26 22:51:05 +020040def run_all_demos(quiet=False):
Gilles Peskine2fcf04f2019-06-14 18:23:03 +020041 """Run all the available demos.
42
43 Return True if all demos passed and False if a demo fails.
44 """
45 all_demos = glob.glob('programs/*/*_demo.sh')
Gilles Peskine1b015592020-04-27 10:39:20 +020046 if not all_demos:
47 raise Exception('No demos found. run_demos needs to operate from the Mbed TLS toplevel directory.')
Gilles Peskine9fdc6572020-04-26 22:51:05 +020048 return run_demos(all_demos, quiet=quiet)
Gilles Peskine2fcf04f2019-06-14 18:23:03 +020049
Gilles Peskine198d87a2020-04-26 22:33:48 +020050def main():
Gilles Peskine9fdc6572020-04-26 22:51:05 +020051 parser = argparse.ArgumentParser(description=__doc__)
52 parser.add_argument('--quiet', '-q',
53 action='store_true',
54 help="suppress the output of demos")
55 options = parser.parse_args()
56 success = run_all_demos(quiet=options.quiet)
Gilles Peskine198d87a2020-04-26 22:33:48 +020057 sys.exit(0 if success else 1)
58
Gilles Peskine2fcf04f2019-06-14 18:23:03 +020059if __name__ == '__main__':
Gilles Peskine198d87a2020-04-26 22:33:48 +020060 main()