Fetching contributors…
Cannot retrieve contributors at this time
1561 lines (1176 sloc) 48.2 KB

DNF Release Notes

2.1.0 Release Notes

API additions in 2.1.0:

Bugs fixed in 2.1.0:

2.0.1 Release Notes

API changes in 2.0.1:

API additions in 2.0.1:

DNF command additions in 2.0.1:

  • dnf [options] shell [filename] opens an interactive shell for conducting multiple commands during a single execution of DNF
  • dnf [options] swap <remove-spec> <install-spec> removes spec and install spec in one transaction

Bugs fixed in 2.0.1:

2.0.0 Release Notes

List of all incompatible changes can be found at: :doc:`dnf-1 vs dnf-2 <dnf-1_vs_dnf-2>`

API changes in 2.0.0:

API additions in 2.0.0:

DNF command changes in 2.0.0:

  • dnf [options] group install [with-optional] <group-spec>... changes to dnf [options] group install [--with-optional] <group-spec>....
  • dnf [options] list command [<package-name-specs>...] changes to dnf [options] list --command [<package-name-specs>...]`.
  • dnf [options] makecache timer changes to dnf [options] makecache --timer.
  • dnf [options] repolist [enabled|disabled|all] changes to dnf [options] repolist [--enabled|--disabled|--all].
  • dnf [options] repository-packages <repoid> info command [<package-name-spec>...] changes to dnf [options] repository-packages <repoid> info --command [<package-name-spec>...].
  • dnf repoquery --duplicated changes to dnf repoquery --duplicates.
  • dnf [options] search [all] <keywords>... changes to dnf [options] search [--all] <keywords>....
  • dnf [options] updateinfo [<availability>] [<spec>...] changes to dnf [options] updateinfo [--summary|--list|--info] [<availability>] [<spec>...].
  • --disablerepo :doc:`command line argument <command_ref>` is mutually exclusive with --repo.
  • --enablerepo :doc:`command line argument <command_ref>` now appends repositories.
  • --installroot :doc:`command line argument <command_ref>`. For detailed description see: :doc:`DNF command API <command_ref>`.
  • --releasever :doc:`command line argument <command_ref>` now doesn't detect release number from running system.
  • --repofrompath :doc:`command line argument <command_ref>` can now be combined with --repo instead of --enablerepo.
  • Alternative of yum's deplist changes from dnf repoquery --requires to dnf repoquery --deplist.
  • New systemd units dnf-automatic-notifyonly, dnf-automatic-download, dnf-automatic-download

were added for a better customizability of :doc:`dnf-automatic <automatic>`.

DNF command additions in 2.0.0:

  • dnf [options] remove --duplicates removes older version of duplicated packages.
  • dnf [options] remove --oldinstallonly``removes old installonly packages keeping only ``installonly_limit latest versions.
  • dnf [options] repoquery [<select-options>] [<query-options>] [<pkg-spec>] searches the available DNF repositories for selected packages and displays the requested information about them. It is an equivalent of rpm -q for remote repositories.
  • dnf [options] repoquery --querytags provides list of recognized tags by repoquery option -:ref:`-queryformat <queryformat_repoquery-label>`.
  • --repo :doc:`command line argument <command_ref>` enables just specific repositories by an id or a glob. Can be used multiple times with accumulative effect. It is basically shortcut for --disablerepo="*" --enablerepo=<repoid> and is mutually exclusive with --disablerepo option.
  • New commands have been introduced: check and upgrade-minimal.
  • New security options introduced: bugfix, enhancement, newpackage, security, advisory, bzs, cves, sec-severity and secseverity.

Bugs fixed in 2.0.0:

1.1.10 Release Notes

Fixed unicode handling and fixing other bugs.

Bugs fixed in 1.1.10:

1.1.9 Release Notes

From this release if you use any non-API methods warning will be printed and bugfixes.

Bugs fixed in 1.1.9:

1.1.8 Release Notes

Improvements in documentation, bugfixes, translation updates.

Bugs fixed in 1.1.8:

1.1.7 Release Notes

Added :meth:`dnf.rpm.basearch` method, intended for the detection of CPU base architecture.

The :ref:`group list <grouplist_command-label>` command was enriched with installed and available switches.

Documented a standard way of overriding autodetected arhitectures in :doc:`DNF API <api_conf>`.

Bugs fixed in 1.1.7:

1.1.6 Release Notes

Added support of socks5 proxy.

Bugs fixed in 1.1.6:

1.1.5 Release Notes

Improved the start-up time of bash completion.

Reviewed documentation.

Bugs fixed in 1.1.5:

1.1.4 Release Notes

API additions in 1.1.4:

Bugs fixed in 1.1.4:

1.1.3 Release Notes

Now :meth:`dnf.Base.group_install` is able to exclude mandatory packages of the group from transaction.

1.1.2 Release Notes

Implemented :ref:`--downloadonly <downloadonly-label>` command line option.

Bugs fixed in 1.1.2:

1.1.1 Release Notes

Implemented dnf mark :doc:`command <command_ref>`.

Bugs fixed in 1.1.1:

1.1.0 Release Notes

API additions in 1.1.0:

:meth:`dnf.Base.do_transaction` now accepts multiple displays.

Introduced install_weak_deps :doc:`configuration <conf_ref>` option.

Implemented strict :doc:`configuration <conf_ref>` option.

API deprecations in 1.1.0:

Bugs fixed in 1.1.0

1.0.2 Release Notes

When a transaction is not successfully finished, DNF preserves downloaded packages until the next successful transaction even if keepcache option is set to False.

Maximum number of simultaneous package downloads can be adjusted by newly added max_parallel_downloads :doc:`configuration <conf_ref>` option.

--repofrompath :doc:`command line argument <command_ref>` was introduced for temporary configuration of repositories.

API additions in 1.0.2:

Newly added package attributes: :attr:`dnf.package.Package.obsoletes`, :attr:`dnf.package.Package.provides` and :attr:`dnf.package.Package.requires`.

:attr:`dnf.package.Query.filter`'s keys requires and provides now accepts list of Hawkey.Reldep type.

Bugs fixed in 1.0.2:

1.0.1 Release Notes

DNF follows the Semantic Versioning as defined at

Documented SSL :doc:`configuration <conf_ref>` and :doc:`repository <api_repos>` options.

Added virtual provides allowing installation of DNF commands by their name in the form of dnf install dnf-command(name).

:doc:`dnf-automatic <automatic>` now by default waits random interval between 0 and 300 seconds before any network communication is performed.

Bugs fixed in 1.0.1:

1.0.0 Release Notes

Improved documentation of YUM to DNF transition in :doc:`cli_vs_yum`.

:ref:`Auto remove command <autoremove_command-label>` does not remove installonly packages.

:ref:`Downgrade command <downgrade_command-label>` downgrades to specified package version if that is lower than currently installed one.

DNF now uses :attr:`` as a default value for :attr:``.

Added support of repositories which use basic HTTP authentication.

API additions in 1.0.0:

:doc:`configuration <conf_ref>` options username and password (HTTP authentication)

:attr:`dnf.repo.Repo.username` and :attr:`dnf.repo.Repo.password` (HTTP authentication)

Bugs fixed in 1.0.0:

0.6.5 Release Notes

Python 3 version of DNF is now default in Fedora 23 and later.

yum-dnf package does not conflict with yum package.

dnf erase was deprecated in favor of dnf remove.

Extended documentation of handling non-existent packages and YUM to DNF transition in :doc:`cli_vs_yum`.

API additions in 0.6.5:

Newly added pluginconfpath option in :doc:`configuration <conf_ref>`.

Exposed skip_if_unavailable attribute from :doc:`api_repos`.

Documented IOError exception of method fill_sack from :class:`dnf.Base`.

Bugs fixed in 0.6.5:

0.6.4 Release Notes

Added example code snippets into :doc:`use_cases`.

Shows ordered groups/environments by display_order tag from :ref:`cli <grouplist_command-label>` and :doc:`api_comps` DNF API.

In commands the environment group is specified the same as :ref:`group <specifying_groups-label>`.

:ref:`skip_if_unavailable <skip_if_unavailable-label>` configuration option affects the metadata only.

added enablegroups, minrate and timeout :doc:`configuration options <conf_ref>`

API additions in 0.6.4:

Documented install_set and remove_set attributes from :doc:`api_transaction`.

Exposed downloadsize, files, installsize attributes from :doc:`api_package`.

Bugs fixed in 0.6.4:

0.6.3 Release Notes

:ref:`Deltarpm <deltarpm-label>` configuration option is set on by default.

API additions in 0.6.3:

Bugs fixed in 0.6.3:

0.6.2 Release Notes

API additions in 0.6.2:

Bugs fixed in 0.6.2:

0.6.1 Release Notes

New release adds :ref:`upgrade-type command <upgrade_type_automatic-label>` to dnf-automatic for choosing specific advisory type updates.

Implemented missing :ref:`history redo command <history_redo_command-label>` for repeating transactions.

Supports :ref:`gpgkey <repo_gpgkey-label>` repo config, :ref:`repo_gpgcheck <repo_gpgcheck-label>` and :ref:`gpgcheck <gpgcheck-label>` [main] and Repo configs.

Distributing new package :ref:`dnf-yum <dnf_yum_package-label>` that provides /usr/bin/yum as a symlink to /usr/bin/dnf.

API additions in 0.6.1:

Bugs fixed in 0.6.1:

0.6.0 Release Notes

0.6.0 marks a new minor version of DNF and the first release to support advisories listing with the :ref:`udpateinfo command <updateinfo_command-label>`.

Support for the :ref:`include configuration directive <include-label>` has been added. Its functionality reflects Yum's includepkgs but it has been renamed to make it consistent with the exclude setting.

Group operations now produce a list of proposed marking changes to group objects and the user is given a chance to accept or reject them just like with an ordinary package transaction.

Bugs fixed in 0.6.0:

0.5.5 Release Notes

The full proxy configuration, API extensions and several bugfixes are provided in this release.

API changes in 0.5.5:

  • cachedir, the second parameter of :meth:`dnf.repo.Repo.__init__` is not optional (the method has always been this way but the documentation was not matching)

API additions in 0.5.5:

Bugs fixed in 0.5.5:

0.5.4 Release Notes

Several encodings bugs were fixed in this release, along with some packaging issues and updates to :doc:`conf_ref`.

Repository :ref:`priority <repo_priority-label>` configuration setting has been added, providing similar functionality to Yum Utils' Priorities plugin.

Bugs fixed in 0.5.4:

0.5.3 Release Notes

A set of bugfixes related to i18n and Unicode handling. There is a -4/-6 switch and a corresponding :ref:`ip_resolve <ip-resolve-label>` configuration option (both known from Yum) to force DNS resolving of hosts to IPv4 or IPv6 addresses.

0.5.3 comes with several extensions and clarifications in the API: notably :class:`~.dnf.transaction.Transaction` is introspectible now, :class:`Query.filter <dnf.query.Query.filter>` is more useful with new types of arguments and we've hopefully shed more light on how a client is expected to setup the configuration :attr:`~dnf.conf.Conf.substitutions`.

Finally, plugin authors can now use a new :meth:`~dnf.Plugin.resolved` hook.

API changes in 0.5.3:

API additions in 0.5.3:

Bugs fixed in 0.5.3:

0.5.2 Release Notes

This release brings autoremove command that removes any package that was originally installed as a dependency (e.g. had not been specified as an explicit argument to the install command) and is no longer needed.

Enforced verification of SSL connections can now be disabled with the :ref:`sslverify setting <sslverify-label>`.

We have been plagued with many crashes related to Unicode and encodings since the 0.5.0 release. These have been cleared out now.

There's more: improvement in startup time, extended globbing semantics for input arguments and better search relevance sorting.

Bugs fixed in 0.5.2:

0.5.1 Release Notes

Bugfix release with several internal cleanups. One outstanding change for CLI users is that DNF is a lot less verbose now during the dependency resolving phase.

Bugs fixed in 0.5.1:

0.5.0 Release Notes

The biggest improvement in 0.5.0 is complete support for groups and environments, including internal database of installed groups independent of the actual packages (concept known as groups-as-objects from Yum). Upgrading groups is supported now with group upgrade too.

To force refreshing of metadata before an operation (even if the data is not expired yet), the refresh option has been added.

Internally, the CLI went through several changes to allow for better API accessibility like granular requesting of root permissions.

API has got many more extensions, focusing on better manipulation with comps and packages. There are new entries in :doc:`cli_vs_yum` and :doc:`user_faq` too.

Several resource leaks (file descriptors, noncollectable Python objects) were found and fixed.

API changes in 0.5.0:

API extensions in 0.5.0:

Bugs fixed in 0.5.0:

0.4.19 Release Notes

Arriving one week after 0.4.18, the 0.4.19 mainly provides a fix to a traceback in group operations under non-root users.

DNF starts to ship separate translation files (.mo) starting with this release.

Bugs fixed in 0.4.19:

0.4.18 Release Notes

Support for dnf distro-sync <spec> finally arrives in this version.

DNF has moved to handling groups as objects, tagged installed/uninstalled independently from the actual installed packages. This has been in Yum as the group_command=objects setting and the default in recent Fedora releases. There are API extensions related to this change as well as two new CLI commands: group mark install and group mark remove.

API items deprecated in 0.4.8 and 0.4.9 have been dropped in 0.4.18, in accordance with our :ref:`deprecating-label`.

API changes in 0.4.18:

API deprecations in 0.4.18:

API additions in 0.4.18:

Bugs fixed in 0.4.18:

0.4.17 Release Notes

This release fixes many bugs in the downloads/DRPM CLI area. A bug got fixed preventing a regular user from running read-only operations using --cacheonly. Another fix ensures that metadata_expire=never setting is respected. Lastly, the release provides three requested API calls in the repo management area.

API additions in 0.4.17:

Bugs fixed in 0.4.17:

0.4.16 Release Notes

The refactorings from 0.4.15 are introducing breakage causing the background dnf makecache runs traceback. This release fixes that.

Bugs fixed in 0.4.16:

0.4.15 Release Notes

Massive refactoring of the downloads handling to provide better API for reporting download progress and fixed bugs are the main things brought in 0.4.15.

API additions in 0.4.15:

Bugs fixed in 0.4.15:

0.4.14 Release Notes

This quickly follows 0.4.13 to address the issue of crashes when DNF output is piped into another program.

API additions in 0.4.14:

Bugs fixed in 0.4.14:

0.4.13 Release Notes

0.4.13 finally ships support for delta RPMS. Enabling this can save some bandwidth (and use some CPU time) when downloading packages for updates.

Support for bash completion is also included in this version. It is recommended to use the generate_completion_cache plugin to have the completion work fast. This plugin will be also shipped with dnf-plugins-core-0.0.3.

The :ref:`keepcache <keepcache-label>` config option has been readded.

Bugs fixed in 0.4.13:

0.4.12 Release Notes

This release disables fastestmirror by default as we received many complains about it. There are also several bugfixes, most importantly an issue has been fixed that caused packages installed by Anaconda be removed together with a depending package. It is now possible to use bandwidth and throttle config values too.

Bugs fixed in 0.4.12:

0.4.11 Release Notes

This is mostly a bugfix release following quickly after 0.4.10, with many updates to documentation.

API additions in 0.4.11:

API changes in 0.4.11:

Bugs fixed in 0.4.11:

0.4.10 Release Notes

0.4.10 is a bugfix release that also adds some long-requested CLI features and extends the plugin support with two new plugin hooks. An important feature for plugin developers is going to be the possibility to register plugin's own CLI command, available from this version.

dnf history now recognizes last as a special argument, just like other history commands.

dnf install now accepts group specifications via the @ character.

Support for the --setopt option has been readded from Yum.

API additions in 0.4.10:

API changes in 0.4.10:

Bugs fixed in 0.4.10:

0.4.9 Release Notes

Several Yum features are revived in this release. dnf history rollback now works again. The history userinstalled has been added, it displays a list of ackages that the user manually selected for installation on an installed system and does not include those packages that got installed as dependencies.

We're happy to announce that the API in 0.4.9 has been extended to finally support plugins. There is a limited set of plugin hooks now, we will carefully add new ones in the following releases. New marking operations have ben added to the API and also some configuration options.

An alternative to yum shell is provided now for its most common use case: :ref:`replacing a non-leaf package with a conflicting package <allowerasing_instead_of_shell>` is achieved by using the --allowerasing switch now.

API additions in 0.4.9:

API deprecations in 0.4.9:

Bugs fixed in 0.4.9:

0.4.8 Release Notes

There are mainly internal changes, new API functions and bugfixes in this release.

Python 3 is fully supported now, the Fedora builds include the Py3 variant. The DNF program still runs under Python 2.7 but the extension authors can now choose what Python they prefer to use.

This is the first version of DNF that deprecates some of its API. Clients using deprecated code will see a message emitted to stderr using the standard Python warnings module. You can filter out :exc:`dnf.exceptions.DeprecationWarning` to suppress them.

API additions in 0.4.8:

API deprecations in 0.4.8:

Bugs fixed in 0.4.8:

0.4.7 Release Notes

We start to publish the :doc:`api` with this release. It is largely incomprehensive at the moment, yet outlines the shape of the documentation and the process the project is going to use to maintain it.

There are two Yum configuration options that were dropped: :ref:`group_package_types <group_package_types_dropped>` and :ref:`upgrade_requirements_on_install <upgrade_requirements_on_install_dropped>`.

Bugs fixed in 0.4.7:

0.4.6 Release Notes

0.4.6 brings two new major features. Firstly, it is the revival of history undo, so transactions can be reverted now. Secondly, DNF will now limit the number of installed kernels and installonly packages in general to the number specified by :ref:`installonly_limit <installonly-limit-label>` configuration option.

DNF now supports the group summary command and one-word group commands no longer cause tracebacks, e.g. dnf grouplist.

There are vast internal changes to dnf.cli, the subpackage that provides CLI to DNF. In particular, it is now better separated from the core.

The hawkey library used against DNF from with this versions uses a recent RPMDB loading optimization in libsolv that shortens DNF startup by seconds when the cached RPMDB is invalid.

We have also added further fixes to support Python 3 and enabled librepo's fastestmirror caching optimization to tighten the download times even more.

Bugs fixed in 0.4.6:

0.4.5 Release Notes

A serious bug causing tracebacks during package downloads made it into 0.4.4 and this release contains a fix for that. Also, a basic proxy support has been readded now.

Bugs fixed in 0.4.5:

0.4.4 Release Notes

The initial support for Python 3 in DNF has been merged in this version. In practice one can not yet run the dnf command in Py3 but the unit tests already pass there. We expect to give Py3 and DNF heavy testing during the Fedora 21 development cycle and eventually switch to it as the default. The plan is to drop Python 2 support as soon as Anaconda is running in Python 3.

Minor adjustments to allow Anaconda support also happened during the last week, as well as a fix to a possibly severe bug that one is however not really likely to see with non-devel Fedora repos:

0.4.3 Release Notes

This is an early release to get the latest DNF out with the latest librepo fixing the Too many open files bug.

In Fedora, the spec file has been updated to no longer depend on precise versions of the libraries so in the future they can be released independently.

This release sees the finished refactoring in error handling during basic operations and adds support for group remove and group info commands, i.e. the following two bugs:

0.4.2 Release Notes

DNF now downloads packages for the transaction in parallel with progress bars updated to effectively represent this. Since so many things in the downloading code were changing, we figured it was a good idea to finally drop urlgrabber dependency at the same time. Indeed, this is the first version that doesn't require urlgrabber for neither build nor run.

Similarly, since librepo started to support this, downloads in DNF now use the fastests mirrors available by default.

The option to :ref:`specify repositories' costs <repo_cost-label>` has been readded.

