mirror of
https://github.com/mudler/luet.git
synced 2025-09-03 08:14:46 +00:00
Add assertion hashing
This commit is contained in:
@@ -16,6 +16,7 @@
|
|||||||
package solver
|
package solver
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"crypto/sha256"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
pkg "github.com/mudler/luet/pkg/package"
|
pkg "github.com/mudler/luet/pkg/package"
|
||||||
@@ -102,3 +103,33 @@ func (assertions PackagesAssertions) Order() PackagesAssertions {
|
|||||||
|
|
||||||
return orderedAssertions
|
return orderedAssertions
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (assertions PackagesAssertions) Explain() string {
|
||||||
|
var fingerprint string
|
||||||
|
for _, assertion := range assertions.Order() { // Always order them
|
||||||
|
fingerprint += assertion.ToString() + "\n"
|
||||||
|
}
|
||||||
|
return fingerprint
|
||||||
|
}
|
||||||
|
|
||||||
|
func (assertions PackagesAssertions) AssertionHash() string {
|
||||||
|
var fingerprint string
|
||||||
|
for _, assertion := range assertions.Order() { // Always order them
|
||||||
|
if assertion.Value && assertion.Package.Flagged() { // Tke into account only dependencies installed (get fingerprint of subgraph)
|
||||||
|
fingerprint += assertion.ToString() + "\n"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
hash := sha256.Sum256([]byte(fingerprint))
|
||||||
|
return fmt.Sprintf("%x", hash)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (assertions PackagesAssertions) Drop(p pkg.Package) PackagesAssertions {
|
||||||
|
ass := PackagesAssertions{}
|
||||||
|
|
||||||
|
for _, a := range assertions {
|
||||||
|
if a.Package.GetFingerPrint() != p.GetFingerPrint() {
|
||||||
|
ass = append(ass, a)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ass
|
||||||
|
}
|
||||||
|
@@ -129,4 +129,72 @@ var _ = Describe("Decoder", func() {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Context("Assertion hashing", func() {
|
||||||
|
It("Hashes them, and could be used for comparison", func() {
|
||||||
|
C := pkg.NewPackage("C", "", []*pkg.DefaultPackage{}, []*pkg.DefaultPackage{})
|
||||||
|
E := pkg.NewPackage("E", "", []*pkg.DefaultPackage{}, []*pkg.DefaultPackage{})
|
||||||
|
F := pkg.NewPackage("F", "", []*pkg.DefaultPackage{}, []*pkg.DefaultPackage{})
|
||||||
|
G := pkg.NewPackage("G", "", []*pkg.DefaultPackage{}, []*pkg.DefaultPackage{})
|
||||||
|
H := pkg.NewPackage("H", "", []*pkg.DefaultPackage{G}, []*pkg.DefaultPackage{})
|
||||||
|
D := pkg.NewPackage("D", "", []*pkg.DefaultPackage{H}, []*pkg.DefaultPackage{})
|
||||||
|
B := pkg.NewPackage("B", "", []*pkg.DefaultPackage{D}, []*pkg.DefaultPackage{})
|
||||||
|
A := pkg.NewPackage("A", "", []*pkg.DefaultPackage{B}, []*pkg.DefaultPackage{})
|
||||||
|
|
||||||
|
s := NewSolver([]pkg.Package{C}, []pkg.Package{A, B, C, D, E, F, G})
|
||||||
|
|
||||||
|
solution, err := s.Install([]pkg.Package{A})
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: A.IsFlagged(true), Value: true}))
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: B.IsFlagged(true), Value: true}))
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: D.IsFlagged(true), Value: true}))
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: C.IsFlagged(true), Value: true}))
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: H.IsFlagged(true), Value: true}))
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: G.IsFlagged(true), Value: true}))
|
||||||
|
|
||||||
|
Expect(len(solution)).To(Equal(6))
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
solution = solution.Order()
|
||||||
|
Expect(len(solution)).To(Equal(6))
|
||||||
|
Expect(solution[0].Package.GetName()).To(Equal("G"))
|
||||||
|
Expect(solution[1].Package.GetName()).To(Equal("H"))
|
||||||
|
Expect(solution[2].Package.GetName()).To(Equal("D"))
|
||||||
|
Expect(solution[3].Package.GetName()).To(Equal("B"))
|
||||||
|
|
||||||
|
hash := solution.AssertionHash()
|
||||||
|
|
||||||
|
solution, err = s.Install([]pkg.Package{B})
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: B.IsFlagged(true), Value: true}))
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: D.IsFlagged(true), Value: true}))
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: C.IsFlagged(true), Value: true}))
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: H.IsFlagged(true), Value: true}))
|
||||||
|
Expect(solution).To(ContainElement(PackageAssert{Package: G.IsFlagged(true), Value: true}))
|
||||||
|
|
||||||
|
Expect(len(solution)).To(Equal(6))
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
solution = solution.Order()
|
||||||
|
hash2 := solution.AssertionHash()
|
||||||
|
|
||||||
|
Expect(len(solution)).To(Equal(6))
|
||||||
|
Expect(solution[0].Package.GetName()).To(Equal("G"))
|
||||||
|
Expect(solution[1].Package.GetName()).To(Equal("H"))
|
||||||
|
Expect(solution[2].Package.GetName()).To(Equal("D"))
|
||||||
|
Expect(solution[3].Package.GetName()).To(Equal("B"))
|
||||||
|
|
||||||
|
Expect(hash).ToNot(Equal(""))
|
||||||
|
Expect(hash2).ToNot(Equal(""))
|
||||||
|
Expect(hash != hash2).To(BeTrue())
|
||||||
|
|
||||||
|
X := pkg.NewPackage("X", "", []*pkg.DefaultPackage{}, []*pkg.DefaultPackage{})
|
||||||
|
Y := pkg.NewPackage("Y", "", []*pkg.DefaultPackage{X}, []*pkg.DefaultPackage{})
|
||||||
|
Z := pkg.NewPackage("Z", "", []*pkg.DefaultPackage{X}, []*pkg.DefaultPackage{})
|
||||||
|
s = NewSolver([]pkg.Package{}, []pkg.Package{X, Y, Z})
|
||||||
|
solution, err = s.Install([]pkg.Package{Y})
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
|
||||||
|
solution2, err := s.Install([]pkg.Package{Z})
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
Expect(solution.Drop(Y).AssertionHash() == solution2.Drop(Z).AssertionHash()).To(BeTrue())
|
||||||
|
})
|
||||||
|
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
Reference in New Issue
Block a user