Blame tests/test_cli.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
Packit 6f3914
from __future__ import absolute_import
Packit 6f3914
from __future__ import unicode_literals
Packit 6f3914
Packit 6f3914
import argparse
Packit 6f3914
import os
Packit 6f3914
import re
Packit 6f3914
from argparse import Namespace
Packit 6f3914
Packit 6f3914
import dnf.cli.cli
Packit 6f3914
import dnf.conf
Packit 6f3914
import dnf.goal
Packit 6f3914
import dnf.repo
Packit 6f3914
import dnf.repodict
Packit 6f3914
Packit 6f3914
import tests.support
Packit 6f3914
from tests.support import mock
Packit 6f3914
Packit 6f3914
Packit 6f3914
VERSIONS_OUTPUT = """\
Packit 6f3914
  Installed: pepper-0:20-0.x86_64 at Thu Jan  1 00:00:00 1970
Packit 6f3914
  Built    :  at Thu Jan  1 00:00:00 1970
Packit 6f3914
Packit 6f3914
  Installed: tour-0:5-0.noarch at Thu Jan  1 00:00:00 1970
Packit 6f3914
  Built    :  at Thu Jan  1 00:00:00 1970
Packit 6f3914
"""
Packit 6f3914
Packit 6f3914
Packit 6f3914
class VersionStringTest(tests.support.DnfBaseTestCase):
Packit 6f3914
Packit 6f3914
    REPOS = []
Packit 6f3914
Packit 6f3914
    def test_print_versions(self):
Packit 6f3914
        output = tests.support.MockOutput()
Packit 6f3914
        with mock.patch('sys.stdout') as stdout,\
Packit 6f3914
                mock.patch('dnf.sack._rpmdb_sack', return_value=self.base.sack):
Packit 6f3914
            dnf.cli.cli.print_versions(['pepper', 'tour'], self.base, output)
Packit 6f3914
        written = ''.join([mc[1][0] for mc in stdout.method_calls
Packit 6f3914
                           if mc[0] == 'write'])
Packit 6f3914
        self.assertEqual(written, VERSIONS_OUTPUT)
Packit 6f3914
Packit 6f3914
Packit 6f3914
@mock.patch('dnf.cli.cli.logger', new_callable=tests.support.mock_logger)
Packit 6f3914
class BaseCliTest(tests.support.ResultTestCase):
Packit 6f3914
Packit 6f3914
    REPOS = ["main", "updates"]
Packit 6f3914
    BASE_CLI = True
Packit 6f3914
    INIT_SACK = True
Packit 6f3914
Packit 6f3914
    def setUp(self):
Packit 6f3914
        super(BaseCliTest, self).setUp()
Packit 6f3914
        self.base.output.term = tests.support.MockTerminal()
Packit 6f3914
        self.base.downgrade_to = mock.Mock(wraps=self.base.downgrade_to)
Packit 6f3914
Packit 6f3914
    def test_downgradePkgs(self, logger):
Packit 6f3914
        self.base.downgradePkgs(('tour',))
Packit 6f3914
Packit 6f3914
        self.assertEqual(self.base.downgrade_to.mock_calls, [mock.call('tour', strict=False)])
Packit 6f3914
        self.assertEqual(logger.mock_calls, [])
Packit 6f3914
Packit 6f3914
    def test_downgradePkgs_notfound(self, logger):
Packit 6f3914
        with self.assertRaises(dnf.exceptions.Error) as ctx:
Packit 6f3914
            self.base.downgradePkgs(('non-existent',))
Packit 6f3914
        self.assertEqual(str(ctx.exception), 'No packages marked for downgrade.')
Packit 6f3914
Packit 6f3914
        self.assertEqual(self.base.downgrade_to.mock_calls,
Packit 6f3914
                         [mock.call('non-existent', strict=False)])
Packit 6f3914
        self.assertEqual(logger.mock_calls,
Packit 6f3914
                         [mock.call.info('No package %s available.',
Packit 6f3914
                                         'non-existent')])
