Blame tests/test_cli_progress.py

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