Script 'mail_helper' called by obssrc Hello community, here is the log from the commit of package PackageKit for openSUSE:Factory checked in at 2021-02-16 22:35:28 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Comparing /work/SRC/openSUSE:Factory/PackageKit (Old) and /work/SRC/openSUSE:Factory/.PackageKit.new.28504 (New) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "PackageKit" Tue Feb 16 22:35:28 2021 rev:214 rq:870844 version:1.2.2 Changes: -------- --- /work/SRC/openSUSE:Factory/PackageKit/PackageKit.changes 2021-01-30 13:28:56.067706945 +0100 +++ /work/SRC/openSUSE:Factory/.PackageKit.new.28504/PackageKit.changes 2021-02-16 22:37:12.765715594 +0100 @@ -7,0 +8,6 @@ +Fri Jan 29 21:30:49 UTC 2021 - Neal Gompa <ngomp...@gmail.com> + +- Backport fix from upstream to have DNF backend force dup for updates + + Patch: PackageKit-dnf-Add-support-for-coercing-upgrade-to-distupgrade.patch + +------------------------------------------------------------------- New: ---- PackageKit-dnf-Add-support-for-coercing-upgrade-to-distupgrade.patch ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Other differences: ------------------ ++++++ PackageKit.spec ++++++ --- /var/tmp/diff_new_pack.8PMpHs/_old 2021-02-16 22:37:14.469717864 +0100 +++ /var/tmp/diff_new_pack.8PMpHs/_new 2021-02-16 22:37:14.473717869 +0100 @@ -56,6 +56,8 @@ Patch5: PackageKit-fix-crash-pre-dbus.patch # PATCH-FIX-UPSTREAM PackageKit-zypp-reset-update-mode-after-get-updates.patch gh#hughsie/PackageKit/commit#b208f551 bsc#1180150 sck...@suse.com -- zypp: Reset update mode after getting updates Patch6: PackageKit-zypp-reset-update-mode-after-get-updates.patch +# PATCH-FIX-UPSTREAM PackageKit-dnf-Add-support-for-coercing-upgrade-to-distupgrade.patch gh#hughsie/PackageKit#449 -- Use dup for upgrades on Tumbleweed with DNF +Patch7: PackageKit-dnf-Add-support-for-coercing-upgrade-to-distupgrade.patch BuildRequires: fdupes BuildRequires: gcc-c++ ++++++ PackageKit-dnf-Add-support-for-coercing-upgrade-to-distupgrade.patch ++++++ >From 7d89261b61b8536531ef2ae85c0c631d8c97f723 Mon Sep 17 00:00:00 2001 From: Neal Gompa <ngomp...@gmail.com> Date: Fri, 29 Jan 2021 13:41:06 -0500 Subject: [PATCH] dnf: Add support for coercing upgrade to distupgrade Some distributions (particularly rolling release distributions) prefer that normal "upgrade" actions actually trigger the distupgrade method in the package manager. This change enables that if the installed distribution release package specifies that this behavior must occur. --- backends/dnf/pk-backend-dnf.c | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/backends/dnf/pk-backend-dnf.c b/backends/dnf/pk-backend-dnf.c index 74d35c34c..05f354afe 100644 --- a/backends/dnf/pk-backend-dnf.c +++ b/backends/dnf/pk-backend-dnf.c @@ -823,6 +823,28 @@ dnf_utils_run_query_with_newest_filter (DnfSack *sack, HyQuery query) return results; } +static gboolean +dnf_utils_force_distupgrade_on_upgrade (DnfSack *sack) +{ + g_autoptr(GPtrArray) plist = NULL; + gint candidates; + const gchar *distroverpkg_names[] = { "system-release", "distribution-release", NULL }; + const gchar *distupgrade_provides[] = { "system-upgrade(dsync)", "product-upgrade() = dup", NULL }; + HyQuery query_tmp = hy_query_create (sack); + + hy_query_filter (query_tmp, HY_PKG_REPONAME, HY_EQ, HY_SYSTEM_REPO_NAME); + hy_query_filter_provides_in (query_tmp, (gchar**) distroverpkg_names); + hy_query_filter_provides_in (query_tmp, (gchar**) distupgrade_provides); + + plist = hy_query_run (query_tmp); + candidates = plist->len; + hy_query_free (query_tmp); + + if (candidates > 0) + return TRUE; + return FALSE; +} + static GPtrArray * dnf_utils_run_query_with_filters (PkBackendJob *job, DnfSack *sack, HyQuery query, PkBitfield filters) @@ -1001,7 +1023,11 @@ pk_backend_search_thread (PkBackendJob *job, GVariant *params, gpointer user_dat dnf_sack_set_installonly_limit (sack, dnf_context_get_installonly_limit (job_data->context)); job_data->goal = hy_goal_create (sack); - hy_goal_upgrade_all (job_data->goal); + if (dnf_utils_force_distupgrade_on_upgrade (sack)) { + hy_goal_distupgrade_all (job_data->goal); + } else { + hy_goal_upgrade_all (job_data->goal); + } ret = dnf_goal_depsolve (job_data->goal, DNF_ALLOW_UNINSTALL, &error); if (!ret) { pk_backend_job_error_code (job, error->code, "%s", error->message); -- 2.29.2