Packit 6f3914
Packit 6f3914
    @mock.patch('dnf.cli.cli._', dnf.pycomp.NullTranslations().ugettext)
Packit 6f3914
    def test_downgradePkgs_notinstalled(self, logger):
Packit 6f3914
        tests.support.ObjectMatcher(dnf.package.Package, {'name': 'lotus'})
Packit 6f3914
Packit 6f3914
        with self.assertRaises(dnf.exceptions.Error) as ctx:
Packit 6f3914
            self.base.downgradePkgs(('lotus',))
Packit 6f3914
        self.assertEqual(str(ctx.exception), 'No packages marked for downgrade.')
Packit 6f3914
Packit 6f3914
        self.assertEqual(self.base.downgrade_to.mock_calls, [mock.call('lotus', strict=False)])
Packit 6f3914
Packit 6f3914
Packit 6f3914
@mock.patch('dnf.cli.cli.Cli._read_conf_file')
Packit 6f3914
class CliTest(tests.support.DnfBaseTestCase):
Packit 6f3914
Packit 6f3914
    REPOS = ["main"]
Packit 6f3914
    CLI = "init"
Packit 6f3914
Packit 6f3914
    def setUp(self):
Packit 6f3914
        super(CliTest, self).setUp()
Packit 6f3914
        self.base.output = tests.support.MockOutput()
Packit 6f3914
Packit 6f3914
    def test_knows_upgrade(self, _):
Packit 6f3914
        upgrade = self.cli.cli_commands['upgrade']
Packit 6f3914
        update = self.cli.cli_commands['update']
Packit 6f3914
        self.assertIs(upgrade, update)
Packit 6f3914
Packit 6f3914
    def test_simple(self, _):
Packit 6f3914
        self.assertFalse(self.base.conf.assumeyes)
Packit 6f3914
        self.cli.configure(['update', '-y'])
Packit 6f3914
        self.assertTrue(self.base.conf.assumeyes)
Packit 6f3914
Packit 6f3914
    def test_glob_options_cmds(self, _):
Packit 6f3914
        params = [
Packit 6f3914
            ['install', '-y', 'pkg1', 'pkg2'],
Packit 6f3914
            ['install', 'pkg1', '-y', 'pkg2'],
Packit 6f3914
            ['install', 'pkg1', 'pkg2', '-y'],
Packit 6f3914
            ['-y', 'install', 'pkg1', 'pkg2']
Packit 6f3914
        ]
Packit 6f3914
        for param in params:
Packit 6f3914
            self.cli.configure(args=param)
Packit 6f3914
            self.assertTrue(self.base.conf.assumeyes)
Packit 6f3914
            self.assertEqual(self.cli.command.opts.command, "install")
Packit 6f3914
            self.assertEqual(self.cli.command.opts.pkg_specs, ["pkg1", "pkg2"])
Packit 6f3914
Packit 6f3914
    def test_configure_repos(self, _):
Packit 6f3914
        opts = Namespace()
Packit 6f3914
        opts.repo = []
Packit 6f3914
        opts.repos_ed = [('*', 'disable'), ('comb', 'enable')]
Packit 6f3914
        opts.cacheonly = True
Packit 6f3914
        opts.nogpgcheck = True
Packit 6f3914
        opts.repofrompath = {}
Packit 6f3914
        self.base._repos = dnf.repodict.RepoDict()
Packit 6f3914
        self.base._repos.add(tests.support.MockRepo('one', self.base.conf))
Packit 6f3914
        self.base._repos.add(tests.support.MockRepo('two', self.base.conf))
Packit 6f3914
        self.base._repos.add(tests.support.MockRepo('comb', self.base.conf))
Packit 6f3914
        self.cli._configure_repos(opts)
Packit 6f3914
        self.assertFalse(self.base.repos['one'].enabled)
Packit 6f3914
        self.assertFalse(self.base.repos['two'].enabled)
