Python Library Unittest

output.py 1.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. #
  4. #
  5. # STATUS_KEYS
  6. #
  7. STATUS_AVAILABLE = 'AVAILABLE'
  8. STATUS_CLEAN = 'CLEAN'
  9. STATUS_RELEASED = 'RELEASED'
  10. STATUS_SUCCESS = 'SUCCESS'
  11. #
  12. STATUS_CHANGED = 'CHANGED'
  13. STATUS_EXISTS = 'EXISTS'
  14. STATUS_IN_WORK = 'IN_WORK'
  15. STATUS_OLD = 'OLD'
  16. #
  17. STATUS_FAILED = 'FAILED'
  18. STATUS_MISSING = 'MISSING'
  19. STATUS_UNKNOWN = 'UNKNOWN'
  20. class termcolors:
  21. HEADER = '\033[95m'
  22. OKBLUE = '\033[94m'
  23. OKGREEN = '\033[92m'
  24. WARNING = '\033[93m'
  25. FAIL = '\033[91m'
  26. ENDC = '\033[0m'
  27. BOLD = '\033[1m'
  28. UNDERLINE = '\033[4m'
  29. STATUS_COLORS = {
  30. STATUS_AVAILABLE: termcolors.OKGREEN,
  31. STATUS_CLEAN: termcolors.OKGREEN,
  32. STATUS_RELEASED: termcolors.OKGREEN,
  33. STATUS_SUCCESS: termcolors.OKGREEN,
  34. #
  35. STATUS_CHANGED: termcolors.WARNING,
  36. STATUS_EXISTS: termcolors.WARNING,
  37. STATUS_IN_WORK: termcolors.WARNING,
  38. STATUS_OLD: termcolors.WARNING,
  39. #
  40. STATUS_FAILED: termcolors.FAIL,
  41. STATUS_MISSING: termcolors.FAIL,
  42. STATUS_UNKNOWN: termcolors.FAIL,
  43. }
  44. def print_header(txt):
  45. print(termcolors.BOLD + termcolors.WARNING + txt + termcolors.ENDC)
  46. def print_action(txt):
  47. print(termcolors.BOLD + ' * ' + txt + termcolors.ENDC)
  48. def status_output(txt, default_color):
  49. return STATUS_COLORS.get(txt, default_color) + txt + termcolors.ENDC
  50. def print_info(txt, default_color=termcolors.ENDC):
  51. print(' ' + status_output(txt, default_color))
  52. def coverage_output(lcov, bcov, length=None):
  53. if lcov is None or bcov is None:
  54. return (length - len(STATUS_UNKNOWN)) * ' ' + status_output(STATUS_UNKNOWN, termcolors.FAIL)
  55. elif lcov > 90:
  56. rv = termcolors.OKGREEN + '%3d%% (%3d%%)' % (lcov, bcov) + termcolors.ENDC
  57. else:
  58. rv = termcolors.WARNING + '%3d%% (%3d%%)' % (lcov, bcov) + termcolors.ENDC
  59. if length is None:
  60. return rv
  61. else:
  62. return (length - 11) * ' ' + rv
  63. def print_coverage(lcov, bcov):
  64. print(' ' + coverage_output(lcov, bcov))