Internally, DNF has seen first part of ongoing refactorings of the basic operations (install, update) as well as a couple of new API methods supporting development of extensions.

These bugzillas are fixed in 0.4.2:

0.4.1 Release Notes

The focus of this release was to support our efforts in implementing the DNF Payload for Anaconda, with changes on the API side of things (better logging, new Base.reset() method).

Support for some irrelevant config options has been dropped (kernelpkgnames, exactarch, rpm_check_debug). We also no longer detect metalinks in the mirrorlist option (see Fedora bug 948788).

DNF is on its way to drop the urlgrabber dependency and the first set of patches towards this goal is already in.

Expect the following bugs to go away with upgrade to 0.4.1:

0.4.0 Release Notes

The new minor version brings many internal changes to the comps code, most comps parsing and processing is now delegated to libcomps by Jindřich Luža.

The overwrite_groups config option has been dropped in this version and DNF acts if it was 0, that is groups with the same name are merged together.

The currently supported groups commands (group list and group install) are documented on the manpage now.

The 0.4.0 version is the first one supported by the DNF Payload for Anaconda and many changes since 0.3.11 make that possible by cleaning up the API and making it more sane (cleanup of yumvars initialization API, unifying the RPM transaction callback objects hierarchy, slimming down dnf.rpmUtils.arch, improved logging).

