resulttool 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  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 perform regression file analysis, execute the below
  19. # $ resulttool regression-file <base_result_file> <target_result_file>
  20. #
  21. # To execute manual test cases, execute the below
  22. # $ resulttool manualexecution <manualjsonfile>
  23. #
  24. # By default testresults.json for manualexecution store in <build>/tmp/log/manual/
  25. #
  26. # Copyright (c) 2019, Intel Corporation.
  27. #
  28. # This program is free software; you can redistribute it and/or modify it
  29. # under the terms and conditions of the GNU General Public License,
  30. # version 2, as published by the Free Software Foundation.
  31. #
  32. # This program is distributed in the hope it will be useful, but WITHOUT
  33. # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  34. # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  35. # more details.
  36. #
  37. import os
  38. import sys
  39. import argparse
  40. import logging
  41. script_path = os.path.dirname(os.path.realpath(__file__))
  42. lib_path = script_path + '/lib'
  43. sys.path = sys.path + [lib_path]
  44. import argparse_oe
  45. import scriptutils
  46. import resulttool.merge
  47. import resulttool.store
  48. import resulttool.regression
  49. import resulttool.report
  50. import resulttool.manualexecution
  51. logger = scriptutils.logger_create('resulttool')
  52. def _validate_user_input_arguments(args):
  53. if hasattr(args, "source_dir"):
  54. if not os.path.isdir(args.source_dir):
  55. logger.error('source_dir argument need to be a directory : %s' % args.source_dir)
  56. return False
  57. return True
  58. def main():
  59. parser = argparse_oe.ArgumentParser(description="OEQA test result manipulation tool.",
  60. epilog="Use %(prog)s <subcommand> --help to get help on a specific command")
  61. parser.add_argument('-d', '--debug', help='enable debug output', action='store_true')
  62. parser.add_argument('-q', '--quiet', help='print only errors', action='store_true')
  63. subparsers = parser.add_subparsers(dest="subparser_name", title='subcommands', metavar='<subcommand>')
  64. subparsers.required = True
  65. subparsers.add_subparser_group('manualexecution', 'manual testcases', 300)
  66. resulttool.manualexecution.register_commands(subparsers)
  67. subparsers.add_subparser_group('setup', 'setup', 200)
  68. resulttool.merge.register_commands(subparsers)
  69. resulttool.store.register_commands(subparsers)
  70. subparsers.add_subparser_group('analysis', 'analysis', 100)
  71. resulttool.regression.register_commands(subparsers)
  72. resulttool.report.register_commands(subparsers)
  73. args = parser.parse_args()
  74. if args.debug:
  75. logger.setLevel(logging.DEBUG)
  76. elif args.quiet:
  77. logger.setLevel(logging.ERROR)
  78. if not _validate_user_input_arguments(args):
  79. return -1
  80. try:
  81. ret = args.func(args, logger)
  82. except argparse_oe.ArgumentUsageError as ae:
  83. parser.error_subcommand(ae.message, ae.subcommand)
  84. return ret
  85. if __name__ == "__main__":
  86. sys.exit(main())