log_printer_test.py 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. from __future__ import absolute_import
  2. from __future__ import unicode_literals
  3. import os
  4. import six
  5. from .. import unittest
  6. from compose.cli.log_printer import LogPrinter
  7. class LogPrinterTest(unittest.TestCase):
  8. def get_default_output(self, monochrome=False):
  9. def reader(*args, **kwargs):
  10. yield "hello\nworld"
  11. container = MockContainer(reader)
  12. output = run_log_printer([container], monochrome=monochrome)
  13. return output
  14. def test_single_container(self):
  15. output = self.get_default_output()
  16. self.assertIn('hello', output)
  17. self.assertIn('world', output)
  18. def test_monochrome(self):
  19. output = self.get_default_output(monochrome=True)
  20. self.assertNotIn('\033[', output)
  21. def test_polychrome(self):
  22. output = self.get_default_output()
  23. self.assertIn('\033[', output)
  24. @unittest.skipIf(six.PY3, "Only test unicode in python2")
  25. def test_unicode(self):
  26. glyph = u'\u2022'
  27. def reader(*args, **kwargs):
  28. yield glyph + '\n'
  29. container = MockContainer(reader)
  30. output = run_log_printer([container])
  31. self.assertIn(glyph, output.decode('utf-8'))
  32. def run_log_printer(containers, monochrome=False):
  33. r, w = os.pipe()
  34. reader, writer = os.fdopen(r, 'r'), os.fdopen(w, 'w')
  35. printer = LogPrinter(containers, output=writer, monochrome=monochrome)
  36. printer.run()
  37. writer.close()
  38. return reader.read()
  39. class MockContainer(object):
  40. def __init__(self, reader):
  41. self._reader = reader
  42. @property
  43. def name(self):
  44. return 'myapp_web_1'
  45. @property
  46. def name_without_project(self):
  47. return 'web_1'
  48. def attach(self, *args, **kwargs):
  49. return self._reader()
  50. def wait(self, *args, **kwargs):
  51. return 0