Packit 6f3914
        self.assertTrue(self.base.repos['comb'].enabled)
Packit 6f3914
        self.assertFalse(self.base.repos["comb"].gpgcheck)
Packit 6f3914
        self.assertFalse(self.base.repos["comb"].repo_gpgcheck)
Packit 6f3914
Packit 6f3914
    def test_configure_repos_expired(self, _):
Packit 6f3914
        """Ensure that --cacheonly beats the expired status."""
Packit 6f3914
        opts = Namespace()
Packit 6f3914
        opts.repo = []
Packit 6f3914
        opts.repos_ed = []
Packit 6f3914
        opts.cacheonly = True
Packit 6f3914
        opts.repofrompath = {}
Packit 6f3914
Packit 6f3914
        pers = self.base._repo_persistor
Packit 6f3914
        pers.get_expired_repos = mock.Mock(return_value=('one',))
Packit 6f3914
        self.base._repos = dnf.repodict.RepoDict()
Packit 6f3914
        self.base._repos.add(tests.support.MockRepo('one', self.base.conf))
Packit 6f3914
        self.cli._configure_repos(opts)
Packit 6f3914
        # _process_demands() should respect --cacheonly in spite of modified demands
Packit 6f3914
        self.cli.demands.fresh_metadata = False
Packit 6f3914
        self.cli.demands.cacheonly = True
Packit 6f3914
        self.cli._process_demands()
Packit 6f3914
        self.assertEqual(self.base.repos['one']._repo.getSyncStrategy(),
Packit 6f3914
                         dnf.repo.SYNC_ONLY_CACHE)
Packit 6f3914
Packit 6f3914
Packit 6f3914
@mock.patch('dnf.logging.Logging._setup', new=mock.MagicMock)
Packit 6f3914
class ConfigureTest(tests.support.DnfBaseTestCase):
Packit 6f3914
Packit 6f3914
    REPOS = ["main"]
Packit 6f3914
#    CLI = "init"
Packit 6f3914
Packit 6f3914
    def setUp(self):
Packit 6f3914
        super(ConfigureTest, self).setUp()
Packit 6f3914
        self.base._conf = dnf.conf.Conf()
Packit 6f3914
        self.base.output = tests.support.MockOutput()
Packit 6f3914
        self.base._plugins = mock.Mock()
Packit 6f3914
        self.cli = dnf.cli.cli.Cli(self.base)
Packit 6f3914
        self.cli.command = mock.Mock()
Packit 6f3914
        self.conffile = os.path.join(tests.support.dnf_toplevel(), "etc/dnf/dnf.conf")
Packit 6f3914
Packit 6f3914
    @mock.patch('dnf.util.am_i_root', lambda: False)
Packit 6f3914
    def test_configure_user(self):
Packit 6f3914
        """ Test Cli.configure as user."""
Packit 6f3914
        self.base._conf = dnf.conf.Conf()
Packit 6f3914
        with mock.patch('dnf.rpm.detect_releasever', return_value=69):
Packit 6f3914
            self.cli.configure(['update', '-c', self.conffile])
Packit 6f3914
        reg = re.compile('^/var/tmp/dnf-[.a-zA-Z0-9_-]+$')
Packit 6f3914
        self.assertIsNotNone(reg.match(self.base.conf.cachedir))
Packit 6f3914
        parser = argparse.ArgumentParser()
Packit 6f3914
        expected = "%s update -c %s " % (parser.prog, self.conffile)
Packit 6f3914
        self.assertEqual(self.cli.cmdstring, expected)
Packit 6f3914
Packit 6f3914
    @mock.patch('dnf.util.am_i_root', lambda: True)
Packit 6f3914
    def test_configure_root(self):
Packit 6f3914
        """ Test Cli.configure as root."""
Packit 6f3914
        self.base._conf = dnf.conf.Conf()
Packit 6f3914
        with mock.patch('dnf.rpm.detect_releasever', return_value=69):
