Blame tests/test_cli_progress.py

Packit 6f3914
# -*- coding: utf-8 -*-
Packit 6f3914
Packit 6f3914
# Copyright (C) 2012-2018 Red Hat, Inc.
Packit 6f3914
#
Packit 6f3914
# This copyrighted material is made available to anyone wishing to use,
Packit 6f3914
# modify, copy, or redistribute it subject to the terms and conditions of
Packit 6f3914
# the GNU General Public License v.2, or (at your option) any later version.
Packit 6f3914
# This program is distributed in the hope that it will be useful, but WITHOUT
Packit 6f3914
# ANY WARRANTY expressed or implied, including the implied warranties of
Packit 6f3914
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General
Packit 6f3914
# Public License for more details.  You should have received a copy of the
Packit 6f3914
# GNU General Public License along with this program; if not, write to the
Packit 6f3914
# Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
Packit 6f3914
# 02110-1301, USA.  Any Red Hat trademarks that are incorporated in the
Packit 6f3914
# source code or documentation are not subject to the GNU General Public
Packit 6f3914
# License and may only be used or replicated with the express permission of
Packit 6f3914
# Red Hat, Inc.
Packit 6f3914
Packit 6f3914
from __future__ import absolute_import
Packit 6f3914
from __future__ import unicode_literals
Packit 6f3914
Packit 6f3914
import dnf.callback
Packit 6f3914
import dnf.cli.progress
Packit 6f3914
import dnf.pycomp
Packit 6f3914
Packit 6f3914
import tests.support
Packit 6f3914
from tests.support import mock
Packit 6f3914
Packit 6f3914
Packit 6f3914
class MockStdout(dnf.pycomp.StringIO):
Packit 6f3914
    def visible_lines(self):
Packit 6f3914
        lines = self.lines()
Packit 6f3914
        last = len(lines) - 1
Packit 6f3914
        return [l[:-1] for (i, l) in enumerate(lines)
Packit 6f3914
                if l.endswith('\n') or i == last]
Packit 6f3914
Packit 6f3914
    def lines(self):
Packit 6f3914
        return self.getvalue().splitlines(True)
Packit 6f3914
Packit 6f3914
Packit 6f3914
class FakePayload(object):
Packit 6f3914
    def __init__(self, string, size):
Packit 6f3914
        self.string = string
Packit 6f3914
        self._size = size
Packit 6f3914
Packit 6f3914
    def __str__(self):
Packit 6f3914
        return self.string
Packit 6f3914
Packit 6f3914
    @property
Packit 6f3914
    def download_size(self):
Packit 6f3914
        return self._size
Packit 6f3914
Packit 6f3914
Packit 6f3914
class ProgressTest(tests.support.TestCase):
Packit 6f3914
    def test_single(self):
Packit 6f3914
        now = 1379406823.9
Packit 6f3914
        fo = MockStdout()
Packit 6f3914
        with mock.patch('dnf.cli.progress._term_width', return_value=60), \
Packit 6f3914
                mock.patch('dnf.cli.progress.time', lambda: now):
Packit 6f3914
Packit 6f3914
            p = dnf.cli.progress.MultiFileProgressMeter(fo)
Packit 6f3914
            p.isatty = True
Packit 6f3914
            pload = FakePayload('dummy-text', 5)
Packit 6f3914
            p.start(1, 1)
Packit 6f3914
            for i in range(6):
Packit 6f3914
                now += 1.0
Packit 6f3914
                p.progress(pload, i)
Packit 6f3914
            p.end(pload, None, None)
Packit 6f3914
        self.assertEqual(fo.lines(), [
Packit 6f3914
            'dummy-text  0% [          ] ---  B/s |   0  B     --:-- ETA\r',
Packit 6f3914
            'dummy-text 20% [==        ] 1.0  B/s |   1  B     00:04 ETA\r',
Packit 6f3914
            'dummy-text 40% [====      ] 1.0  B/s |   2  B     00:03 ETA\r',
Packit 6f3914
            'dummy-text 60% [======    ] 1.0  B/s |   3  B     00:02 ETA\r',
Packit 6f3914
            'dummy-text 80% [========  ] 1.0  B/s |   4  B     00:01 ETA\r',
Packit 6f3914
            'dummy-text100% [==========] 1.0  B/s |   5  B     00:00 ETA\r',
Packit 6f3914
            'dummy-text                  1.0  B/s |   5  B     00:05    \n'])
Packit 6f3914
Packit 6f3914
    def test_mirror(self):
Packit 6f3914
        fo = MockStdout()
Packit 6f3914
        p = dnf.cli.progress.MultiFileProgressMeter(fo, update_period=-1)
Packit 6f3914
        p.isatty = True
Packit 6f3914
        p.start(1, 5)
Packit 6f3914
        pload = FakePayload('foo', 5.0)
Packit 6f3914
        now = 1379406823.9
