mirror of
https://github.com/mudler/luet.git
synced 2025-09-03 08:14:46 +00:00
Fix compilation and hash image calculation. Tests fails on spec (installing d)
This commit is contained in:
@@ -123,7 +123,7 @@ func (cs *LuetCompiler) compileWithImage(image, buildertaggedImage, packageImage
|
|||||||
|
|
||||||
err = cs.Backend.BuildImage(builderOpts)
|
err = cs.Backend.BuildImage(builderOpts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.Wrap(err, "Could not build image: "+image)
|
return nil, errors.Wrap(err, "Could not build image: "+image+" "+builderOpts.DockerFileName)
|
||||||
}
|
}
|
||||||
|
|
||||||
err = cs.Backend.ExportImage(builderOpts)
|
err = cs.Backend.ExportImage(builderOpts)
|
||||||
@@ -147,7 +147,7 @@ func (cs *LuetCompiler) compileWithImage(image, buildertaggedImage, packageImage
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if err := cs.Backend.BuildImage(runnerOpts); err != nil {
|
if err := cs.Backend.BuildImage(runnerOpts); err != nil {
|
||||||
return nil, errors.Wrap(err, "Failed building image")
|
return nil, errors.Wrap(err, "Failed building image for "+runnerOpts.ImageName+" "+runnerOpts.DockerFileName)
|
||||||
}
|
}
|
||||||
if err := cs.Backend.ExportImage(runnerOpts); err != nil {
|
if err := cs.Backend.ExportImage(runnerOpts); err != nil {
|
||||||
return nil, errors.Wrap(err, "Failed exporting image")
|
return nil, errors.Wrap(err, "Failed exporting image")
|
||||||
@@ -168,6 +168,9 @@ func (cs *LuetCompiler) compileWithImage(image, buildertaggedImage, packageImage
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
rootfs, err := ioutil.TempDir(p.GetOutputPath(), "rootfs")
|
rootfs, err := ioutil.TempDir(p.GetOutputPath(), "rootfs")
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrap(err, "Could not create tempdir")
|
||||||
|
}
|
||||||
defer os.RemoveAll(rootfs) // clean up
|
defer os.RemoveAll(rootfs) // clean up
|
||||||
|
|
||||||
// TODO: Compression and such
|
// TODO: Compression and such
|
||||||
@@ -184,6 +187,12 @@ func (cs *LuetCompiler) compileWithImage(image, buildertaggedImage, packageImage
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (cs *LuetCompiler) Compile(concurrency int, keepPermissions bool, p CompilationSpec) (Artifact, error) {
|
func (cs *LuetCompiler) Compile(concurrency int, keepPermissions bool, p CompilationSpec) (Artifact, error) {
|
||||||
|
Debug("Compiling " + p.GetPackage().GetName())
|
||||||
|
|
||||||
|
if len(p.GetPackage().GetRequires()) == 0 && p.GetImage() == "" {
|
||||||
|
Error("Package with no deps and no seed image supplied, bailing out")
|
||||||
|
return nil, errors.New("Package " + p.GetPackage().GetFingerPrint() + "with no deps and no seed image supplied, bailing out")
|
||||||
|
}
|
||||||
|
|
||||||
// - If image is not set, we read a base_image. Then we will build one image from it to kick-off our build based
|
// - If image is not set, we read a base_image. Then we will build one image from it to kick-off our build based
|
||||||
// on how we compute the resolvable tree.
|
// on how we compute the resolvable tree.
|
||||||
@@ -203,42 +212,52 @@ func (cs *LuetCompiler) Compile(concurrency int, keepPermissions bool, p Compila
|
|||||||
}
|
}
|
||||||
|
|
||||||
s := solver.NewSolver([]pkg.Package{}, world)
|
s := solver.NewSolver([]pkg.Package{}, world)
|
||||||
solution, err := s.Install([]pkg.Package{p.GetPackage()})
|
pack, err := cs.Tree().FindPackage(p.GetPackage())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.Wrap(err, "While computing a solution for "+p.GetPackage().GetName())
|
return nil, errors.Wrap(err, "While computing a solution for "+p.GetPackage().GetName())
|
||||||
}
|
}
|
||||||
|
solution, err := s.Install([]pkg.Package{pack})
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrap(err, "While computing a solution for "+p.GetPackage().GetName())
|
||||||
|
}
|
||||||
|
Info("Build dependencies: ( target "+p.GetPackage().GetName()+")", solution.Explain())
|
||||||
|
|
||||||
dependencies := solution.Drop(p.GetPackage()).Order() // at this point we should have a flattened list of deps to build, including all of them (with all constraints propagated already)
|
dependencies := solution.Drop(p.GetPackage()).Order() // at this point we should have a flattened list of deps to build, including all of them (with all constraints propagated already)
|
||||||
departifacts := []Artifact{} // TODO: Return this somehow
|
departifacts := []Artifact{} // TODO: Return this somehow
|
||||||
deperrs := []error{}
|
deperrs := []error{}
|
||||||
var lastHash string
|
var lastHash string
|
||||||
Info("Build dependencies:", dependencies.Explain())
|
//Info("Build dependencies: ( target "+p.GetPackage().GetName()+")", dependencies.Explain())
|
||||||
|
|
||||||
if len(dependencies[0].Package.GetRequires()) != 0 {
|
if len(dependencies[0].Package.GetRequires()) != 0 {
|
||||||
return nil, errors.New("The first dependency of the deptree doesn't have an image base")
|
return nil, errors.New("The first dependency of the deptree doesn't have an image base")
|
||||||
}
|
}
|
||||||
for _, assertion := range dependencies { //highly dependent on the order
|
for _, assertion := range dependencies { //highly dependent on the order
|
||||||
if assertion.Value && assertion.Package.Flagged() {
|
if assertion.Value && assertion.Package.Flagged() {
|
||||||
Info("Building", assertion.Package.GetName())
|
Info("( target "+p.GetPackage().GetName()+") Building", assertion.Package.GetName())
|
||||||
compileSpec, err := cs.FromPackage(assertion.Package)
|
compileSpec, err := cs.FromPackage(assertion.Package)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.New("Error while generating compilespec for " + assertion.Package.GetName())
|
return nil, errors.New("Error while generating compilespec for " + assertion.Package.GetName())
|
||||||
}
|
}
|
||||||
compileSpec.SetOutputPath(p.GetOutputPath())
|
compileSpec.SetOutputPath(p.GetOutputPath())
|
||||||
pack, err := cs.Tree().FindPackage(p.GetPackage())
|
depPack, err := cs.Tree().FindPackage(assertion.Package)
|
||||||
if err != nil {
|
|
||||||
return nil, errors.Wrap(err, "While computing a solution for "+p.GetPackage().GetName())
|
|
||||||
}
|
|
||||||
//TODO: Generate image name of builder image - it should match with the hash up to this point - package
|
|
||||||
nthsolution, err := s.Install([]pkg.Package{pack})
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.Wrap(err, "While computing a solution for "+p.GetPackage().GetName())
|
return nil, errors.Wrap(err, "While computing a solution for "+p.GetPackage().GetName())
|
||||||
}
|
}
|
||||||
|
|
||||||
buildImageHash := "luet/cache-" + nthsolution.Drop(p.GetPackage()).AssertionHash()
|
// Generate image name of builder image - it should match with the hash up to this point - package
|
||||||
|
nthsolution, err := s.Install([]pkg.Package{depPack})
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrap(err, "While computing a solution for "+p.GetPackage().GetName())
|
||||||
|
}
|
||||||
|
|
||||||
|
buildImageHash := "luet/cache-" + nthsolution.Drop(depPack).AssertionHash()
|
||||||
currentPackageImageHash := "luet/cache-" + nthsolution.AssertionHash()
|
currentPackageImageHash := "luet/cache-" + nthsolution.AssertionHash()
|
||||||
|
Debug("("+p.GetPackage().GetName()+") Builder image name:", buildImageHash)
|
||||||
|
Debug("("+p.GetPackage().GetName()+") Package image name:", currentPackageImageHash)
|
||||||
|
|
||||||
lastHash = currentPackageImageHash
|
lastHash = currentPackageImageHash
|
||||||
if compileSpec.GetImage() != "" {
|
if compileSpec.GetImage() != "" {
|
||||||
|
Debug("(" + p.GetPackage().GetName() + ") Compiling " + compileSpec.GetPackage().GetFingerPrint() + " from image")
|
||||||
artifact, err := cs.compileWithImage(compileSpec.GetImage(), buildImageHash, currentPackageImageHash, concurrency, keepPermissions, compileSpec)
|
artifact, err := cs.compileWithImage(compileSpec.GetImage(), buildImageHash, currentPackageImageHash, concurrency, keepPermissions, compileSpec)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
deperrs = append(deperrs, err)
|
deperrs = append(deperrs, err)
|
||||||
@@ -257,6 +276,7 @@ func (cs *LuetCompiler) Compile(concurrency int, keepPermissions bool, p Compila
|
|||||||
departifacts = append(departifacts, artifact)
|
departifacts = append(departifacts, artifact)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Debug("("+p.GetPackage().GetName()+") Building target from", lastHash)
|
||||||
|
|
||||||
return cs.compileWithImage(lastHash, "", "", concurrency, keepPermissions, p)
|
return cs.compileWithImage(lastHash, "", "", concurrency, keepPermissions, p)
|
||||||
}
|
}
|
||||||
|
@@ -116,21 +116,25 @@ var _ = Describe("Compiler", func() {
|
|||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
Expect(generalRecipe.Tree()).ToNot(BeNil()) // It should be populated back at this point
|
Expect(generalRecipe.Tree()).ToNot(BeNil()) // It should be populated back at this point
|
||||||
|
|
||||||
Expect(len(generalRecipe.Tree().GetPackageSet().GetPackages())).To(Equal(3))
|
Expect(len(generalRecipe.Tree().GetPackageSet().GetPackages())).To(Equal(4))
|
||||||
|
|
||||||
compiler := NewLuetCompiler(sd.NewSimpleDockerBackend(), generalRecipe.Tree())
|
compiler := NewLuetCompiler(sd.NewSimpleDockerBackend(), generalRecipe.Tree())
|
||||||
spec, err := compiler.FromPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
spec, err := compiler.FromPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
spec2, err := compiler.FromPackage(&pkg.DefaultPackage{Name: "a", Category: "test", Version: "1.0"})
|
spec2, err := compiler.FromPackage(&pkg.DefaultPackage{Name: "a", Category: "test", Version: "1.0"})
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
spec3, err := compiler.FromPackage(&pkg.DefaultPackage{Name: "d", Category: "test", Version: "1.0"})
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
|
||||||
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
||||||
|
|
||||||
spec.SetOutputPath(tmpdir)
|
spec.SetOutputPath(tmpdir)
|
||||||
spec2.SetOutputPath(tmpdir)
|
spec2.SetOutputPath(tmpdir)
|
||||||
artifacts, errs := compiler.CompileParallel(2, false, []CompilationSpec{spec, spec2})
|
spec3.SetOutputPath(tmpdir)
|
||||||
Expect(errs).To(Equal(""))
|
artifacts, errs := compiler.CompileParallel(2, false, []CompilationSpec{spec, spec2, spec3})
|
||||||
Expect(len(errs)).To(Equal(0))
|
Expect(errs).To(BeNil())
|
||||||
|
Expect(len(artifacts)).To(Equal(3))
|
||||||
|
|
||||||
for _, artifact := range artifacts {
|
for _, artifact := range artifacts {
|
||||||
Expect(helpers.Exists(artifact.GetPath())).To(BeTrue())
|
Expect(helpers.Exists(artifact.GetPath())).To(BeTrue())
|
||||||
Expect(helpers.Untar(artifact.GetPath(), tmpdir, false)).ToNot(HaveOccurred())
|
Expect(helpers.Untar(artifact.GetPath(), tmpdir, false)).ToNot(HaveOccurred())
|
||||||
|
@@ -71,10 +71,10 @@ func (assertions PackagesAssertions) Order() PackagesAssertions {
|
|||||||
tmpMap := map[string]PackageAssert{}
|
tmpMap := map[string]PackageAssert{}
|
||||||
|
|
||||||
for _, a := range assertions {
|
for _, a := range assertions {
|
||||||
|
tmpMap[a.Package.GetFingerPrint()] = a
|
||||||
if a.Package.Flagged() {
|
if a.Package.Flagged() {
|
||||||
unorderedAssertions = append(unorderedAssertions, a) // Build a list of the ones that must be ordered
|
unorderedAssertions = append(unorderedAssertions, a) // Build a list of the ones that must be ordered
|
||||||
fingerprints = append(fingerprints, a.Package.GetFingerPrint())
|
fingerprints = append(fingerprints, a.Package.GetFingerPrint())
|
||||||
tmpMap[a.Package.GetFingerPrint()] = a
|
|
||||||
} else {
|
} else {
|
||||||
orderedAssertions = append(orderedAssertions, a) // Keep last the ones which are not meant to be installed
|
orderedAssertions = append(orderedAssertions, a) // Keep last the ones which are not meant to be installed
|
||||||
}
|
}
|
||||||
@@ -92,13 +92,12 @@ func (assertions PackagesAssertions) Order() PackagesAssertions {
|
|||||||
if !ok {
|
if !ok {
|
||||||
panic("cycle detected")
|
panic("cycle detected")
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, res := range result {
|
for _, res := range result {
|
||||||
a, ok := tmpMap[res]
|
a, ok := tmpMap[res]
|
||||||
if !ok {
|
if !ok {
|
||||||
panic("Sort order - this shouldn't happen")
|
continue
|
||||||
}
|
}
|
||||||
orderedAssertions = append([]PackageAssert{a}, orderedAssertions...) // push upfront
|
orderedAssertions = append(PackagesAssertions{a}, orderedAssertions...) // push upfront
|
||||||
}
|
}
|
||||||
|
|
||||||
return orderedAssertions
|
return orderedAssertions
|
||||||
|
@@ -55,7 +55,6 @@ func (r *CompilerRecipe) Load(path string) error {
|
|||||||
r.Tree().SetPackageSet(pkg.NewInMemoryDatabase(false))
|
r.Tree().SetPackageSet(pkg.NewInMemoryDatabase(false))
|
||||||
//r.Tree().SetPackageSet(pkg.NewBoltDatabase(tmpfile.Name()))
|
//r.Tree().SetPackageSet(pkg.NewBoltDatabase(tmpfile.Name()))
|
||||||
// TODO: Handle cleaning after? Cleanup implemented in GetPackageSet().Clean()
|
// TODO: Handle cleaning after? Cleanup implemented in GetPackageSet().Clean()
|
||||||
|
|
||||||
// the function that handles each file or dir
|
// the function that handles each file or dir
|
||||||
var ff = func(currentpath string, info os.FileInfo, err error) error {
|
var ff = func(currentpath string, info os.FileInfo, err error) error {
|
||||||
|
|
||||||
@@ -78,7 +77,7 @@ func (r *CompilerRecipe) Load(path string) error {
|
|||||||
// Instead of rdeps, have a different tree for build deps.
|
// Instead of rdeps, have a different tree for build deps.
|
||||||
compileDefPath := pack.Rel(CompilerDefinitionFile)
|
compileDefPath := pack.Rel(CompilerDefinitionFile)
|
||||||
if helpers.Exists(compileDefPath) {
|
if helpers.Exists(compileDefPath) {
|
||||||
dat, err = ioutil.ReadFile(currentpath)
|
dat, err = ioutil.ReadFile(compileDefPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Wrap(err, "Error reading file "+currentpath)
|
return errors.Wrap(err, "Error reading file "+currentpath)
|
||||||
}
|
}
|
||||||
@@ -104,3 +103,6 @@ func (r *CompilerRecipe) Load(path string) error {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (r *CompilerRecipe) Tree() pkg.Tree { return r.PackageTree }
|
||||||
|
func (r *CompilerRecipe) WithTree(t pkg.Tree) { r.PackageTree = t }
|
||||||
|
Reference in New Issue
Block a user