Fixes for the following are contained in this version:

0.3.11 Release Notes

The default multilib policy configuration value is best now. This does not pose any change for the Fedora users because exactly the same default had been previously achieved by a setting in /etc/dnf/dnf.conf shipped with the Fedora package.

An important fix to the repo module speeds up package downloads again is present in this release. The full list of fixes is:

0.3.10 Release Notes

The only major change is that skip_if_unavailable is :ref:`enabled by default now <skip_if_unavailable_default>`.

A minor release otherwise, mainly to get a new version of DNF out that uses a fresh librepo. The following issues are now a thing of the past:

0.3.9 Release Notes

This is a quick bugfix release dealing with reported bugs and tracebacks:

0.3.8 Release Notes

A new locking module has been integrated in this version, clients should see the message about DNF lock being taken less often.

Panu Matilainen has submitted many patches to this release to cleanup the RPM interfacing modules.

The following bugs are fixed in this release:

0.3.7 Release Notes

This is a bugfix release:

0.3.6 Release Notes

This is a bugfix release, including the following fixes:

0.3.5 Release Notes

Besides few fixed bugs this version should not present any differences for the user. On the inside, the transaction managing mechanisms have changed drastically, bringing code simplification, better maintainability and better testability.

In Fedora, there is a change in the spec file effectively preventing the makecache timer from running immediatelly after installation. The timer service is still enabled by default, but unless the user starts it manually with systemctl start dnf-makecache.timer it will not run until after the first reboot. This is in alignment with Fedora packaging best practices.

