mirror of
https://github.com/moparisthebest/pacman
synced 2024-11-15 22:05:02 -05:00
d1ea16dfd0
This patch should avoid duplicated target names in the backend. 1. sync_loadtarget will return with PM_ERR_TRANS_DUP_TARGET when trying to add a duplicated target 2. sysupgrade never pulls duplicated targets 3. resolvedeps won't pull duplicated targets anymore A pulled list was introduced in sync_prepare to improve the pmsyncpkg_t<->pmpkg_t list conversion by making it more direct. Also replace sync1005 and sync1006 by the sync1008 pactest, which is similar but more interesting (the provisions are dependencies instead of explicit targets). sync1005 didn't work as expected anyway. It was expecting that pacman failed, and pacman indeed failed, but not for the good reason. It didn't fail during the preparation step because of conflicting targets, but during the commit step, because of a md5 error... And sync1006 didn't pass and was not really worth fixing. We have already enough failing pactests more important than these two. sync1008 pass with this patch. Signed-off-by: Nagy Gabor <ngaba@bibl.u-szeged.hu> Signed-off-by: Chantry Xavier <shiningxc@gmail.com>
20 lines
457 B
Python
20 lines
457 B
Python
self.description = "Conflicting package names in sync repos"
|
|
|
|
sp1 = pmpkg("cpkg", "1.0-1")
|
|
sp1.provides = [ "provision1" ]
|
|
self.addpkg2db("sync1", sp1)
|
|
|
|
sp2 = pmpkg("cpkg", "2.0-1")
|
|
sp2.provides = [ "provision2" ]
|
|
self.addpkg2db("sync2", sp2)
|
|
|
|
sp3 = pmpkg("pkg")
|
|
sp3.depends = [ "provision1" , "provision2" ]
|
|
self.addpkg2db("sync1", sp3)
|
|
|
|
self.args = "-S pkg"
|
|
|
|
self.addrule("PACMAN_RETCODE=1")
|
|
self.addrule("!PKG_EXIST=pkg")
|
|
self.addrule("!PKG_EXIST=cpkg")
|