2014-06-18 15:50:57 +02:00
|
|
|
from __future__ import absolute_import
|
2015-08-24 21:25:25 +02:00
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
2014-06-18 15:50:57 +02:00
|
|
|
import os
|
|
|
|
|
2014-08-19 23:36:46 +02:00
|
|
|
import six
|
|
|
|
|
2015-08-24 21:25:25 +02:00
|
|
|
from compose.cli.log_printer import LogPrinter
|
2015-08-25 22:49:49 +02:00
|
|
|
from tests import unittest
|
2014-06-18 15:50:57 +02:00
|
|
|
|
|
|
|
|
|
|
|
class LogPrinterTest(unittest.TestCase):
|
2014-08-07 06:03:29 +02:00
|
|
|
def get_default_output(self, monochrome=False):
|
2014-06-18 15:50:57 +02:00
|
|
|
def reader(*args, **kwargs):
|
2015-08-25 23:17:12 +02:00
|
|
|
yield b"hello\nworld"
|
2014-06-18 15:50:57 +02:00
|
|
|
|
|
|
|
container = MockContainer(reader)
|
2014-08-07 06:03:29 +02:00
|
|
|
output = run_log_printer([container], monochrome=monochrome)
|
|
|
|
return output
|
|
|
|
|
|
|
|
def test_single_container(self):
|
|
|
|
output = self.get_default_output()
|
2014-06-18 15:50:57 +02:00
|
|
|
|
|
|
|
self.assertIn('hello', output)
|
|
|
|
self.assertIn('world', output)
|
|
|
|
|
2014-08-07 06:03:29 +02:00
|
|
|
def test_monochrome(self):
|
|
|
|
output = self.get_default_output(monochrome=True)
|
|
|
|
self.assertNotIn('\033[', output)
|
|
|
|
|
|
|
|
def test_polychrome(self):
|
|
|
|
output = self.get_default_output()
|
|
|
|
self.assertIn('\033[', output)
|
|
|
|
|
2014-06-18 15:50:57 +02:00
|
|
|
def test_unicode(self):
|
2014-08-19 23:36:46 +02:00
|
|
|
glyph = u'\u2022'
|
2014-06-18 15:50:57 +02:00
|
|
|
|
|
|
|
def reader(*args, **kwargs):
|
2015-08-25 23:17:12 +02:00
|
|
|
yield glyph.encode('utf-8') + b'\n'
|
2014-06-18 15:50:57 +02:00
|
|
|
|
|
|
|
container = MockContainer(reader)
|
|
|
|
output = run_log_printer([container])
|
2015-08-24 18:43:08 +02:00
|
|
|
if six.PY2:
|
|
|
|
output = output.decode('utf-8')
|
|
|
|
|
|
|
|
self.assertIn(glyph, output)
|
2014-06-18 15:50:57 +02:00
|
|
|
|
|
|
|
|
2014-08-07 06:03:29 +02:00
|
|
|
def run_log_printer(containers, monochrome=False):
|
2014-06-18 15:50:57 +02:00
|
|
|
r, w = os.pipe()
|
|
|
|
reader, writer = os.fdopen(r, 'r'), os.fdopen(w, 'w')
|
2014-08-07 06:03:29 +02:00
|
|
|
printer = LogPrinter(containers, output=writer, monochrome=monochrome)
|
2014-06-18 15:50:57 +02:00
|
|
|
printer.run()
|
|
|
|
writer.close()
|
|
|
|
return reader.read()
|
|
|
|
|
|
|
|
|
|
|
|
class MockContainer(object):
|
|
|
|
def __init__(self, reader):
|
|
|
|
self._reader = reader
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
return 'myapp_web_1'
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name_without_project(self):
|
|
|
|
return 'web_1'
|
|
|
|
|
|
|
|
def attach(self, *args, **kwargs):
|
|
|
|
return self._reader()
|
|
|
|
|
|
|
|
def wait(self, *args, **kwargs):
|
|
|
|
return 0
|