resulttool 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. #!/usr/bin/env python3
  2. #
  3. # test results tool - tool for manipulating OEQA test result json files
  4. # (merge results, summarise results, regression analysis, generate manual test results file)
  5. #
  6. # To look for help information.
  7. # $ resulttool
  8. #
  9. # To store test results from oeqa automated tests, execute the below
  10. # $ resulttool store <source_dir> <git_branch>
  11. #
  12. # To merge test results, execute the below
  13. # $ resulttool merge <base_result_file> <target_result_file>
  14. #
  15. # To report test report, execute the below
  16. # $ resulttool report <source_dir>
  17. #
  18. # To create a unit test report in JUnit XML format, execute the below
  19. # $ resulttool junit <json_file>
  20. #
  21. # To perform regression file analysis, execute the below
  22. # $ resulttool regression-file <base_result_file> <target_result_file>
  23. #
  24. # To execute manual test cases, execute the below
  25. # $ resulttool manualexecution <manualjsonfile>
  26. #
  27. # By default testresults.json for manualexecution store in <build>/tmp/log/manual/
  28. #
  29. # Copyright (c) 2019, Intel Corporation.
  30. #
  31. # SPDX-License-Identifier: GPL-2.0-only
  32. #
  33. import os
  34. import sys
  35. import argparse
  36. import logging
  37. script_path = os.path.dirname(os.path.realpath(__file__))
  38. lib_path = script_path + '/lib'
  39. sys.path = sys.path + [lib_path]
  40. import argparse_oe
  41. import scriptutils
  42. import resulttool.merge
  43. import resulttool.store
  44. import resulttool.regression
  45. import resulttool.report
  46. import resulttool.manualexecution
  47. import resulttool.log
  48. import resulttool.junit
  49. logger = scriptutils.logger_create('resulttool')
  50. def main():
  51. parser = argparse_oe.ArgumentParser(description="OEQA test result manipulation tool.",
  52. epilog="Use %(prog)s <subcommand> --help to get help on a specific command")
  53. parser.add_argument('-d', '--debug', help='enable debug output', action='store_true')
  54. parser.add_argument('-q', '--quiet', help='print only errors', action='store_true')
  55. subparsers = parser.add_subparsers(dest="subparser_name", title='subcommands', metavar='<subcommand>')
  56. subparsers.required = True
  57. subparsers.add_subparser_group('manualexecution', 'manual testcases', 300)
  58. resulttool.manualexecution.register_commands(subparsers)
  59. subparsers.add_subparser_group('setup', 'setup', 200)
  60. resulttool.merge.register_commands(subparsers)
  61. resulttool.store.register_commands(subparsers)
  62. subparsers.add_subparser_group('analysis', 'analysis', 100)
  63. resulttool.regression.register_commands(subparsers)
  64. resulttool.report.register_commands(subparsers)
  65. resulttool.log.register_commands(subparsers)
  66. resulttool.junit.register_commands(subparsers)
  67. args = parser.parse_args()
  68. if args.debug:
  69. logger.setLevel(logging.DEBUG)
  70. elif args.quiet:
  71. logger.setLevel(logging.ERROR)
  72. try:
  73. ret = args.func(args, logger)
  74. except argparse_oe.ArgumentUsageError as ae:
  75. parser.error_subcommand(ae.message, ae.subcommand)
  76. return ret
  77. if __name__ == "__main__":
  78. sys.exit(main())