bitbake-selftest 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. #!/usr/bin/env python3
  2. #
  3. # Copyright (C) 2012 Richard Purdie
  4. #
  5. # SPDX-License-Identifier: GPL-2.0-only
  6. #
  7. import os
  8. import sys, logging
  9. import warnings
  10. warnings.simplefilter("default")
  11. sys.path.insert(0, os.path.join(os.path.dirname(os.path.dirname(__file__)), 'lib'))
  12. import unittest
  13. try:
  14. import bb
  15. import hashserv
  16. import prserv
  17. import layerindexlib
  18. except RuntimeError as exc:
  19. sys.exit(str(exc))
  20. tests = ["bb.tests.codeparser",
  21. "bb.tests.color",
  22. "bb.tests.cooker",
  23. "bb.tests.cow",
  24. "bb.tests.data",
  25. "bb.tests.event",
  26. "bb.tests.fetch",
  27. "bb.tests.parse",
  28. "bb.tests.runqueue",
  29. "bb.tests.siggen",
  30. "bb.tests.utils",
  31. "bb.tests.compression",
  32. "hashserv.tests",
  33. "prserv.tests",
  34. "layerindexlib.tests.layerindexobj",
  35. "layerindexlib.tests.restapi",
  36. "layerindexlib.tests.cooker"]
  37. for t in tests:
  38. t = '.'.join(t.split('.')[:3])
  39. __import__(t)
  40. # Set-up logging
  41. class StdoutStreamHandler(logging.StreamHandler):
  42. """Special handler so that unittest is able to capture stdout"""
  43. def __init__(self):
  44. # Override __init__() because we don't want to set self.stream here
  45. logging.Handler.__init__(self)
  46. @property
  47. def stream(self):
  48. # We want to dynamically write wherever sys.stdout is pointing to
  49. return sys.stdout
  50. handler = StdoutStreamHandler()
  51. bb.logger.addHandler(handler)
  52. bb.logger.setLevel(logging.DEBUG)
  53. ENV_HELP = """\
  54. Environment variables:
  55. BB_SKIP_NETTESTS set to 'yes' in order to skip tests using network
  56. connection
  57. BB_TMPDIR_NOCLEAN set to 'yes' to preserve test tmp directories
  58. """
  59. class main(unittest.main):
  60. def _print_help(self, *args, **kwargs):
  61. super(main, self)._print_help(*args, **kwargs)
  62. print(ENV_HELP)
  63. if __name__ == '__main__':
  64. main(defaultTest=tests, buffer=True)