mirror of
https://github.com/mudler/luet.git
synced 2025-09-05 17:20:29 +00:00
Consider provides during upgrades
This commit is contained in:
@@ -374,6 +374,11 @@ func (db *BoltDatabase) FindPackages(p Package) (Packages, error) {
|
|||||||
|
|
||||||
// FindPackageVersions return the list of the packages beloging to cat/name
|
// FindPackageVersions return the list of the packages beloging to cat/name
|
||||||
func (db *BoltDatabase) FindPackageVersions(p Package) (Packages, error) {
|
func (db *BoltDatabase) FindPackageVersions(p Package) (Packages, error) {
|
||||||
|
// Provides: Treat as the replaced package here
|
||||||
|
if provided, err := db.getProvide(p); err == nil {
|
||||||
|
p = provided
|
||||||
|
}
|
||||||
|
|
||||||
var versionsInWorld []Package
|
var versionsInWorld []Package
|
||||||
for _, w := range db.World() {
|
for _, w := range db.World() {
|
||||||
if w.GetName() != p.GetName() || w.GetCategory() != p.GetCategory() {
|
if w.GetName() != p.GetName() || w.GetCategory() != p.GetCategory() {
|
||||||
|
@@ -225,6 +225,11 @@ func (db *InMemoryDatabase) FindPackage(p Package) (Package, error) {
|
|||||||
|
|
||||||
// FindPackages return the list of the packages beloging to cat/name
|
// FindPackages return the list of the packages beloging to cat/name
|
||||||
func (db *InMemoryDatabase) FindPackageVersions(p Package) (Packages, error) {
|
func (db *InMemoryDatabase) FindPackageVersions(p Package) (Packages, error) {
|
||||||
|
// Provides: Treat as the replaced package here
|
||||||
|
if provided, err := db.getProvide(p); err == nil {
|
||||||
|
p = provided
|
||||||
|
}
|
||||||
|
|
||||||
versions, ok := db.CacheNoVersion[p.GetPackageName()]
|
versions, ok := db.CacheNoVersion[p.GetPackageName()]
|
||||||
if !ok {
|
if !ok {
|
||||||
return nil, errors.New("No versions found for package")
|
return nil, errors.New("No versions found for package")
|
||||||
|
@@ -495,14 +495,20 @@ func (s *Solver) Upgrade(checkconflicts, full bool) (pkg.Packages, PackagesAsser
|
|||||||
availableCache[p.GetName()+p.GetCategory()] = append(availableCache[p.GetName()+p.GetCategory()], p)
|
availableCache[p.GetName()+p.GetCategory()] = append(availableCache[p.GetName()+p.GetCategory()], p)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// we do this in memory so we take into account of provides
|
||||||
|
universe := pkg.NewInMemoryDatabase(false)
|
||||||
|
for _, p := range s.DefinitionDatabase.World() {
|
||||||
|
universe.CreatePackage(p)
|
||||||
|
}
|
||||||
|
|
||||||
installedcopy := pkg.NewInMemoryDatabase(false)
|
installedcopy := pkg.NewInMemoryDatabase(false)
|
||||||
|
|
||||||
for _, p := range s.InstalledDatabase.World() {
|
for _, p := range s.InstalledDatabase.World() {
|
||||||
installedcopy.CreatePackage(p)
|
installedcopy.CreatePackage(p)
|
||||||
packages, ok := availableCache[p.GetName()+p.GetCategory()]
|
packages, err := universe.FindPackageVersions(p)
|
||||||
if ok && len(packages) != 0 {
|
if err == nil && len(packages) != 0 {
|
||||||
best := packages.Best(nil)
|
best := packages.Best(nil)
|
||||||
if best.GetVersion() != p.GetVersion() {
|
if !best.Matches(p) {
|
||||||
toUninstall = append(toUninstall, p)
|
toUninstall = append(toUninstall, p)
|
||||||
toInstall = append(toInstall, best)
|
toInstall = append(toInstall, best)
|
||||||
}
|
}
|
||||||
|
@@ -1209,7 +1209,6 @@ var _ = Describe("Solver", func() {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
Context("Upgrades", func() {
|
Context("Upgrades", func() {
|
||||||
|
|
||||||
C := pkg.NewPackage("c", "1.5", []*pkg.DefaultPackage{&pkg.DefaultPackage{Name: "a", Version: ">=1.0", Category: "test"}}, []*pkg.DefaultPackage{})
|
C := pkg.NewPackage("c", "1.5", []*pkg.DefaultPackage{&pkg.DefaultPackage{Name: "a", Version: ">=1.0", Category: "test"}}, []*pkg.DefaultPackage{})
|
||||||
C.SetCategory("test")
|
C.SetCategory("test")
|
||||||
B := pkg.NewPackage("b", "1.0", []*pkg.DefaultPackage{}, []*pkg.DefaultPackage{})
|
B := pkg.NewPackage("b", "1.0", []*pkg.DefaultPackage{}, []*pkg.DefaultPackage{})
|
||||||
@@ -1219,6 +1218,17 @@ var _ = Describe("Solver", func() {
|
|||||||
A1 := pkg.NewPackage("a", "1.2", []*pkg.DefaultPackage{&pkg.DefaultPackage{Name: "b", Version: "1.0", Category: "test"}}, []*pkg.DefaultPackage{})
|
A1 := pkg.NewPackage("a", "1.2", []*pkg.DefaultPackage{&pkg.DefaultPackage{Name: "b", Version: "1.0", Category: "test"}}, []*pkg.DefaultPackage{})
|
||||||
A1.SetCategory("test")
|
A1.SetCategory("test")
|
||||||
|
|
||||||
|
BeforeEach(func() {
|
||||||
|
C = pkg.NewPackage("c", "1.5", []*pkg.DefaultPackage{&pkg.DefaultPackage{Name: "a", Version: ">=1.0", Category: "test"}}, []*pkg.DefaultPackage{})
|
||||||
|
C.SetCategory("test")
|
||||||
|
B = pkg.NewPackage("b", "1.0", []*pkg.DefaultPackage{}, []*pkg.DefaultPackage{})
|
||||||
|
B.SetCategory("test")
|
||||||
|
A = pkg.NewPackage("a", "1.1", []*pkg.DefaultPackage{&pkg.DefaultPackage{Name: "b", Version: "1.0", Category: "test"}}, []*pkg.DefaultPackage{})
|
||||||
|
A.SetCategory("test")
|
||||||
|
A1 = pkg.NewPackage("a", "1.2", []*pkg.DefaultPackage{&pkg.DefaultPackage{Name: "b", Version: "1.0", Category: "test"}}, []*pkg.DefaultPackage{})
|
||||||
|
A1.SetCategory("test")
|
||||||
|
})
|
||||||
|
|
||||||
It("upgrades correctly", func() {
|
It("upgrades correctly", func() {
|
||||||
for _, p := range []pkg.Package{A1, B, C} {
|
for _, p := range []pkg.Package{A1, B, C} {
|
||||||
_, err := dbDefinitions.CreatePackage(p)
|
_, err := dbDefinitions.CreatePackage(p)
|
||||||
@@ -1240,7 +1250,31 @@ var _ = Describe("Solver", func() {
|
|||||||
Expect(solution).To(ContainElement(PackageAssert{Package: B, Value: true}))
|
Expect(solution).To(ContainElement(PackageAssert{Package: B, Value: true}))
|
||||||
Expect(solution).To(ContainElement(PackageAssert{Package: C, Value: false}))
|
Expect(solution).To(ContainElement(PackageAssert{Package: C, Value: false}))
|
||||||
Expect(len(solution)).To(Equal(3))
|
Expect(len(solution)).To(Equal(3))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("upgrades correctly with provides", func() {
|
||||||
|
B.SetProvides([]*pkg.DefaultPackage{&pkg.DefaultPackage{Name: "a", Version: ">=0", Category: "test"}, &pkg.DefaultPackage{Name: "c", Version: ">=0", Category: "test"}})
|
||||||
|
|
||||||
|
for _, p := range []pkg.Package{A1, B} {
|
||||||
|
_, err := dbDefinitions.CreatePackage(p)
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, p := range []pkg.Package{A, C} {
|
||||||
|
_, err := dbInstalled.CreatePackage(p)
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
}
|
||||||
|
uninstall, solution, err := s.Upgrade(true, true)
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
|
||||||
|
Expect(len(uninstall)).To(Equal(2))
|
||||||
|
Expect(uninstall[1].GetName()).To(Equal("c"))
|
||||||
|
Expect(uninstall[1].GetVersion()).To(Equal("1.5"))
|
||||||
|
Expect(uninstall[0].GetName()).To(Equal("a"))
|
||||||
|
Expect(uninstall[0].GetVersion()).To(Equal("1.1"))
|
||||||
|
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: B, Value: true}))
|
||||||
|
Expect(len(solution)).To(Equal(1))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("UpgradeUniverse upgrades correctly", func() {
|
It("UpgradeUniverse upgrades correctly", func() {
|
||||||
|
Reference in New Issue
Block a user