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
|
|
|
|
|
2015-09-09 23:53:36 +02:00
|
|
|
import mock
|
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-09-09 23:53:36 +02:00
|
|
|
from compose.cli.log_printer import wait_on_exit
|
|
|
|
from compose.container import Container
|
2015-08-25 22:49:49 +02:00
|
|
|
from tests import unittest
|
2014-06-18 15:50:57 +02:00
|
|
|
|
|
|
|
|
2015-09-09 23:53:36 +02:00
|
|
|
def build_mock_container(reader):
|
|
|
|
return mock.Mock(
|
|
|
|
spec=Container,
|
|
|
|
name='myapp_web_1',
|
|
|
|
name_without_project='web_1',
|
|
|
|
has_api_logs=True,
|
|
|
|
attach=reader,
|
|
|
|
wait=mock.Mock(return_value=0),
|
|
|
|
)
|
|
|
|
|
|
|
|
|
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"
|
2015-09-09 23:53:36 +02:00
|
|
|
container = build_mock_container(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
|
|
|
|
2015-09-09 23:53:36 +02:00
|
|
|
container = build_mock_container(reader)
|
2014-06-18 15:50:57 +02:00
|
|
|
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
|
|
|
|
2015-09-09 23:53:36 +02:00
|
|
|
def test_wait_on_exit(self):
|
|
|
|
exit_status = 3
|
|
|
|
mock_container = mock.Mock(
|
|
|
|
spec=Container,
|
|
|
|
name='cname',
|
|
|
|
wait=mock.Mock(return_value=exit_status))
|
2014-06-18 15:50:57 +02:00
|
|
|
|
2015-09-09 23:53:36 +02:00
|
|
|
expected = '{} exited with code {}\n'.format(mock_container.name, exit_status)
|
|
|
|
self.assertEqual(expected, wait_on_exit(mock_container))
|
2014-06-18 15:50:57 +02:00
|
|
|
|
2015-09-09 23:53:36 +02:00
|
|
|
def test_generator_with_no_logs(self):
|
|
|
|
mock_container = mock.Mock(
|
|
|
|
spec=Container,
|
|
|
|
has_api_logs=False,
|
|
|
|
log_driver='none',
|
|
|
|
name_without_project='web_1',
|
|
|
|
wait=mock.Mock(return_value=0))
|
2014-06-18 15:50:57 +02:00
|
|
|
|
2015-09-09 23:53:36 +02:00
|
|
|
output = run_log_printer([mock_container])
|
|
|
|
self.assertIn(
|
|
|
|
"WARNING: no logs are available with the 'none' log driver\n",
|
|
|
|
output
|
|
|
|
)
|
2014-06-18 15:50:57 +02:00
|
|
|
|
|
|
|
|
2015-09-09 23:53:36 +02:00
|
|
|
def run_log_printer(containers, monochrome=False):
|
|
|
|
output = six.StringIO()
|
|
|
|
LogPrinter(containers, output=output, monochrome=monochrome).run()
|
|
|
|
return output.getvalue()
|