2014-10-18 19:54:04 +02:00
|
|
|
from __future__ import absolute_import
|
2015-08-24 21:25:25 +02:00
|
|
|
from __future__ import unicode_literals
|
2014-10-18 19:54:04 +02:00
|
|
|
|
|
|
|
from six import StringIO
|
|
|
|
|
2015-03-26 04:13:01 +01:00
|
|
|
from compose import progress_stream
|
2015-08-24 21:25:25 +02:00
|
|
|
from tests import unittest
|
2014-10-18 19:54:04 +02:00
|
|
|
|
|
|
|
|
|
|
|
class ProgressStreamTestCase(unittest.TestCase):
|
|
|
|
def test_stream_output(self):
|
|
|
|
output = [
|
2015-08-24 19:16:13 +02:00
|
|
|
b'{"status": "Downloading", "progressDetail": {"current": '
|
|
|
|
b'31019763, "start": 1413653874, "total": 62763875}, '
|
|
|
|
b'"progress": "..."}',
|
2014-10-18 19:54:04 +02:00
|
|
|
]
|
|
|
|
events = progress_stream.stream_output(output, StringIO())
|
|
|
|
self.assertEqual(len(events), 1)
|
2015-05-26 21:25:52 +02:00
|
|
|
|
|
|
|
def test_stream_output_div_zero(self):
|
|
|
|
output = [
|
2015-08-24 19:16:13 +02:00
|
|
|
b'{"status": "Downloading", "progressDetail": {"current": '
|
|
|
|
b'0, "start": 1413653874, "total": 0}, '
|
|
|
|
b'"progress": "..."}',
|
2015-05-26 21:25:52 +02:00
|
|
|
]
|
|
|
|
events = progress_stream.stream_output(output, StringIO())
|
|
|
|
self.assertEqual(len(events), 1)
|
|
|
|
|
|
|
|
def test_stream_output_null_total(self):
|
|
|
|
output = [
|
2015-08-24 19:16:13 +02:00
|
|
|
b'{"status": "Downloading", "progressDetail": {"current": '
|
|
|
|
b'0, "start": 1413653874, "total": null}, '
|
|
|
|
b'"progress": "..."}',
|
2015-05-26 21:25:52 +02:00
|
|
|
]
|
|
|
|
events = progress_stream.stream_output(output, StringIO())
|
|
|
|
self.assertEqual(len(events), 1)
|
2015-11-04 23:40:57 +01:00
|
|
|
|
|
|
|
def test_stream_output_progress_event_tty(self):
|
|
|
|
events = [
|
|
|
|
b'{"status": "Already exists", "progressDetail": {}, "id": "8d05e3af52b0"}'
|
|
|
|
]
|
|
|
|
|
|
|
|
class TTYStringIO(StringIO):
|
|
|
|
def isatty(self):
|
|
|
|
return True
|
|
|
|
|
|
|
|
output = TTYStringIO()
|
|
|
|
events = progress_stream.stream_output(events, output)
|
|
|
|
self.assertTrue(len(output.getvalue()) > 0)
|
|
|
|
|
|
|
|
def test_stream_output_progress_event_no_tty(self):
|
|
|
|
events = [
|
|
|
|
b'{"status": "Already exists", "progressDetail": {}, "id": "8d05e3af52b0"}'
|
|
|
|
]
|
|
|
|
output = StringIO()
|
|
|
|
|
|
|
|
events = progress_stream.stream_output(events, output)
|
|
|
|
self.assertEqual(len(output.getvalue()), 0)
|
|
|
|
|
|
|
|
def test_stream_output_no_progress_event_no_tty(self):
|
|
|
|
events = [
|
|
|
|
b'{"status": "Pulling from library/xy", "id": "latest"}'
|
|
|
|
]
|
|
|
|
output = StringIO()
|
|
|
|
|
|
|
|
events = progress_stream.stream_output(events, output)
|
|
|
|
self.assertTrue(len(output.getvalue()) > 0)
|
2016-06-14 22:55:48 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_get_digest_from_push():
|
|
|
|
digest = "sha256:abcd"
|
|
|
|
events = [
|
|
|
|
{"status": "..."},
|
|
|
|
{"status": "..."},
|
|
|
|
{"progressDetail": {}, "aux": {"Digest": digest}},
|
|
|
|
]
|
|
|
|
assert progress_stream.get_digest_from_push(events) == digest
|
|
|
|
|
|
|
|
|
|
|
|
def test_get_digest_from_pull():
|
|
|
|
digest = "sha256:abcd"
|
|
|
|
events = [
|
|
|
|
{"status": "..."},
|
|
|
|
{"status": "..."},
|
|
|
|
{"status": "Digest: %s" % digest},
|
|
|
|
]
|
|
|
|
assert progress_stream.get_digest_from_pull(events) == digest
|