Packit 6f3914
Packit 6f3914
        with mock.patch('dnf.cli.progress._term_width', return_value=60), \
Packit 6f3914
                mock.patch('dnf.cli.progress.time', lambda: now):
Packit 6f3914
            p.progress(pload, 3)
Packit 6f3914
            p.end(pload, dnf.callback.STATUS_MIRROR, 'Timeout.')
Packit 6f3914
            p.progress(pload, 4)
Packit 6f3914
        self.assertEqual(fo.visible_lines(), [
Packit 6f3914
            '[MIRROR] foo: Timeout.                                     ',
Packit 6f3914
            'foo        80% [========  ] ---  B/s |   4  B     --:-- ETA'])
Packit 6f3914
Packit 6f3914
    _REFERENCE_TAB = [
Packit 6f3914
        ['(1-2/2): f  0% [          ] ---  B/s |   0  B     --:-- ETA'],
Packit 6f3914
        ['(1-2/2): b 10% [=         ] 2.2  B/s |   3  B     00:12 ETA'],
Packit 6f3914
        ['(1-2/2): f 20% [==        ] 2.4  B/s |   6  B     00:10 ETA'],
Packit 6f3914
        ['(1-2/2): b 30% [===       ] 2.5  B/s |   9  B     00:08 ETA'],
Packit 6f3914
        ['(1-2/2): f 40% [====      ] 2.6  B/s |  12  B     00:06 ETA'],
Packit 6f3914
        ['(1-2/2): b 50% [=====     ] 2.7  B/s |  15  B     00:05 ETA'],
Packit 6f3914
        ['(1-2/2): f 60% [======    ] 2.8  B/s |  18  B     00:04 ETA'],
Packit 6f3914
        ['(1-2/2): b 70% [=======   ] 2.8  B/s |  21  B     00:03 ETA'],
Packit 6f3914
        ['(1-2/2): f 80% [========  ] 2.9  B/s |  24  B     00:02 ETA'],
Packit 6f3914
        ['(1-2/2): b 90% [========= ] 2.9  B/s |  27  B     00:01 ETA'],
Packit 6f3914
        ['(1/2): foo                  1.0  B/s |  10  B     00:10    ',
Packit 6f3914
         '(2/2): bar100% [==========] 2.9  B/s |  30  B     00:00 ETA']]
Packit 6f3914
Packit 6f3914
    def test_multi(self):
Packit 6f3914
        now = 1379406823.9
Packit 6f3914
        fo = MockStdout()
Packit 6f3914
        with mock.patch('dnf.cli.progress._term_width', return_value=60), \
Packit 6f3914
                mock.patch('dnf.cli.progress.time', lambda: now):
Packit 6f3914
Packit 6f3914
            p = dnf.cli.progress.MultiFileProgressMeter(fo)
Packit 6f3914
            p.isatty = True
Packit 6f3914
            p.start(2, 30)
Packit 6f3914
            pload1 = FakePayload('foo', 10.0)
Packit 6f3914
            pload2 = FakePayload('bar', 20.0)
Packit 6f3914
            for i in range(11):
Packit 6f3914
                p.progress(pload1, float(i))
Packit 6f3914
                if i == 10:
Packit 6f3914
                    p.end(pload1, None, None)
Packit 6f3914
                now += 0.5
Packit 6f3914
Packit 6f3914
                p.progress(pload2, float(i * 2))
Packit 6f3914
                self.assertEqual(self._REFERENCE_TAB[i], fo.visible_lines())
Packit 6f3914
                if i == 10:
Packit 6f3914
                    p.end(pload2, dnf.callback.STATUS_FAILED, 'some error')
Packit 6f3914
                now += 0.5
Packit 6f3914
Packit 6f3914
        # check "end" events
Packit 6f3914
        self.assertEqual(fo.visible_lines(), [
Packit 6f3914
            '(1/2): foo                  1.0  B/s |  10  B     00:10    ',
Packit 6f3914
            '[FAILED] bar: some error                                   '])
Packit 6f3914
        self.assertTrue(2.0 < p.rate < 4.0)
Packit 6f3914
Packit 6f3914
    @mock.patch('dnf.cli.progress._term_width', return_value=40)
Packit 6f3914
    def test_skip(self, mock_term_width):
Packit 6f3914
        fo = MockStdout()
Packit 6f3914
        p = dnf.cli.progress.MultiFileProgressMeter(fo)
Packit 6f3914
        p.start(2, 30)
Packit 6f3914
        pload1 = FakePayload('club', 20.0)
Packit 6f3914
        p.end(pload1, dnf.callback.STATUS_ALREADY_EXISTS, 'already got')
Packit 6f3914
        self.assertEqual(p.done_files, 1)
Packit 6f3914
        self.assertEqual(p.done_size, pload1._size)
Packit 6f3914
        self.assertEqual(fo.getvalue(),
Packit 6f3914
                         '[SKIPPED] club: already got            \n')