Packit 6f3914
            self.cli.configure(['update', '--nogpgcheck', '-c', self.conffile])
Packit 6f3914
        reg = re.compile('^/var/cache/dnf$')
Packit 6f3914
        self.assertIsNotNone(reg.match(self.base.conf.system_cachedir))
Packit 6f3914
        parser = argparse.ArgumentParser()
Packit 6f3914
        expected = "%s update --nogpgcheck -c %s " % (parser.prog, self.conffile)
Packit 6f3914
        self.assertEqual(self.cli.cmdstring, expected)
Packit 6f3914
Packit 6f3914
    def test_configure_verbose(self):
Packit 6f3914
        with mock.patch('dnf.rpm.detect_releasever', return_value=69):
Packit 6f3914
            self.cli.configure(['-v', 'update', '-c', self.conffile])
Packit 6f3914
        parser = argparse.ArgumentParser()
Packit 6f3914
        expected = "%s -v update -c %s " % (parser.prog, self.conffile)
Packit 6f3914
        self.assertEqual(self.cli.cmdstring, expected)
Packit 6f3914
        self.assertEqual(self.base.conf.debuglevel, 6)
Packit 6f3914
        self.assertEqual(self.base.conf.errorlevel, 6)
Packit 6f3914
Packit 6f3914
    @mock.patch('dnf.cli.cli.Cli._parse_commands', new=mock.MagicMock)
Packit 6f3914
    @mock.patch('os.path.exists', return_value=True)
Packit 6f3914
    def test_conf_exists_in_installroot(self, ospathexists):
Packit 6f3914
        with mock.patch('logging.Logger.warning'), \
Packit 6f3914
                mock.patch('dnf.rpm.detect_releasever', return_value=69):
Packit 6f3914
            self.cli.configure(['--installroot', '/roots/dnf', 'update'])
Packit 6f3914
        self.assertEqual(self.base.conf.config_file_path, '/roots/dnf/etc/dnf/dnf.conf')
Packit 6f3914
        self.assertEqual(self.base.conf.installroot, '/roots/dnf')
Packit 6f3914
Packit 6f3914
    @mock.patch('dnf.cli.cli.Cli._parse_commands', new=mock.MagicMock)
Packit 6f3914
    @mock.patch('os.path.exists', return_value=False)
Packit 6f3914
    def test_conf_notexists_in_installroot(self, ospathexists):
Packit 6f3914
        with mock.patch('dnf.rpm.detect_releasever', return_value=69):
Packit 6f3914
            self.cli.configure(['--installroot', '/roots/dnf', 'update'])
Packit 6f3914
        self.assertEqual(self.base.conf.config_file_path, '/etc/dnf/dnf.conf')
Packit 6f3914
        self.assertEqual(self.base.conf.installroot, '/roots/dnf')
Packit 6f3914
Packit 6f3914
    @mock.patch('dnf.cli.cli.Cli._parse_commands', new=mock.MagicMock)
Packit 6f3914
    def test_installroot_with_etc(self):
Packit 6f3914
        """Test that conffile is detected in a new installroot."""
Packit 6f3914
        self.base.extcmds = []
Packit 6f3914
Packit 6f3914
        tlv = tests.support.dnf_toplevel()
Packit 6f3914
        self.cli.configure(['--installroot', tlv, 'update'])
Packit 6f3914
        self.assertEqual(self.base.conf.config_file_path, '%s/etc/dnf/dnf.conf' % tlv)
Packit 6f3914
Packit 6f3914
    def test_installroot_configurable(self):
Packit 6f3914
        """Test that conffile is detected in a new installroot."""
Packit 6f3914
Packit 6f3914
        conf = os.path.join(tests.support.dnf_toplevel(), "tests/etc/installroot.conf")
Packit 6f3914
        self.cli.configure(['-c', conf, '--nogpgcheck', '--releasever', '17', 'update'])
Packit 6f3914
        self.assertEqual(self.base.conf.installroot, '/roots/dnf')