2019-11-22 22:12:03 +00:00
|
|
|
// Copyright © 2019 Ettore Di Giacinto <mudler@gentoo.org>
|
|
|
|
//
|
|
|
|
// This program is free software; you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation; either version 2 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License along
|
|
|
|
// with this program; if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
package installer_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
2019-11-23 11:19:05 +00:00
|
|
|
"path/filepath"
|
2019-11-22 22:12:03 +00:00
|
|
|
|
|
|
|
// . "github.com/mudler/luet/pkg/installer"
|
|
|
|
compiler "github.com/mudler/luet/pkg/compiler"
|
2019-11-22 23:29:24 +00:00
|
|
|
backend "github.com/mudler/luet/pkg/compiler/backend"
|
2019-11-22 22:12:03 +00:00
|
|
|
"github.com/mudler/luet/pkg/helpers"
|
2019-11-22 23:29:24 +00:00
|
|
|
. "github.com/mudler/luet/pkg/installer"
|
2019-11-22 22:12:03 +00:00
|
|
|
pkg "github.com/mudler/luet/pkg/package"
|
|
|
|
"github.com/mudler/luet/pkg/tree"
|
|
|
|
. "github.com/onsi/ginkgo"
|
|
|
|
. "github.com/onsi/gomega"
|
|
|
|
)
|
|
|
|
|
|
|
|
var _ = Describe("Installer", func() {
|
|
|
|
Context("Writes a repository definition", func() {
|
2019-11-25 19:02:43 +00:00
|
|
|
It("Writes a repo and can install packages from it", func() {
|
2019-12-31 00:21:06 +00:00
|
|
|
//repo:=NewLuetSystemRepository()
|
2019-11-22 22:12:03 +00:00
|
|
|
|
|
|
|
tmpdir, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe.Load("../../tests/fixtures/buildable")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
2019-11-29 18:01:52 +00:00
|
|
|
Expect(len(generalRecipe.GetDatabase().GetPackages())).To(Equal(3))
|
2019-11-22 22:12:03 +00:00
|
|
|
|
2020-03-24 23:19:40 +00:00
|
|
|
c := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
2019-11-22 22:12:03 +00:00
|
|
|
|
2020-03-24 23:19:40 +00:00
|
|
|
spec, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
2019-11-22 22:12:03 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
tmpdir, err = ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
Expect(spec.BuildSteps()).To(Equal([]string{"echo artifact5 > /test5", "echo artifact6 > /test6", "./generate.sh"}))
|
|
|
|
Expect(spec.GetPreBuildSteps()).To(Equal([]string{"echo foo > /test", "echo bar > /test2", "chmod +x generate.sh"}))
|
|
|
|
|
|
|
|
spec.SetOutputPath(tmpdir)
|
2020-03-24 23:19:40 +00:00
|
|
|
c.SetConcurrency(2)
|
2019-12-30 13:46:45 +00:00
|
|
|
|
2020-03-24 23:19:40 +00:00
|
|
|
artifact, err := c.Compile(false, spec)
|
2019-11-22 22:12:03 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Exists(artifact.GetPath())).To(BeTrue())
|
|
|
|
Expect(helpers.Untar(artifact.GetPath(), tmpdir, false)).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel("test6"))).To(BeTrue())
|
|
|
|
|
|
|
|
content1, err := helpers.Read(spec.Rel("test5"))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
content2, err := helpers.Read(spec.Rel("test6"))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(content1).To(Equal("artifact5\n"))
|
|
|
|
Expect(content2).To(Equal("artifact6\n"))
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.0.package.tar"))).To(BeTrue())
|
2019-11-22 22:24:22 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.0.metadata.yaml"))).To(BeTrue())
|
2019-11-22 22:12:03 +00:00
|
|
|
|
2019-12-31 00:21:06 +00:00
|
|
|
repo, err := GenerateRepository("test", "description", "disk", []string{tmpdir}, 1, tmpdir, "../../tests/fixtures/buildable", pkg.NewInMemoryDatabase(false))
|
2019-11-22 23:29:24 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
2019-11-23 11:19:05 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).ToNot(BeTrue())
|
2020-03-24 11:52:45 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).ToNot(BeTrue())
|
2020-01-04 14:53:22 +00:00
|
|
|
err = repo.Write(tmpdir, false)
|
2019-11-23 11:19:05 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).To(BeTrue())
|
2020-03-24 11:52:45 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).To(BeTrue())
|
2019-12-30 21:51:51 +00:00
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
2019-12-29 15:17:45 +00:00
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
2019-11-23 11:19:05 +00:00
|
|
|
|
|
|
|
fakeroot, err := ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
2020-02-12 11:05:28 +00:00
|
|
|
inst := NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
2019-12-31 00:21:06 +00:00
|
|
|
repo2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
2019-11-23 11:19:05 +00:00
|
|
|
name: "test"
|
2019-12-29 15:17:45 +00:00
|
|
|
type: "disk"
|
2019-12-30 21:51:51 +00:00
|
|
|
urls:
|
|
|
|
- "`+tmpdir+`"
|
2019-11-23 14:42:05 +00:00
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
2019-11-23 11:19:05 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
2019-12-30 21:51:51 +00:00
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
2019-12-29 15:17:45 +00:00
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
2019-11-23 11:19:05 +00:00
|
|
|
systemDB := pkg.NewInMemoryDatabase(false)
|
|
|
|
system := &System{Database: systemDB, Target: fakeroot}
|
2020-04-13 16:49:05 +00:00
|
|
|
err = inst.Install([]pkg.Package{&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}}, system)
|
2019-11-23 11:19:05 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).To(BeTrue())
|
2019-11-23 17:58:34 +00:00
|
|
|
_, err = systemDB.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
2019-11-23 21:41:51 +00:00
|
|
|
|
|
|
|
files, err := systemDB.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(files).To(Equal([]string{"artifact42", "test5", "test6"}))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
2019-11-23 23:16:12 +00:00
|
|
|
|
2019-11-25 19:02:43 +00:00
|
|
|
Expect(len(system.Database.GetPackages())).To(Equal(1))
|
|
|
|
p, err := system.Database.GetPackage(system.Database.GetPackages()[0])
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(p.GetName()).To(Equal("b"))
|
|
|
|
|
2019-11-23 23:16:12 +00:00
|
|
|
err = inst.Uninstall(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}, system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
// Nothing should be there anymore (files, packagedb entry)
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).ToNot(BeTrue())
|
|
|
|
|
|
|
|
_, err = systemDB.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
_, err = systemDB.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
2019-11-22 22:12:03 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
})
|
2019-11-25 19:02:43 +00:00
|
|
|
|
2020-03-24 23:19:40 +00:00
|
|
|
Context("Writes a repository definition without compression", func() {
|
|
|
|
It("Writes a repo and can install packages from it", func() {
|
|
|
|
//repo:=NewLuetSystemRepository()
|
|
|
|
|
|
|
|
tmpdir, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe.Load("../../tests/fixtures/buildable")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(generalRecipe.GetDatabase().GetPackages())).To(Equal(3))
|
|
|
|
|
|
|
|
c := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(),
|
|
|
|
generalRecipe.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
|
|
|
|
|
|
|
spec, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
tmpdir, err = ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
Expect(spec.BuildSteps()).To(Equal([]string{"echo artifact5 > /test5", "echo artifact6 > /test6", "./generate.sh"}))
|
|
|
|
Expect(spec.GetPreBuildSteps()).To(Equal([]string{"echo foo > /test", "echo bar > /test2", "chmod +x generate.sh"}))
|
|
|
|
|
|
|
|
spec.SetOutputPath(tmpdir)
|
|
|
|
c.SetConcurrency(2)
|
|
|
|
|
|
|
|
artifact, err := c.Compile(false, spec)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Exists(artifact.GetPath())).To(BeTrue())
|
|
|
|
Expect(helpers.Untar(artifact.GetPath(), tmpdir, false)).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel("test6"))).To(BeTrue())
|
|
|
|
|
|
|
|
content1, err := helpers.Read(spec.Rel("test5"))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
content2, err := helpers.Read(spec.Rel("test6"))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(content1).To(Equal("artifact5\n"))
|
|
|
|
Expect(content2).To(Equal("artifact6\n"))
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.0.package.tar"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.0.metadata.yaml"))).To(BeTrue())
|
|
|
|
|
|
|
|
repo, err := GenerateRepository("test", "description", "disk", []string{tmpdir}, 1, tmpdir, "../../tests/fixtures/buildable", pkg.NewInMemoryDatabase(false))
|
|
|
|
treeFile := NewDefaultTreeRepositoryFile()
|
|
|
|
treeFile.SetCompressionType(compiler.None)
|
|
|
|
repo.SetRepositoryFile(REPOFILE_TREE_KEY, treeFile)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).ToNot(BeTrue())
|
|
|
|
err = repo.Write(tmpdir, false)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).To(BeTrue())
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
|
|
|
|
fakeroot, err := ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
|
|
|
inst := NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
|
|
|
repo2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
|
|
|
name: "test"
|
|
|
|
type: "disk"
|
|
|
|
urls:
|
|
|
|
- "`+tmpdir+`"
|
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
systemDB := pkg.NewInMemoryDatabase(false)
|
|
|
|
system := &System{Database: systemDB, Target: fakeroot}
|
2020-04-13 16:49:05 +00:00
|
|
|
err = inst.Install([]pkg.Package{&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}}, system)
|
2020-03-24 23:19:40 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).To(BeTrue())
|
|
|
|
_, err = systemDB.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
files, err := systemDB.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(files).To(Equal([]string{"artifact42", "test5", "test6"}))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(system.Database.GetPackages())).To(Equal(1))
|
|
|
|
p, err := system.Database.GetPackage(system.Database.GetPackages()[0])
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(p.GetName()).To(Equal("b"))
|
|
|
|
|
|
|
|
err = inst.Uninstall(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}, system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
// Nothing should be there anymore (files, packagedb entry)
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).ToNot(BeTrue())
|
|
|
|
|
|
|
|
_, err = systemDB.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
_, err = systemDB.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
})
|
|
|
|
|
|
|
|
})
|
|
|
|
|
2019-11-25 19:02:43 +00:00
|
|
|
Context("Installation", func() {
|
|
|
|
It("Installs in a system with a persistent db", func() {
|
2019-12-31 00:21:06 +00:00
|
|
|
//repo:=NewLuetSystemRepository()
|
2019-11-25 19:02:43 +00:00
|
|
|
|
|
|
|
tmpdir, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe.Load("../../tests/fixtures/buildable")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
2019-11-29 18:01:52 +00:00
|
|
|
Expect(len(generalRecipe.GetDatabase().GetPackages())).To(Equal(3))
|
2019-11-25 19:02:43 +00:00
|
|
|
|
2020-03-24 23:19:40 +00:00
|
|
|
c := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
2019-11-25 19:02:43 +00:00
|
|
|
|
2020-03-24 23:19:40 +00:00
|
|
|
spec, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
2019-11-25 19:02:43 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
tmpdir, err = ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
Expect(spec.BuildSteps()).To(Equal([]string{"echo artifact5 > /test5", "echo artifact6 > /test6", "./generate.sh"}))
|
|
|
|
Expect(spec.GetPreBuildSteps()).To(Equal([]string{"echo foo > /test", "echo bar > /test2", "chmod +x generate.sh"}))
|
|
|
|
|
|
|
|
spec.SetOutputPath(tmpdir)
|
2020-03-24 23:19:40 +00:00
|
|
|
c.SetConcurrency(2)
|
2019-12-30 13:46:45 +00:00
|
|
|
|
2020-03-24 23:19:40 +00:00
|
|
|
artifact, err := c.Compile(false, spec)
|
2019-11-25 19:02:43 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Exists(artifact.GetPath())).To(BeTrue())
|
|
|
|
Expect(helpers.Untar(artifact.GetPath(), tmpdir, false)).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel("test6"))).To(BeTrue())
|
|
|
|
|
|
|
|
content1, err := helpers.Read(spec.Rel("test5"))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
content2, err := helpers.Read(spec.Rel("test6"))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(content1).To(Equal("artifact5\n"))
|
|
|
|
Expect(content2).To(Equal("artifact6\n"))
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.0.package.tar"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.0.metadata.yaml"))).To(BeTrue())
|
|
|
|
|
2019-12-31 00:21:06 +00:00
|
|
|
repo, err := GenerateRepository("test", "description", "disk", []string{tmpdir}, 1, tmpdir, "../../tests/fixtures/buildable", pkg.NewInMemoryDatabase(false))
|
2019-11-25 19:02:43 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).ToNot(BeTrue())
|
2020-03-24 11:52:45 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).ToNot(BeTrue())
|
2020-03-24 13:01:22 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).ToNot(BeTrue())
|
2020-01-04 14:53:22 +00:00
|
|
|
err = repo.Write(tmpdir, false)
|
2019-11-25 19:02:43 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).To(BeTrue())
|
2020-03-24 11:52:45 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).To(BeTrue())
|
2020-03-24 13:01:22 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).To(BeTrue())
|
2019-12-30 21:51:51 +00:00
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
2019-12-29 15:17:45 +00:00
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
2019-11-25 19:02:43 +00:00
|
|
|
|
|
|
|
fakeroot, err := ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
2020-02-12 11:05:28 +00:00
|
|
|
inst := NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
2019-12-31 00:21:06 +00:00
|
|
|
repo2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
2019-11-25 19:02:43 +00:00
|
|
|
name: "test"
|
2019-12-29 15:17:45 +00:00
|
|
|
type: "disk"
|
2019-12-30 21:51:51 +00:00
|
|
|
urls:
|
|
|
|
- "`+tmpdir+`"
|
2019-11-25 19:02:43 +00:00
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
2019-12-30 21:51:51 +00:00
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
2019-12-29 15:17:45 +00:00
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
2019-11-25 19:02:43 +00:00
|
|
|
|
|
|
|
bolt, err := ioutil.TempDir("", "db")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(bolt) // clean up
|
|
|
|
|
|
|
|
systemDB := pkg.NewBoltDatabase(filepath.Join(bolt, "db.db"))
|
|
|
|
system := &System{Database: systemDB, Target: fakeroot}
|
2020-04-13 16:49:05 +00:00
|
|
|
err = inst.Install([]pkg.Package{&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}}, system)
|
2019-11-25 19:02:43 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).To(BeTrue())
|
|
|
|
_, err = systemDB.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(system.Database.GetPackages())).To(Equal(1))
|
|
|
|
p, err := system.Database.GetPackage(system.Database.GetPackages()[0])
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(p.GetName()).To(Equal("b"))
|
|
|
|
|
|
|
|
files, err := systemDB.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(files).To(Equal([]string{"artifact42", "test5", "test6"}))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
err = inst.Uninstall(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}, system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
// Nothing should be there anymore (files, packagedb entry)
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).ToNot(BeTrue())
|
|
|
|
|
|
|
|
_, err = system.Database.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
|
|
|
|
})
|
|
|
|
|
2020-05-02 11:27:15 +00:00
|
|
|
It("Installs new packages from a syste with others installed", func() {
|
2020-05-02 11:24:46 +00:00
|
|
|
//repo:=NewLuetSystemRepository()
|
|
|
|
|
|
|
|
tmpdir, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe.Load("../../tests/fixtures/buildable")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(generalRecipe.GetDatabase().GetPackages())).To(Equal(3))
|
|
|
|
|
|
|
|
c := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
|
|
|
|
|
|
|
spec, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
tmpdir, err = ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
Expect(spec.BuildSteps()).To(Equal([]string{"echo artifact5 > /test5", "echo artifact6 > /test6", "./generate.sh"}))
|
|
|
|
Expect(spec.GetPreBuildSteps()).To(Equal([]string{"echo foo > /test", "echo bar > /test2", "chmod +x generate.sh"}))
|
|
|
|
|
|
|
|
spec.SetOutputPath(tmpdir)
|
|
|
|
c.SetConcurrency(2)
|
|
|
|
|
|
|
|
artifact, err := c.Compile(false, spec)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Exists(artifact.GetPath())).To(BeTrue())
|
|
|
|
Expect(helpers.Untar(artifact.GetPath(), tmpdir, false)).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel("test6"))).To(BeTrue())
|
|
|
|
|
|
|
|
content1, err := helpers.Read(spec.Rel("test5"))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
content2, err := helpers.Read(spec.Rel("test6"))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(content1).To(Equal("artifact5\n"))
|
|
|
|
Expect(content2).To(Equal("artifact6\n"))
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.0.package.tar"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.0.metadata.yaml"))).To(BeTrue())
|
|
|
|
|
|
|
|
repo, err := GenerateRepository("test", "description", "disk", []string{tmpdir}, 1, tmpdir, "../../tests/fixtures/buildable", pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).ToNot(BeTrue())
|
|
|
|
err = repo.Write(tmpdir, false)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).To(BeTrue())
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
|
|
|
|
fakeroot, err := ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
|
|
|
inst := NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
|
|
|
repo2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
|
|
|
name: "test"
|
|
|
|
type: "disk"
|
|
|
|
urls:
|
|
|
|
- "`+tmpdir+`"
|
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
|
|
|
|
bolt, err := ioutil.TempDir("", "db")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(bolt) // clean up
|
|
|
|
|
|
|
|
systemDB := pkg.NewBoltDatabase(filepath.Join(bolt, "db.db"))
|
|
|
|
system := &System{Database: systemDB, Target: fakeroot}
|
|
|
|
err = inst.Install([]pkg.Package{&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}}, system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
tmpdir2, err := ioutil.TempDir("", "tree2")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe2 := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe2.Load("../../tests/fixtures/alpine")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(generalRecipe2.GetDatabase().GetPackages())).To(Equal(1))
|
|
|
|
|
|
|
|
c = compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe2.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
|
|
|
|
|
|
|
spec, err = c.FromPackage(&pkg.DefaultPackage{Name: "alpine", Category: "seed", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
spec.SetOutputPath(tmpdir2)
|
|
|
|
c.SetConcurrency(2)
|
|
|
|
|
|
|
|
artifact, err = c.Compile(false, spec)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Exists(artifact.GetPath())).To(BeTrue())
|
|
|
|
|
|
|
|
repo, err = GenerateRepository("test", "description", "disk", []string{tmpdir2}, 1, tmpdir2, "../../tests/fixtures/alpine", pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
err = repo.Write(tmpdir2, false)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
fakeroot, err = ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
|
|
|
inst = NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
|
|
|
repo2, err = NewLuetSystemRepositoryFromYaml([]byte(`
|
|
|
|
name: "test"
|
|
|
|
type: "disk"
|
|
|
|
urls:
|
|
|
|
- "`+tmpdir2+`"
|
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
inst.Repositories(Repositories{repo2})
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir2))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
system.Target = fakeroot
|
|
|
|
err = inst.Install([]pkg.Package{&pkg.DefaultPackage{Name: "alpine", Category: "seed", Version: "1.0"}}, system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "alpine", Category: "seed", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
})
|
|
|
|
|
2019-11-25 19:02:43 +00:00
|
|
|
})
|
2019-11-29 18:01:56 +00:00
|
|
|
|
|
|
|
Context("Simple upgrades", func() {
|
|
|
|
It("Installs packages and Upgrades a system with a persistent db", func() {
|
2019-12-31 00:21:06 +00:00
|
|
|
//repo:=NewLuetSystemRepository()
|
2019-11-29 18:01:56 +00:00
|
|
|
|
|
|
|
tmpdir, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe.Load("../../tests/fixtures/upgrade")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(generalRecipe.GetDatabase().GetPackages())).To(Equal(4))
|
|
|
|
|
2020-01-05 14:31:08 +00:00
|
|
|
c := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
2019-11-29 18:01:56 +00:00
|
|
|
|
|
|
|
spec, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
spec2, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.1"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
spec3, err := c.FromPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
tmpdir, err = ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
spec.SetOutputPath(tmpdir)
|
|
|
|
spec2.SetOutputPath(tmpdir)
|
|
|
|
spec3.SetOutputPath(tmpdir)
|
2019-12-30 13:46:45 +00:00
|
|
|
c.SetConcurrency(2)
|
|
|
|
|
|
|
|
_, errs := c.CompileParallel(false, compiler.NewLuetCompilationspecs(spec, spec2, spec3))
|
2019-11-29 18:01:56 +00:00
|
|
|
|
|
|
|
Expect(errs).To(BeEmpty())
|
|
|
|
|
2019-12-31 00:21:06 +00:00
|
|
|
repo, err := GenerateRepository("test", "description", "disk", []string{tmpdir}, 1, tmpdir, "../../tests/fixtures/upgrade", pkg.NewInMemoryDatabase(false))
|
2019-11-29 18:01:56 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).ToNot(BeTrue())
|
2020-03-24 11:52:45 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).ToNot(BeTrue())
|
2020-03-24 13:01:22 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).ToNot(BeTrue())
|
2020-01-04 14:53:22 +00:00
|
|
|
err = repo.Write(tmpdir, false)
|
2019-11-29 18:01:56 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).To(BeTrue())
|
2020-03-24 11:52:45 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).To(BeTrue())
|
2020-03-24 13:01:22 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).To(BeTrue())
|
2019-12-30 21:51:51 +00:00
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
2019-12-29 15:17:45 +00:00
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
2019-11-29 18:01:56 +00:00
|
|
|
|
|
|
|
fakeroot, err := ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
2020-02-12 11:05:28 +00:00
|
|
|
inst := NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
2019-12-31 00:21:06 +00:00
|
|
|
repo2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
2019-11-29 18:01:56 +00:00
|
|
|
name: "test"
|
2019-12-29 15:17:45 +00:00
|
|
|
type: "disk"
|
2019-12-30 21:51:51 +00:00
|
|
|
urls:
|
|
|
|
- "`+tmpdir+`"
|
2019-11-29 18:01:56 +00:00
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
2019-12-30 21:51:51 +00:00
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
2019-12-29 15:17:45 +00:00
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
2019-12-30 15:33:47 +00:00
|
|
|
|
|
|
|
bolt, err := ioutil.TempDir("", "db")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(bolt) // clean up
|
|
|
|
|
|
|
|
systemDB := pkg.NewBoltDatabase(filepath.Join(bolt, "db.db"))
|
|
|
|
system := &System{Database: systemDB, Target: fakeroot}
|
2020-04-13 16:49:05 +00:00
|
|
|
err = inst.Install([]pkg.Package{&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}}, system)
|
2019-12-30 15:33:47 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).To(BeTrue())
|
|
|
|
_, err = systemDB.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(system.Database.GetPackages())).To(Equal(1))
|
|
|
|
p, err := system.Database.GetPackage(system.Database.GetPackages()[0])
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(p.GetName()).To(Equal("b"))
|
|
|
|
|
|
|
|
files, err := systemDB.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(files).To(Equal([]string{"artifact42", "test5", "test6"}))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
err = inst.Upgrade(system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
// Nothing should be there anymore (files, packagedb entry)
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).ToNot(BeTrue())
|
|
|
|
|
|
|
|
// New version - new files
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "newc"))).To(BeTrue())
|
|
|
|
_, err = system.Database.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
|
|
|
|
// New package should be there
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.1"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
})
|
|
|
|
|
2020-05-02 10:18:19 +00:00
|
|
|
It("Handles package drops", func() {
|
|
|
|
//repo:=NewLuetSystemRepository()
|
|
|
|
|
|
|
|
tmpdir, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
generalRecipeNewRepo := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe.Load("../../tests/fixtures/upgrade_old_repo")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
err = generalRecipeNewRepo.Load("../../tests/fixtures/upgrade_new_repo")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(generalRecipe.GetDatabase().GetPackages())).To(Equal(3))
|
|
|
|
Expect(len(generalRecipeNewRepo.GetDatabase().GetPackages())).To(Equal(3))
|
|
|
|
|
|
|
|
c := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
|
|
|
c2 := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipeNewRepo.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
|
|
|
|
|
|
|
spec, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
spec3, err := c.FromPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
spec2, err := c2.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.1"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
tmpdir, err = ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
tmpdirnewrepo, err := ioutil.TempDir("", "tree2")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdirnewrepo) // clean up
|
|
|
|
|
|
|
|
spec.SetOutputPath(tmpdir)
|
|
|
|
spec2.SetOutputPath(tmpdirnewrepo)
|
|
|
|
spec3.SetOutputPath(tmpdir)
|
|
|
|
c.SetConcurrency(2)
|
|
|
|
|
|
|
|
_, errs := c.CompileParallel(false, compiler.NewLuetCompilationspecs(spec, spec3))
|
|
|
|
|
|
|
|
Expect(errs).To(BeEmpty())
|
|
|
|
|
|
|
|
_, errs = c2.CompileParallel(false, compiler.NewLuetCompilationspecs(spec2))
|
|
|
|
Expect(errs).To(BeEmpty())
|
|
|
|
|
|
|
|
repo, err := GenerateRepository("test", "description", "disk", []string{tmpdir}, 1, tmpdir, "../../tests/fixtures/upgrade_old_repo", pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).ToNot(BeTrue())
|
|
|
|
err = repo.Write(tmpdir, false)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
repoupgrade, err := GenerateRepository("test", "description", "disk", []string{tmpdirnewrepo}, 1, tmpdirnewrepo, "../../tests/fixtures/upgrade_new_repo", pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
err = repoupgrade.Write(tmpdirnewrepo, false)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
fakeroot, err := ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
|
|
|
inst := NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
|
|
|
repo2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
|
|
|
name: "test"
|
|
|
|
type: "disk"
|
|
|
|
urls:
|
|
|
|
- "`+tmpdir+`"
|
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
repoupgrade2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
|
|
|
name: "test"
|
|
|
|
type: "disk"
|
|
|
|
urls:
|
|
|
|
- "`+tmpdirnewrepo+`"
|
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
|
|
|
|
bolt, err := ioutil.TempDir("", "db")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(bolt) // clean up
|
|
|
|
|
|
|
|
systemDB := pkg.NewBoltDatabase(filepath.Join(bolt, "db.db"))
|
|
|
|
system := &System{Database: systemDB, Target: fakeroot}
|
|
|
|
err = inst.Install([]pkg.Package{&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}}, system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).To(BeTrue())
|
|
|
|
_, err = systemDB.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(system.Database.GetPackages())).To(Equal(1))
|
|
|
|
p, err := system.Database.GetPackage(system.Database.GetPackages()[0])
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(p.GetName()).To(Equal("b"))
|
|
|
|
|
|
|
|
files, err := systemDB.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(files).To(Equal([]string{"artifact42", "test5", "test6"}))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
inst.Repositories(Repositories{repoupgrade2})
|
|
|
|
|
|
|
|
err = inst.Upgrade(system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
// Nothing should be there anymore (files, packagedb entry)
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).ToNot(BeTrue())
|
|
|
|
|
|
|
|
// New version - new files
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "newc"))).To(BeTrue())
|
|
|
|
_, err = system.Database.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
|
|
|
|
// New package should be there
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.1"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
})
|
|
|
|
|
2019-12-30 15:33:47 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
Context("Compressed packages", func() {
|
|
|
|
It("Installs", func() {
|
2019-12-31 00:21:06 +00:00
|
|
|
//repo:=NewLuetSystemRepository()
|
2019-12-30 15:33:47 +00:00
|
|
|
|
|
|
|
tmpdir, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe.Load("../../tests/fixtures/upgrade")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(generalRecipe.GetDatabase().GetPackages())).To(Equal(4))
|
|
|
|
|
2020-01-05 14:31:08 +00:00
|
|
|
c := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
2019-12-30 15:33:47 +00:00
|
|
|
|
|
|
|
spec, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
spec2, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.1"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
spec3, err := c.FromPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
tmpdir, err = ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
spec.SetOutputPath(tmpdir)
|
|
|
|
spec2.SetOutputPath(tmpdir)
|
|
|
|
spec3.SetOutputPath(tmpdir)
|
|
|
|
c.SetConcurrency(2)
|
|
|
|
c.SetCompressionType(compiler.GZip)
|
|
|
|
_, errs := c.CompileParallel(false, compiler.NewLuetCompilationspecs(spec, spec2, spec3))
|
|
|
|
|
|
|
|
Expect(errs).To(BeEmpty())
|
|
|
|
|
2019-12-31 00:21:06 +00:00
|
|
|
repo, err := GenerateRepository("test", "description", "disk", []string{tmpdir}, 1, tmpdir, "../../tests/fixtures/upgrade", pkg.NewInMemoryDatabase(false))
|
2019-12-30 15:33:47 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).ToNot(BeTrue())
|
2020-03-24 11:52:45 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).ToNot(BeTrue())
|
2020-03-24 13:01:22 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).ToNot(BeTrue())
|
2020-01-04 14:53:22 +00:00
|
|
|
err = repo.Write(tmpdir, false)
|
2019-12-30 15:33:47 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.1.package.tar.gz"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.1.package.tar"))).ToNot(BeTrue())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).To(BeTrue())
|
2020-03-24 11:52:45 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).To(BeTrue())
|
2020-03-24 13:01:22 +00:00
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).To(BeTrue())
|
2019-12-30 21:51:51 +00:00
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
2019-12-30 21:03:37 +00:00
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
2019-12-30 15:33:47 +00:00
|
|
|
|
|
|
|
fakeroot, err := ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
2020-02-12 11:05:28 +00:00
|
|
|
inst := NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
2019-12-31 00:21:06 +00:00
|
|
|
repo2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
2019-12-30 15:33:47 +00:00
|
|
|
name: "test"
|
2019-12-30 21:03:37 +00:00
|
|
|
type: "disk"
|
2019-12-30 21:51:51 +00:00
|
|
|
urls:
|
|
|
|
- "`+tmpdir+`"
|
2019-12-30 15:33:47 +00:00
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
2019-12-30 21:51:51 +00:00
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
2019-12-30 21:03:37 +00:00
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
2019-11-29 18:01:56 +00:00
|
|
|
|
|
|
|
bolt, err := ioutil.TempDir("", "db")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(bolt) // clean up
|
|
|
|
|
|
|
|
systemDB := pkg.NewBoltDatabase(filepath.Join(bolt, "db.db"))
|
|
|
|
system := &System{Database: systemDB, Target: fakeroot}
|
2020-04-13 16:49:05 +00:00
|
|
|
err = inst.Install([]pkg.Package{&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"}}, system)
|
2019-11-29 18:01:56 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).To(BeTrue())
|
|
|
|
_, err = systemDB.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(system.Database.GetPackages())).To(Equal(1))
|
|
|
|
p, err := system.Database.GetPackage(system.Database.GetPackages()[0])
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(p.GetName()).To(Equal("b"))
|
|
|
|
|
|
|
|
files, err := systemDB.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(files).To(Equal([]string{"artifact42", "test5", "test6"}))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
err = inst.Upgrade(system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
// Nothing should be there anymore (files, packagedb entry)
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).ToNot(BeTrue())
|
|
|
|
|
|
|
|
// New version - new files
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "newc"))).To(BeTrue())
|
|
|
|
_, err = system.Database.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
|
|
|
|
// New package should be there
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.1"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
})
|
|
|
|
|
2020-04-13 17:30:40 +00:00
|
|
|
Context("Existing files", func() {
|
|
|
|
It("Reclaims them", func() {
|
|
|
|
//repo:=NewLuetSystemRepository()
|
|
|
|
|
|
|
|
tmpdir, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe.Load("../../tests/fixtures/upgrade")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(generalRecipe.GetDatabase().GetPackages())).To(Equal(4))
|
|
|
|
|
|
|
|
c := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
|
|
|
|
|
|
|
spec, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
spec2, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.1"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
spec3, err := c.FromPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
tmpdir, err = ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
spec.SetOutputPath(tmpdir)
|
|
|
|
spec2.SetOutputPath(tmpdir)
|
|
|
|
spec3.SetOutputPath(tmpdir)
|
|
|
|
c.SetConcurrency(2)
|
|
|
|
c.SetCompressionType(compiler.GZip)
|
|
|
|
_, errs := c.CompileParallel(false, compiler.NewLuetCompilationspecs(spec, spec2, spec3))
|
|
|
|
|
|
|
|
Expect(errs).To(BeEmpty())
|
|
|
|
|
|
|
|
repo, err := GenerateRepository("test", "description", "disk", []string{tmpdir}, 1, tmpdir, "../../tests/fixtures/upgrade", pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).ToNot(BeTrue())
|
|
|
|
err = repo.Write(tmpdir, false)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.1.package.tar.gz"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel("b-test-1.1.package.tar"))).ToNot(BeTrue())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).To(BeTrue())
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
|
|
|
|
fakeroot, err := ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
|
|
|
inst := NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
|
|
|
repo2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
|
|
|
name: "test"
|
|
|
|
type: "disk"
|
|
|
|
urls:
|
|
|
|
- "`+tmpdir+`"
|
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
|
|
|
|
bolt, err := ioutil.TempDir("", "db")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(bolt) // clean up
|
|
|
|
|
|
|
|
systemDB := pkg.NewBoltDatabase(filepath.Join(bolt, "db.db"))
|
|
|
|
system := &System{Database: systemDB, Target: fakeroot}
|
|
|
|
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(system.Database.World())).To(Equal(0))
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).To(BeFalse())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).To(BeFalse())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "c"))).To(BeFalse())
|
|
|
|
|
|
|
|
Expect(helpers.Touch(filepath.Join(fakeroot, "test5"))).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Touch(filepath.Join(fakeroot, "test6"))).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Touch(filepath.Join(fakeroot, "c"))).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
err = inst.Reclaim(system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(system.Database.World())).To(Equal(2))
|
|
|
|
})
|
2020-05-02 10:18:19 +00:00
|
|
|
|
|
|
|
It("Upgrades reclaimed packages", func() {
|
|
|
|
//repo:=NewLuetSystemRepository()
|
|
|
|
|
|
|
|
tmpdir, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
|
|
|
|
generalRecipe := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe.Load("../../tests/fixtures/upgrade_old_repo")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(generalRecipe.GetDatabase().GetPackages())).To(Equal(3))
|
|
|
|
|
|
|
|
c := compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
|
|
|
|
|
|
|
spec, err := c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
spec3, err := c.FromPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(spec.GetPackage().GetPath()).ToNot(Equal(""))
|
|
|
|
|
|
|
|
tmpdir, err = ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir) // clean up
|
|
|
|
spec.SetOutputPath(tmpdir)
|
|
|
|
spec3.SetOutputPath(tmpdir)
|
|
|
|
c.SetConcurrency(1)
|
|
|
|
c.SetCompressionType(compiler.GZip)
|
|
|
|
_, errs := c.CompileParallel(false, compiler.NewLuetCompilationspecs(spec, spec3))
|
|
|
|
|
|
|
|
Expect(errs).To(BeEmpty())
|
|
|
|
|
|
|
|
repo, err := GenerateRepository("test", "description", "disk", []string{tmpdir}, 1, tmpdir, "../../tests/fixtures/upgrade_old_repo", pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).ToNot(BeTrue())
|
|
|
|
err = repo.Write(tmpdir, false)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(helpers.Exists(spec.Rel("repository.yaml"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(TREE_TARBALL + ".gz"))).To(BeTrue())
|
|
|
|
Expect(helpers.Exists(spec.Rel(REPOSITORY_METAFILE + ".tar"))).To(BeTrue())
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
|
|
|
|
fakeroot, err := ioutil.TempDir("", "fakeroot")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(fakeroot) // clean up
|
|
|
|
|
|
|
|
inst := NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
|
|
|
repo2, err := NewLuetSystemRepositoryFromYaml([]byte(`
|
|
|
|
name: "test"
|
|
|
|
type: "disk"
|
|
|
|
urls:
|
|
|
|
- "`+tmpdir+`"
|
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
|
|
|
Expect(repo.GetUrls()[0]).To(Equal(tmpdir))
|
|
|
|
Expect(repo.GetType()).To(Equal("disk"))
|
|
|
|
|
|
|
|
bolt, err := ioutil.TempDir("", "db")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(bolt) // clean up
|
|
|
|
|
|
|
|
systemDB := pkg.NewBoltDatabase(filepath.Join(bolt, "db.db"))
|
|
|
|
system := &System{Database: systemDB, Target: fakeroot}
|
|
|
|
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(system.Database.World())).To(Equal(0))
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).To(BeFalse())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).To(BeFalse())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "c"))).To(BeFalse())
|
|
|
|
|
|
|
|
Expect(helpers.Touch(filepath.Join(fakeroot, "test5"))).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Touch(filepath.Join(fakeroot, "test6"))).ToNot(HaveOccurred())
|
|
|
|
Expect(helpers.Touch(filepath.Join(fakeroot, "c"))).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
err = inst.Reclaim(system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "c", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(system.Database.World())).To(Equal(2))
|
|
|
|
|
|
|
|
generalRecipe2 := tree.NewCompilerRecipe(pkg.NewInMemoryDatabase(false))
|
|
|
|
|
|
|
|
err = generalRecipe2.Load("../../tests/fixtures/upgrade_new_repo")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
Expect(len(generalRecipe2.GetDatabase().GetPackages())).To(Equal(3))
|
|
|
|
|
|
|
|
c = compiler.NewLuetCompiler(backend.NewSimpleDockerBackend(), generalRecipe2.GetDatabase(), compiler.NewDefaultCompilerOptions())
|
|
|
|
|
|
|
|
spec, err = c.FromPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.1"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
tmpdir2, err := ioutil.TempDir("", "tree")
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
defer os.RemoveAll(tmpdir2) // clean up
|
|
|
|
spec.SetOutputPath(tmpdir2)
|
|
|
|
|
|
|
|
_, errs = c.CompileParallel(false, compiler.NewLuetCompilationspecs(spec))
|
|
|
|
|
|
|
|
Expect(errs).To(BeEmpty())
|
|
|
|
|
|
|
|
repo, err = GenerateRepository("test", "description", "disk", []string{tmpdir2}, 1, tmpdir2, "../../tests/fixtures/upgrade_new_repo", pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(repo.GetName()).To(Equal("test"))
|
|
|
|
err = repo.Write(tmpdir2, false)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst = NewLuetInstaller(LuetInstallerOptions{Concurrency: 1})
|
|
|
|
repo2, err = NewLuetSystemRepositoryFromYaml([]byte(`
|
|
|
|
name: "test"
|
|
|
|
type: "disk"
|
|
|
|
urls:
|
|
|
|
- "`+tmpdir2+`"
|
|
|
|
`), pkg.NewInMemoryDatabase(false))
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
inst.Repositories(Repositories{repo2})
|
|
|
|
err = inst.Upgrade(system)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
// Nothing should be there anymore (files, packagedb entry)
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test5"))).ToNot(BeTrue())
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "test6"))).ToNot(BeTrue())
|
|
|
|
|
|
|
|
// New version - new files
|
|
|
|
Expect(helpers.Exists(filepath.Join(fakeroot, "newc"))).To(BeTrue())
|
|
|
|
_, err = system.Database.GetPackageFiles(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.0"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
|
|
|
|
// New package should be there
|
|
|
|
_, err = system.Database.FindPackage(&pkg.DefaultPackage{Name: "b", Category: "test", Version: "1.1"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
|
|
|
|
})
|
2020-04-13 17:30:40 +00:00
|
|
|
})
|
|
|
|
|
2019-11-22 22:12:03 +00:00
|
|
|
})
|