The following bugfixes are included in 0.3.5:

0.3.4 Release Notes

0.3.4 is the first DNF version since the fork from Yum that is able to manipulate the comps data. In practice, dnf group install <group name> works again. No other group commands are supported yet.

Support for librepo-0.0.4 and related cleanups and extensions this new version allows are included (see the buglist below)

This version has also improved reporting of obsoleted packages in the CLI (the Yum-style "replacing <package-nevra>" appears in the textual transaction overview).

The following bugfixes are included in 0.3.4:

0.3.3 Release Notes

The improvements in 0.3.3 are only API changes to the logging. There is a new module dnf.logging that defines simplified logging structure compared to Yum, with fewer logging levels and simpler usage for the developers. The RPM transaction logs are no longer in /var/log/dnf.transaction.log but in /var/log/dnf.rpm.log by default.

The exception classes were simplified and moved to dnf.exceptions.

The following bugs are fixed in 0.3.3:

0.3.2 Release Notes

The major improvement in this version is in speeding up syncing of repositories using metalink by looking at the repomd.xml checksums. This effectively lets DNF cheaply refresh expired repositories in cases where the original has not changed: for instance the main Fedora repository is refreshed with one 30 kB HTTP download. This functionality is present in the current Yum but hasn't worked in DNF since 3.0.0.

Otherwise this is mainly a release fixing bugs and tracebacks. The following reported bugs are fixed:

0.3.1 Release Notes

0.3.1 brings mainly changes to the automatic metadata synchronization. In Fedora, dnf makecache is triggered via SystemD timers now and takes an optional background extra-argument to run in resource-considerate mode (no syncing when running on laptop battery, only actually performing the check at most once every three hours). Also, the IO and CPU priorities of the timer-triggered process are lowered now and shouldn't as noticeably impact the system's performance.

The administrator can also easily disable the automatic metadata updates by setting :ref:`metadata_timer_sync <metadata_timer_sync-label>` to 0.

The default value of :ref:`metadata_expire <metadata_expire-label>` was increased from 6 hours to 48 hours. In Fedora, the repos usually set this explicitly so this change is not going to cause much impact.

The following reported issues are fixed in this release: