2018-03-16 00:22:28 +01:00
|
|
|
# ~*~ encoding: utf-8 ~*~
|
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
|
|
|
|
2018-03-16 00:22:28 +01:00
|
|
|
import io
|
|
|
|
import os
|
|
|
|
import random
|
|
|
|
import shutil
|
|
|
|
import tempfile
|
|
|
|
|
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
|
|
|
]
|
2018-07-21 00:37:15 +02:00
|
|
|
events = list(progress_stream.stream_output(output, StringIO()))
|
2018-01-04 22:01:54 +01:00
|
|
|
assert 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
|
|
|
]
|
2018-07-21 00:37:15 +02:00
|
|
|
events = list(progress_stream.stream_output(output, StringIO()))
|
2018-01-04 22:01:54 +01:00
|
|
|
assert len(events) == 1
|
2015-05-26 21:25:52 +02:00
|
|
|
|
|
|
|
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
|
|
|
]
|
2018-07-21 00:37:15 +02:00
|
|
|
events = list(progress_stream.stream_output(output, StringIO()))
|
2018-01-04 22:01:54 +01:00
|
|
|
assert 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()
|
2018-07-21 00:37:15 +02:00
|
|
|
events = list(progress_stream.stream_output(events, output))
|
2018-01-04 22:01:54 +01:00
|
|
|
assert len(output.getvalue()) > 0
|
2015-11-04 23:40:57 +01:00
|
|
|
|
|
|
|
def test_stream_output_progress_event_no_tty(self):
|
|
|
|
events = [
|
|
|
|
b'{"status": "Already exists", "progressDetail": {}, "id": "8d05e3af52b0"}'
|
|
|
|
]
|
|
|
|
output = StringIO()
|
|
|
|
|
2018-07-21 00:37:15 +02:00
|
|
|
events = list(progress_stream.stream_output(events, output))
|
2018-01-04 22:01:54 +01:00
|
|
|
assert len(output.getvalue()) == 0
|
2015-11-04 23:40:57 +01:00
|
|
|
|
|
|
|
def test_stream_output_no_progress_event_no_tty(self):
|
|
|
|
events = [
|
|
|
|
b'{"status": "Pulling from library/xy", "id": "latest"}'
|
|
|
|
]
|
|
|
|
output = StringIO()
|
|
|
|
|
2018-07-21 00:37:15 +02:00
|
|
|
events = list(progress_stream.stream_output(events, output))
|
2018-01-04 22:01:54 +01:00
|
|
|
assert len(output.getvalue()) > 0
|
2016-06-14 22:55:48 +02:00
|
|
|
|
2018-03-16 00:22:28 +01:00
|
|
|
def test_mismatched_encoding_stream_write(self):
|
|
|
|
tmpdir = tempfile.mkdtemp()
|
|
|
|
self.addCleanup(shutil.rmtree, tmpdir, True)
|
|
|
|
|
|
|
|
def mktempfile(encoding):
|
|
|
|
fname = os.path.join(tmpdir, hex(random.getrandbits(128))[2:-1])
|
|
|
|
return io.open(fname, mode='w+', encoding=encoding)
|
|
|
|
|
|
|
|
text = '就吃饭'
|
|
|
|
with mktempfile(encoding='utf-8') as tf:
|
|
|
|
progress_stream.write_to_stream(text, tf)
|
|
|
|
tf.seek(0)
|
|
|
|
assert tf.read() == text
|
|
|
|
|
|
|
|
with mktempfile(encoding='utf-32') as tf:
|
|
|
|
progress_stream.write_to_stream(text, tf)
|
|
|
|
tf.seek(0)
|
|
|
|
assert tf.read() == text
|
|
|
|
|
|
|
|
with mktempfile(encoding='ascii') as tf:
|
|
|
|
progress_stream.write_to_stream(text, tf)
|
|
|
|
tf.seek(0)
|
|
|
|
assert tf.read() == '???'
|
|
|
|
|
2019-01-09 23:14:12 +01:00
|
|
|
def test_get_digest_from_push(self):
|
|
|
|
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(self):
|
|
|
|
events = list()
|
|
|
|
assert progress_stream.get_digest_from_pull(events) is None
|
2016-06-14 22:55:48 +02:00
|
|
|
|
2019-01-09 23:14:12 +01:00
|
|
|
digest = "sha256:abcd"
|
|
|
|
events = [
|
|
|
|
{"status": "..."},
|
|
|
|
{"status": "..."},
|
|
|
|
{"status": "Digest: %s" % digest},
|
|
|
|
{"status": "..."},
|
|
|
|
]
|
|
|
|
assert progress_stream.get_digest_from_pull(events) == digest
|