mirror of
https://github.com/mudler/luet.git
synced 2025-09-07 02:00:39 +00:00
Compare commits
8 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
86bd6c5fc0 | ||
|
658612fcf3 | ||
|
7128c88da6 | ||
|
74402fae81 | ||
|
9d1594c036 | ||
|
75906c4198 | ||
|
cb032dc714 | ||
|
2c7e495fa1 |
19
cmd/build.go
19
cmd/build.go
@@ -21,6 +21,7 @@ import (
|
|||||||
|
|
||||||
"github.com/ghodss/yaml"
|
"github.com/ghodss/yaml"
|
||||||
helpers "github.com/mudler/luet/cmd/helpers"
|
helpers "github.com/mudler/luet/cmd/helpers"
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
"github.com/mudler/luet/pkg/compiler"
|
"github.com/mudler/luet/pkg/compiler"
|
||||||
"github.com/mudler/luet/pkg/compiler/types/artifact"
|
"github.com/mudler/luet/pkg/compiler/types/artifact"
|
||||||
compilerspec "github.com/mudler/luet/pkg/compiler/types/spec"
|
compilerspec "github.com/mudler/luet/pkg/compiler/types/spec"
|
||||||
@@ -83,10 +84,8 @@ Build packages specifying multiple definition trees:
|
|||||||
viper.BindPFlag("wait", cmd.Flags().Lookup("wait"))
|
viper.BindPFlag("wait", cmd.Flags().Lookup("wait"))
|
||||||
viper.BindPFlag("keep-images", cmd.Flags().Lookup("keep-images"))
|
viper.BindPFlag("keep-images", cmd.Flags().Lookup("keep-images"))
|
||||||
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.type", cmd.Flags().Lookup("solver-type"))
|
util.BindSolverFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("solver.discount", cmd.Flags().Lookup("solver-discount"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.rate", cmd.Flags().Lookup("solver-rate"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.max_attempts", cmd.Flags().Lookup("solver-attempts"))
|
|
||||||
LuetCfg.Viper.BindPFlag("general.show_build_output", cmd.Flags().Lookup("live-output"))
|
LuetCfg.Viper.BindPFlag("general.show_build_output", cmd.Flags().Lookup("live-output"))
|
||||||
LuetCfg.Viper.BindPFlag("backend-args", cmd.Flags().Lookup("backend-args"))
|
LuetCfg.Viper.BindPFlag("backend-args", cmd.Flags().Lookup("backend-args"))
|
||||||
|
|
||||||
@@ -148,21 +147,11 @@ Build packages specifying multiple definition trees:
|
|||||||
|
|
||||||
Info("Building in", dst)
|
Info("Building in", dst)
|
||||||
|
|
||||||
stype := LuetCfg.Viper.GetString("solver.type")
|
opts := util.SetSolverConfig()
|
||||||
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
|
||||||
rate := LuetCfg.Viper.GetFloat64("solver.rate")
|
|
||||||
attempts := LuetCfg.Viper.GetInt("solver.max_attempts")
|
|
||||||
pullRepo, _ := cmd.Flags().GetStringArray("pull-repository")
|
pullRepo, _ := cmd.Flags().GetStringArray("pull-repository")
|
||||||
|
|
||||||
LuetCfg.GetGeneral().ShowBuildOutput = LuetCfg.Viper.GetBool("general.show_build_output")
|
LuetCfg.GetGeneral().ShowBuildOutput = LuetCfg.Viper.GetBool("general.show_build_output")
|
||||||
|
|
||||||
opts := &LuetSolverOptions{
|
|
||||||
Type: stype,
|
|
||||||
LearnRate: float32(rate),
|
|
||||||
Discount: float32(discount),
|
|
||||||
MaxAttempts: attempts,
|
|
||||||
}
|
|
||||||
|
|
||||||
Debug("Solver", opts.CompactString())
|
Debug("Solver", opts.CompactString())
|
||||||
|
|
||||||
if concurrent {
|
if concurrent {
|
||||||
|
@@ -20,8 +20,8 @@ import (
|
|||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
config "github.com/mudler/luet/pkg/config"
|
|
||||||
fileHelper "github.com/mudler/luet/pkg/helpers/file"
|
fileHelper "github.com/mudler/luet/pkg/helpers/file"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
|
|
||||||
@@ -33,19 +33,11 @@ var cleanupCmd = &cobra.Command{
|
|||||||
Short: "Clean packages cache.",
|
Short: "Clean packages cache.",
|
||||||
Long: `remove downloaded packages tarballs and clean cache directory`,
|
Long: `remove downloaded packages tarballs and clean cache directory`,
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
|
||||||
LuetCfg.Viper.BindPFlag("installed", cmd.Flags().Lookup("installed"))
|
|
||||||
},
|
},
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
var cleaned int = 0
|
var cleaned int = 0
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
util.SetSystemConfig()
|
||||||
rootfs := config.LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := config.LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
// Check if cache dir exists
|
// Check if cache dir exists
|
||||||
if fileHelper.Exists(LuetCfg.GetSystem().GetSystemPkgsCacheDirPath()) {
|
if fileHelper.Exists(LuetCfg.GetSystem().GetSystemPkgsCacheDirPath()) {
|
||||||
|
|
||||||
|
@@ -18,6 +18,7 @@ package cmd_database
|
|||||||
import (
|
import (
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
|
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
artifact "github.com/mudler/luet/pkg/compiler/types/artifact"
|
artifact "github.com/mudler/luet/pkg/compiler/types/artifact"
|
||||||
|
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
@@ -45,21 +46,11 @@ The yaml must contain the package definition, and the file list at least.
|
|||||||
For reference, inspect a "metadata.yaml" file generated while running "luet build"`,
|
For reference, inspect a "metadata.yaml" file generated while running "luet build"`,
|
||||||
Args: cobra.OnlyValidArgs,
|
Args: cobra.OnlyValidArgs,
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
|
||||||
|
|
||||||
},
|
},
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
|
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
util.SetSystemConfig()
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
|
|
||||||
systemDB := LuetCfg.GetSystemDB()
|
systemDB := LuetCfg.GetSystemDB()
|
||||||
|
|
||||||
for _, a := range args {
|
for _, a := range args {
|
||||||
|
@@ -19,6 +19,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
helpers "github.com/mudler/luet/cmd/helpers"
|
helpers "github.com/mudler/luet/cmd/helpers"
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
@@ -38,20 +39,11 @@ To return also files:
|
|||||||
$ luet database get --files system/foo`,
|
$ luet database get --files system/foo`,
|
||||||
Args: cobra.OnlyValidArgs,
|
Args: cobra.OnlyValidArgs,
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
|
||||||
|
|
||||||
},
|
},
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
showFiles, _ := cmd.Flags().GetBool("files")
|
showFiles, _ := cmd.Flags().GetBool("files")
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
util.SetSystemConfig()
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
|
|
||||||
systemDB := LuetCfg.GetSystemDB()
|
systemDB := LuetCfg.GetSystemDB()
|
||||||
|
|
||||||
|
@@ -19,6 +19,7 @@ import (
|
|||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
|
|
||||||
helpers "github.com/mudler/luet/cmd/helpers"
|
helpers "github.com/mudler/luet/cmd/helpers"
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
@@ -36,19 +37,10 @@ This commands takes multiple packages as arguments and prunes their entries from
|
|||||||
`,
|
`,
|
||||||
Args: cobra.OnlyValidArgs,
|
Args: cobra.OnlyValidArgs,
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
|
||||||
|
|
||||||
},
|
},
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
util.SetSystemConfig()
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
|
|
||||||
systemDB := LuetCfg.GetSystemDB()
|
systemDB := LuetCfg.GetSystemDB()
|
||||||
|
|
||||||
|
@@ -19,6 +19,7 @@ import (
|
|||||||
"github.com/mudler/luet/pkg/solver"
|
"github.com/mudler/luet/pkg/solver"
|
||||||
|
|
||||||
helpers "github.com/mudler/luet/cmd/helpers"
|
helpers "github.com/mudler/luet/cmd/helpers"
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
pkg "github.com/mudler/luet/pkg/package"
|
pkg "github.com/mudler/luet/pkg/package"
|
||||||
@@ -47,13 +48,8 @@ To force install a package:
|
|||||||
`,
|
`,
|
||||||
Aliases: []string{"i"},
|
Aliases: []string{"i"},
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
util.BindSolverFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.type", cmd.Flags().Lookup("solver-type"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.discount", cmd.Flags().Lookup("solver-discount"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.rate", cmd.Flags().Lookup("solver-rate"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.max_attempts", cmd.Flags().Lookup("solver-attempts"))
|
|
||||||
LuetCfg.Viper.BindPFlag("onlydeps", cmd.Flags().Lookup("onlydeps"))
|
LuetCfg.Viper.BindPFlag("onlydeps", cmd.Flags().Lookup("onlydeps"))
|
||||||
LuetCfg.Viper.BindPFlag("nodeps", cmd.Flags().Lookup("nodeps"))
|
LuetCfg.Viper.BindPFlag("nodeps", cmd.Flags().Lookup("nodeps"))
|
||||||
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
||||||
@@ -70,10 +66,6 @@ To force install a package:
|
|||||||
toInstall = append(toInstall, pack)
|
toInstall = append(toInstall, pack)
|
||||||
}
|
}
|
||||||
|
|
||||||
stype := LuetCfg.Viper.GetString("solver.type")
|
|
||||||
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
|
||||||
rate := LuetCfg.Viper.GetFloat64("solver.rate")
|
|
||||||
attempts := LuetCfg.Viper.GetInt("solver.max_attempts")
|
|
||||||
force := LuetCfg.Viper.GetBool("force")
|
force := LuetCfg.Viper.GetBool("force")
|
||||||
nodeps := LuetCfg.Viper.GetBool("nodeps")
|
nodeps := LuetCfg.Viper.GetBool("nodeps")
|
||||||
onlydeps := LuetCfg.Viper.GetBool("onlydeps")
|
onlydeps := LuetCfg.Viper.GetBool("onlydeps")
|
||||||
@@ -81,18 +73,8 @@ To force install a package:
|
|||||||
yes := LuetCfg.Viper.GetBool("yes")
|
yes := LuetCfg.Viper.GetBool("yes")
|
||||||
downloadOnly, _ := cmd.Flags().GetBool("download-only")
|
downloadOnly, _ := cmd.Flags().GetBool("download-only")
|
||||||
|
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
util.SetSystemConfig()
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
util.SetSolverConfig()
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
|
|
||||||
LuetCfg.GetSolverOptions().Type = stype
|
|
||||||
LuetCfg.GetSolverOptions().LearnRate = float32(rate)
|
|
||||||
LuetCfg.GetSolverOptions().Discount = float32(discount)
|
|
||||||
LuetCfg.GetSolverOptions().MaxAttempts = attempts
|
|
||||||
|
|
||||||
if concurrent {
|
if concurrent {
|
||||||
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
||||||
|
@@ -15,6 +15,7 @@
|
|||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
installer "github.com/mudler/luet/pkg/installer"
|
installer "github.com/mudler/luet/pkg/installer"
|
||||||
|
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
@@ -27,9 +28,7 @@ var reclaimCmd = &cobra.Command{
|
|||||||
Use: "reclaim",
|
Use: "reclaim",
|
||||||
Short: "Reclaim packages to Luet database from available repositories",
|
Short: "Reclaim packages to Luet database from available repositories",
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
|
||||||
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
||||||
},
|
},
|
||||||
Long: `Reclaim tries to find association between packages in the online repositories and the system one.
|
Long: `Reclaim tries to find association between packages in the online repositories and the system one.
|
||||||
@@ -39,13 +38,7 @@ var reclaimCmd = &cobra.Command{
|
|||||||
It scans the target file system, and if finds a match with a package available in the repositories, it marks as installed in the system database.
|
It scans the target file system, and if finds a match with a package available in the repositories, it marks as installed in the system database.
|
||||||
`,
|
`,
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
util.SetSystemConfig()
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
|
|
||||||
// This shouldn't be necessary, but we need to unmarshal the repositories to a concrete struct, thus we need to port them back to the Repositories type
|
// This shouldn't be necessary, but we need to unmarshal the repositories to a concrete struct, thus we need to port them back to the Repositories type
|
||||||
repos := installer.Repositories{}
|
repos := installer.Repositories{}
|
||||||
|
@@ -19,6 +19,7 @@ import (
|
|||||||
"github.com/mudler/luet/pkg/solver"
|
"github.com/mudler/luet/pkg/solver"
|
||||||
|
|
||||||
helpers "github.com/mudler/luet/cmd/helpers"
|
helpers "github.com/mudler/luet/cmd/helpers"
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
pkg "github.com/mudler/luet/pkg/package"
|
pkg "github.com/mudler/luet/pkg/package"
|
||||||
@@ -34,13 +35,8 @@ var reinstallCmd = &cobra.Command{
|
|||||||
$ luet reinstall -y system/busybox shells/bash system/coreutils ...
|
$ luet reinstall -y system/busybox shells/bash system/coreutils ...
|
||||||
`,
|
`,
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
util.BindSolverFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.type", cmd.Flags().Lookup("solver-type"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.discount", cmd.Flags().Lookup("solver-discount"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.rate", cmd.Flags().Lookup("solver-rate"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.max_attempts", cmd.Flags().Lookup("solver-attempts"))
|
|
||||||
LuetCfg.Viper.BindPFlag("onlydeps", cmd.Flags().Lookup("onlydeps"))
|
LuetCfg.Viper.BindPFlag("onlydeps", cmd.Flags().Lookup("onlydeps"))
|
||||||
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
||||||
LuetCfg.Viper.BindPFlag("for", cmd.Flags().Lookup("for"))
|
LuetCfg.Viper.BindPFlag("for", cmd.Flags().Lookup("for"))
|
||||||
@@ -51,22 +47,14 @@ var reinstallCmd = &cobra.Command{
|
|||||||
var toUninstall pkg.Packages
|
var toUninstall pkg.Packages
|
||||||
var toAdd pkg.Packages
|
var toAdd pkg.Packages
|
||||||
|
|
||||||
stype := LuetCfg.Viper.GetString("solver.type")
|
|
||||||
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
|
||||||
rate := LuetCfg.Viper.GetFloat64("solver.rate")
|
|
||||||
attempts := LuetCfg.Viper.GetInt("solver.max_attempts")
|
|
||||||
force := LuetCfg.Viper.GetBool("force")
|
force := LuetCfg.Viper.GetBool("force")
|
||||||
onlydeps := LuetCfg.Viper.GetBool("onlydeps")
|
onlydeps := LuetCfg.Viper.GetBool("onlydeps")
|
||||||
concurrent, _ := cmd.Flags().GetBool("solver-concurrent")
|
concurrent, _ := cmd.Flags().GetBool("solver-concurrent")
|
||||||
yes := LuetCfg.Viper.GetBool("yes")
|
yes := LuetCfg.Viper.GetBool("yes")
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
downloadOnly, _ := cmd.Flags().GetBool("download-only")
|
downloadOnly, _ := cmd.Flags().GetBool("download-only")
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
util.SetSystemConfig()
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
|
|
||||||
for _, a := range args {
|
for _, a := range args {
|
||||||
pack, err := helpers.ParsePackageStr(a)
|
pack, err := helpers.ParsePackageStr(a)
|
||||||
@@ -87,10 +75,7 @@ var reinstallCmd = &cobra.Command{
|
|||||||
repos = append(repos, r)
|
repos = append(repos, r)
|
||||||
}
|
}
|
||||||
|
|
||||||
LuetCfg.GetSolverOptions().Type = stype
|
util.SetSolverConfig()
|
||||||
LuetCfg.GetSolverOptions().LearnRate = float32(rate)
|
|
||||||
LuetCfg.GetSolverOptions().Discount = float32(discount)
|
|
||||||
LuetCfg.GetSolverOptions().MaxAttempts = attempts
|
|
||||||
|
|
||||||
if concurrent {
|
if concurrent {
|
||||||
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
||||||
|
@@ -19,6 +19,7 @@ import (
|
|||||||
"github.com/mudler/luet/pkg/solver"
|
"github.com/mudler/luet/pkg/solver"
|
||||||
|
|
||||||
helpers "github.com/mudler/luet/cmd/helpers"
|
helpers "github.com/mudler/luet/cmd/helpers"
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
pkg "github.com/mudler/luet/pkg/package"
|
pkg "github.com/mudler/luet/pkg/package"
|
||||||
@@ -35,13 +36,8 @@ var replaceCmd = &cobra.Command{
|
|||||||
$ luet replace -y system/busybox ... --for shells/bash --for system/coreutils ...
|
$ luet replace -y system/busybox ... --for shells/bash --for system/coreutils ...
|
||||||
`,
|
`,
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
util.BindSolverFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.type", cmd.Flags().Lookup("solver-type"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.discount", cmd.Flags().Lookup("solver-discount"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.rate", cmd.Flags().Lookup("solver-rate"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.max_attempts", cmd.Flags().Lookup("solver-attempts"))
|
|
||||||
LuetCfg.Viper.BindPFlag("onlydeps", cmd.Flags().Lookup("onlydeps"))
|
LuetCfg.Viper.BindPFlag("onlydeps", cmd.Flags().Lookup("onlydeps"))
|
||||||
LuetCfg.Viper.BindPFlag("nodeps", cmd.Flags().Lookup("nodeps"))
|
LuetCfg.Viper.BindPFlag("nodeps", cmd.Flags().Lookup("nodeps"))
|
||||||
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
||||||
@@ -54,24 +50,15 @@ var replaceCmd = &cobra.Command{
|
|||||||
var toAdd pkg.Packages
|
var toAdd pkg.Packages
|
||||||
|
|
||||||
f := LuetCfg.Viper.GetStringSlice("for")
|
f := LuetCfg.Viper.GetStringSlice("for")
|
||||||
stype := LuetCfg.Viper.GetString("solver.type")
|
|
||||||
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
|
||||||
rate := LuetCfg.Viper.GetFloat64("solver.rate")
|
|
||||||
attempts := LuetCfg.Viper.GetInt("solver.max_attempts")
|
|
||||||
force := LuetCfg.Viper.GetBool("force")
|
force := LuetCfg.Viper.GetBool("force")
|
||||||
nodeps := LuetCfg.Viper.GetBool("nodeps")
|
nodeps := LuetCfg.Viper.GetBool("nodeps")
|
||||||
onlydeps := LuetCfg.Viper.GetBool("onlydeps")
|
onlydeps := LuetCfg.Viper.GetBool("onlydeps")
|
||||||
concurrent, _ := cmd.Flags().GetBool("solver-concurrent")
|
concurrent, _ := cmd.Flags().GetBool("solver-concurrent")
|
||||||
yes := LuetCfg.Viper.GetBool("yes")
|
yes := LuetCfg.Viper.GetBool("yes")
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
downloadOnly, _ := cmd.Flags().GetBool("download-only")
|
downloadOnly, _ := cmd.Flags().GetBool("download-only")
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
util.SetSystemConfig()
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
util.SetSolverConfig()
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
|
|
||||||
for _, a := range args {
|
for _, a := range args {
|
||||||
pack, err := helpers.ParsePackageStr(a)
|
pack, err := helpers.ParsePackageStr(a)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -98,11 +85,6 @@ var replaceCmd = &cobra.Command{
|
|||||||
repos = append(repos, r)
|
repos = append(repos, r)
|
||||||
}
|
}
|
||||||
|
|
||||||
LuetCfg.GetSolverOptions().Type = stype
|
|
||||||
LuetCfg.GetSolverOptions().LearnRate = float32(rate)
|
|
||||||
LuetCfg.GetSolverOptions().Discount = float32(discount)
|
|
||||||
LuetCfg.GetSolverOptions().MaxAttempts = attempts
|
|
||||||
|
|
||||||
if concurrent {
|
if concurrent {
|
||||||
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
||||||
} else {
|
} else {
|
||||||
|
@@ -41,7 +41,7 @@ var Verbose bool
|
|||||||
var LockedCommands = []string{"install", "uninstall", "upgrade"}
|
var LockedCommands = []string{"install", "uninstall", "upgrade"}
|
||||||
|
|
||||||
const (
|
const (
|
||||||
LuetCLIVersion = "0.17.2"
|
LuetCLIVersion = "0.17.4"
|
||||||
LuetEnvPrefix = "LUET"
|
LuetEnvPrefix = "LUET"
|
||||||
license = `
|
license = `
|
||||||
Luet Copyright (C) 2019-2021 Ettore Di Giacinto
|
Luet Copyright (C) 2019-2021 Ettore Di Giacinto
|
||||||
|
@@ -21,6 +21,7 @@ import (
|
|||||||
"github.com/ghodss/yaml"
|
"github.com/ghodss/yaml"
|
||||||
"github.com/jedib0t/go-pretty/table"
|
"github.com/jedib0t/go-pretty/table"
|
||||||
"github.com/jedib0t/go-pretty/v6/list"
|
"github.com/jedib0t/go-pretty/v6/list"
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
installer "github.com/mudler/luet/pkg/installer"
|
installer "github.com/mudler/luet/pkg/installer"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
@@ -306,14 +307,9 @@ Search can also return results in the terminal in different ways: as terminal ou
|
|||||||
`,
|
`,
|
||||||
Aliases: []string{"s"},
|
Aliases: []string{"s"},
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
util.BindSolverFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("installed", cmd.Flags().Lookup("installed"))
|
LuetCfg.Viper.BindPFlag("installed", cmd.Flags().Lookup("installed"))
|
||||||
LuetCfg.Viper.BindPFlag("solver.type", cmd.Flags().Lookup("solver-type"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.discount", cmd.Flags().Lookup("solver-discount"))
|
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.rate", cmd.Flags().Lookup("solver-rate"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.max_attempts", cmd.Flags().Lookup("solver-attempts"))
|
|
||||||
},
|
},
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
var results Results
|
var results Results
|
||||||
@@ -325,32 +321,20 @@ Search can also return results in the terminal in different ways: as terminal ou
|
|||||||
hidden, _ := cmd.Flags().GetBool("hidden")
|
hidden, _ := cmd.Flags().GetBool("hidden")
|
||||||
|
|
||||||
installed := LuetCfg.Viper.GetBool("installed")
|
installed := LuetCfg.Viper.GetBool("installed")
|
||||||
stype := LuetCfg.Viper.GetString("solver.type")
|
|
||||||
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
|
||||||
rate := LuetCfg.Viper.GetFloat64("solver.rate")
|
|
||||||
attempts := LuetCfg.Viper.GetInt("solver.max_attempts")
|
|
||||||
searchWithLabel, _ := cmd.Flags().GetBool("by-label")
|
searchWithLabel, _ := cmd.Flags().GetBool("by-label")
|
||||||
searchWithLabelMatch, _ := cmd.Flags().GetBool("by-label-regex")
|
searchWithLabelMatch, _ := cmd.Flags().GetBool("by-label-regex")
|
||||||
revdeps, _ := cmd.Flags().GetBool("revdeps")
|
revdeps, _ := cmd.Flags().GetBool("revdeps")
|
||||||
tableMode, _ := cmd.Flags().GetBool("table")
|
tableMode, _ := cmd.Flags().GetBool("table")
|
||||||
files, _ := cmd.Flags().GetBool("files")
|
files, _ := cmd.Flags().GetBool("files")
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
util.SetSystemConfig()
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
util.SetSolverConfig()
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
out, _ := cmd.Flags().GetString("output")
|
out, _ := cmd.Flags().GetString("output")
|
||||||
if out != "terminal" {
|
if out != "terminal" {
|
||||||
LuetCfg.GetLogging().SetLogLevel("error")
|
LuetCfg.GetLogging().SetLogLevel("error")
|
||||||
}
|
}
|
||||||
|
|
||||||
LuetCfg.GetSolverOptions().Type = stype
|
|
||||||
LuetCfg.GetSolverOptions().LearnRate = float32(rate)
|
|
||||||
LuetCfg.GetSolverOptions().Discount = float32(discount)
|
|
||||||
LuetCfg.GetSolverOptions().MaxAttempts = attempts
|
|
||||||
|
|
||||||
l := list.NewWriter()
|
l := list.NewWriter()
|
||||||
t := table.NewWriter()
|
t := table.NewWriter()
|
||||||
t.AppendHeader(rows)
|
t.AppendHeader(rows)
|
||||||
|
@@ -16,6 +16,7 @@ package cmd
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
helpers "github.com/mudler/luet/cmd/helpers"
|
helpers "github.com/mudler/luet/cmd/helpers"
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
installer "github.com/mudler/luet/pkg/installer"
|
installer "github.com/mudler/luet/pkg/installer"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
@@ -31,16 +32,11 @@ var uninstallCmd = &cobra.Command{
|
|||||||
Long: `Uninstall packages`,
|
Long: `Uninstall packages`,
|
||||||
Aliases: []string{"rm", "un"},
|
Aliases: []string{"rm", "un"},
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
util.BindSolverFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("solver.type", cmd.Flags().Lookup("solver-type"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.discount", cmd.Flags().Lookup("solver-discount"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.rate", cmd.Flags().Lookup("solver-rate"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.max_attempts", cmd.Flags().Lookup("solver-attempts"))
|
|
||||||
LuetCfg.Viper.BindPFlag("nodeps", cmd.Flags().Lookup("nodeps"))
|
LuetCfg.Viper.BindPFlag("nodeps", cmd.Flags().Lookup("nodeps"))
|
||||||
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
||||||
LuetCfg.Viper.BindPFlag("yes", cmd.Flags().Lookup("yes"))
|
LuetCfg.Viper.BindPFlag("yes", cmd.Flags().Lookup("yes"))
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
|
||||||
},
|
},
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
toRemove := []pkg.Package{}
|
toRemove := []pkg.Package{}
|
||||||
@@ -53,10 +49,6 @@ var uninstallCmd = &cobra.Command{
|
|||||||
toRemove = append(toRemove, pack)
|
toRemove = append(toRemove, pack)
|
||||||
}
|
}
|
||||||
|
|
||||||
stype := LuetCfg.Viper.GetString("solver.type")
|
|
||||||
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
|
||||||
rate := LuetCfg.Viper.GetFloat64("solver.rate")
|
|
||||||
attempts := LuetCfg.Viper.GetInt("solver.max_attempts")
|
|
||||||
force := LuetCfg.Viper.GetBool("force")
|
force := LuetCfg.Viper.GetBool("force")
|
||||||
nodeps, _ := cmd.Flags().GetBool("nodeps")
|
nodeps, _ := cmd.Flags().GetBool("nodeps")
|
||||||
full, _ := cmd.Flags().GetBool("full")
|
full, _ := cmd.Flags().GetBool("full")
|
||||||
@@ -64,20 +56,12 @@ var uninstallCmd = &cobra.Command{
|
|||||||
fullClean, _ := cmd.Flags().GetBool("full-clean")
|
fullClean, _ := cmd.Flags().GetBool("full-clean")
|
||||||
concurrent, _ := cmd.Flags().GetBool("solver-concurrent")
|
concurrent, _ := cmd.Flags().GetBool("solver-concurrent")
|
||||||
yes := LuetCfg.Viper.GetBool("yes")
|
yes := LuetCfg.Viper.GetBool("yes")
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
keepProtected, _ := cmd.Flags().GetBool("keep-protected-files")
|
keepProtected, _ := cmd.Flags().GetBool("keep-protected-files")
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
util.SetSystemConfig()
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
util.SetSolverConfig()
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
LuetCfg.ConfigProtectSkip = !keepProtected
|
|
||||||
|
|
||||||
LuetCfg.GetSolverOptions().Type = stype
|
LuetCfg.ConfigProtectSkip = !keepProtected
|
||||||
LuetCfg.GetSolverOptions().LearnRate = float32(rate)
|
|
||||||
LuetCfg.GetSolverOptions().Discount = float32(discount)
|
|
||||||
LuetCfg.GetSolverOptions().MaxAttempts = attempts
|
|
||||||
if concurrent {
|
if concurrent {
|
||||||
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
||||||
} else {
|
} else {
|
||||||
|
@@ -15,6 +15,7 @@
|
|||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/mudler/luet/cmd/util"
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
installer "github.com/mudler/luet/pkg/installer"
|
installer "github.com/mudler/luet/pkg/installer"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
@@ -28,15 +29,10 @@ var upgradeCmd = &cobra.Command{
|
|||||||
Short: "Upgrades the system",
|
Short: "Upgrades the system",
|
||||||
Aliases: []string{"u"},
|
Aliases: []string{"u"},
|
||||||
PreRun: func(cmd *cobra.Command, args []string) {
|
PreRun: func(cmd *cobra.Command, args []string) {
|
||||||
LuetCfg.Viper.BindPFlag("system.database_path", installCmd.Flags().Lookup("system-dbpath"))
|
util.BindSystemFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("system.rootfs", installCmd.Flags().Lookup("system-target"))
|
util.BindSolverFlags(cmd)
|
||||||
LuetCfg.Viper.BindPFlag("solver.type", cmd.Flags().Lookup("solver-type"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.discount", cmd.Flags().Lookup("solver-discount"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.rate", cmd.Flags().Lookup("solver-rate"))
|
|
||||||
LuetCfg.Viper.BindPFlag("solver.max_attempts", cmd.Flags().Lookup("solver-attempts"))
|
|
||||||
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
LuetCfg.Viper.BindPFlag("force", cmd.Flags().Lookup("force"))
|
||||||
LuetCfg.Viper.BindPFlag("yes", cmd.Flags().Lookup("yes"))
|
LuetCfg.Viper.BindPFlag("yes", cmd.Flags().Lookup("yes"))
|
||||||
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
|
||||||
},
|
},
|
||||||
Long: `Upgrades packages in parallel`,
|
Long: `Upgrades packages in parallel`,
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
@@ -51,10 +47,6 @@ var upgradeCmd = &cobra.Command{
|
|||||||
repos = append(repos, r)
|
repos = append(repos, r)
|
||||||
}
|
}
|
||||||
|
|
||||||
stype := LuetCfg.Viper.GetString("solver.type")
|
|
||||||
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
|
||||||
rate := LuetCfg.Viper.GetFloat64("solver.rate")
|
|
||||||
attempts := LuetCfg.Viper.GetInt("solver.max_attempts")
|
|
||||||
force := LuetCfg.Viper.GetBool("force")
|
force := LuetCfg.Viper.GetBool("force")
|
||||||
nodeps, _ := cmd.Flags().GetBool("nodeps")
|
nodeps, _ := cmd.Flags().GetBool("nodeps")
|
||||||
full, _ := cmd.Flags().GetBool("full")
|
full, _ := cmd.Flags().GetBool("full")
|
||||||
@@ -63,18 +55,11 @@ var upgradeCmd = &cobra.Command{
|
|||||||
sync, _ := cmd.Flags().GetBool("sync")
|
sync, _ := cmd.Flags().GetBool("sync")
|
||||||
concurrent, _ := cmd.Flags().GetBool("solver-concurrent")
|
concurrent, _ := cmd.Flags().GetBool("solver-concurrent")
|
||||||
yes := LuetCfg.Viper.GetBool("yes")
|
yes := LuetCfg.Viper.GetBool("yes")
|
||||||
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
|
||||||
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
|
||||||
engine := LuetCfg.Viper.GetString("system.database_engine")
|
|
||||||
downloadOnly, _ := cmd.Flags().GetBool("download-only")
|
downloadOnly, _ := cmd.Flags().GetBool("download-only")
|
||||||
|
|
||||||
LuetCfg.System.DatabaseEngine = engine
|
util.SetSystemConfig()
|
||||||
LuetCfg.System.DatabasePath = dbpath
|
util.SetSolverConfig()
|
||||||
LuetCfg.System.Rootfs = rootfs
|
|
||||||
LuetCfg.GetSolverOptions().Type = stype
|
|
||||||
LuetCfg.GetSolverOptions().LearnRate = float32(rate)
|
|
||||||
LuetCfg.GetSolverOptions().Discount = float32(discount)
|
|
||||||
LuetCfg.GetSolverOptions().MaxAttempts = attempts
|
|
||||||
if concurrent {
|
if concurrent {
|
||||||
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
LuetCfg.GetSolverOptions().Implementation = solver.ParallelSimple
|
||||||
} else {
|
} else {
|
||||||
|
65
cmd/util/cli.go
Normal file
65
cmd/util/cli.go
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
// Copyright © 2021 Ettore Di Giacinto <mudler@mocaccino.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 util
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
|
"github.com/mudler/luet/pkg/config"
|
||||||
|
. "github.com/mudler/luet/pkg/config"
|
||||||
|
)
|
||||||
|
|
||||||
|
func BindSystemFlags(cmd *cobra.Command) {
|
||||||
|
LuetCfg.Viper.BindPFlag("system.database_path", cmd.Flags().Lookup("system-dbpath"))
|
||||||
|
LuetCfg.Viper.BindPFlag("system.rootfs", cmd.Flags().Lookup("system-target"))
|
||||||
|
LuetCfg.Viper.BindPFlag("system.database_engine", cmd.Flags().Lookup("system-engine"))
|
||||||
|
}
|
||||||
|
|
||||||
|
func BindSolverFlags(cmd *cobra.Command) {
|
||||||
|
LuetCfg.Viper.BindPFlag("solver.type", cmd.Flags().Lookup("solver-type"))
|
||||||
|
LuetCfg.Viper.BindPFlag("solver.discount", cmd.Flags().Lookup("solver-discount"))
|
||||||
|
LuetCfg.Viper.BindPFlag("solver.rate", cmd.Flags().Lookup("solver-rate"))
|
||||||
|
LuetCfg.Viper.BindPFlag("solver.max_attempts", cmd.Flags().Lookup("solver-attempts"))
|
||||||
|
}
|
||||||
|
|
||||||
|
func SetSystemConfig() {
|
||||||
|
dbpath := LuetCfg.Viper.GetString("system.database_path")
|
||||||
|
rootfs := LuetCfg.Viper.GetString("system.rootfs")
|
||||||
|
engine := LuetCfg.Viper.GetString("system.database_engine")
|
||||||
|
|
||||||
|
LuetCfg.System.DatabaseEngine = engine
|
||||||
|
LuetCfg.System.DatabasePath = dbpath
|
||||||
|
LuetCfg.System.SetRootFS(rootfs)
|
||||||
|
}
|
||||||
|
|
||||||
|
func SetSolverConfig() (c *config.LuetSolverOptions) {
|
||||||
|
stype := LuetCfg.Viper.GetString("solver.type")
|
||||||
|
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
||||||
|
rate := LuetCfg.Viper.GetFloat64("solver.rate")
|
||||||
|
attempts := LuetCfg.Viper.GetInt("solver.max_attempts")
|
||||||
|
|
||||||
|
LuetCfg.GetSolverOptions().Type = stype
|
||||||
|
LuetCfg.GetSolverOptions().LearnRate = float32(rate)
|
||||||
|
LuetCfg.GetSolverOptions().Discount = float32(discount)
|
||||||
|
LuetCfg.GetSolverOptions().MaxAttempts = attempts
|
||||||
|
|
||||||
|
return &config.LuetSolverOptions{
|
||||||
|
Type: stype,
|
||||||
|
LearnRate: float32(rate),
|
||||||
|
Discount: float32(discount),
|
||||||
|
MaxAttempts: attempts,
|
||||||
|
}
|
||||||
|
}
|
@@ -1256,6 +1256,11 @@ func (cs *LuetCompiler) FromPackage(p pkg.Package) (*compilerspec.LuetCompilatio
|
|||||||
|
|
||||||
cs.inheritSpecBuildOptions(newSpec)
|
cs.inheritSpecBuildOptions(newSpec)
|
||||||
|
|
||||||
|
// Update the package in the compiler database to catch updates from NewLuetCompilationSpec
|
||||||
|
if err := cs.Database.UpdatePackage(newSpec.Package); err != nil {
|
||||||
|
return nil, errors.Wrap(err, "failed updating new package entry in compiler database")
|
||||||
|
}
|
||||||
|
|
||||||
return newSpec, err
|
return newSpec, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -453,6 +453,9 @@ func (a *PackageArtifact) GetProtectFiles() []string {
|
|||||||
|
|
||||||
// Unpack Untar and decompress (TODO) to the given path
|
// Unpack Untar and decompress (TODO) to the given path
|
||||||
func (a *PackageArtifact) Unpack(dst string, keepPerms bool) error {
|
func (a *PackageArtifact) Unpack(dst string, keepPerms bool) error {
|
||||||
|
if !strings.HasPrefix(dst, "/") {
|
||||||
|
return errors.New("destination must be an absolute path")
|
||||||
|
}
|
||||||
|
|
||||||
// Create
|
// Create
|
||||||
protectedFiles := a.GetProtectFiles()
|
protectedFiles := a.GetProtectFiles()
|
||||||
|
@@ -23,11 +23,11 @@ import (
|
|||||||
"github.com/mitchellh/hashstructure/v2"
|
"github.com/mitchellh/hashstructure/v2"
|
||||||
options "github.com/mudler/luet/pkg/compiler/types/options"
|
options "github.com/mudler/luet/pkg/compiler/types/options"
|
||||||
|
|
||||||
|
"github.com/ghodss/yaml"
|
||||||
pkg "github.com/mudler/luet/pkg/package"
|
pkg "github.com/mudler/luet/pkg/package"
|
||||||
"github.com/mudler/luet/pkg/solver"
|
"github.com/mudler/luet/pkg/solver"
|
||||||
"github.com/otiai10/copy"
|
"github.com/otiai10/copy"
|
||||||
dirhash "golang.org/x/mod/sumdb/dirhash"
|
dirhash "golang.org/x/mod/sumdb/dirhash"
|
||||||
yaml "gopkg.in/yaml.v2"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type LuetCompilationspecs []LuetCompilationSpec
|
type LuetCompilationspecs []LuetCompilationSpec
|
||||||
@@ -157,11 +157,31 @@ func (cs *LuetCompilationSpec) signature() Signature {
|
|||||||
|
|
||||||
func NewLuetCompilationSpec(b []byte, p pkg.Package) (*LuetCompilationSpec, error) {
|
func NewLuetCompilationSpec(b []byte, p pkg.Package) (*LuetCompilationSpec, error) {
|
||||||
var spec LuetCompilationSpec
|
var spec LuetCompilationSpec
|
||||||
|
var packageDefinition pkg.DefaultPackage
|
||||||
err := yaml.Unmarshal(b, &spec)
|
err := yaml.Unmarshal(b, &spec)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return &spec, err
|
return &spec, err
|
||||||
}
|
}
|
||||||
spec.Package = p.(*pkg.DefaultPackage)
|
err = yaml.Unmarshal(b, &packageDefinition)
|
||||||
|
if err != nil {
|
||||||
|
return &spec, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update requires/conflict/provides
|
||||||
|
// When we have been passed a bytes slice, parse it as a package
|
||||||
|
// and updates requires/conflicts/provides.
|
||||||
|
// This is required in order to allow manipulation of such fields with templating
|
||||||
|
copy := *p.(*pkg.DefaultPackage)
|
||||||
|
spec.Package = ©
|
||||||
|
if len(packageDefinition.GetRequires()) != 0 {
|
||||||
|
spec.Package.Requires(packageDefinition.GetRequires())
|
||||||
|
}
|
||||||
|
if len(packageDefinition.GetConflicts()) != 0 {
|
||||||
|
spec.Package.Conflicts(packageDefinition.GetConflicts())
|
||||||
|
}
|
||||||
|
if len(packageDefinition.GetProvides()) != 0 {
|
||||||
|
spec.Package.SetProvides(packageDefinition.GetProvides())
|
||||||
|
}
|
||||||
return &spec, nil
|
return &spec, nil
|
||||||
}
|
}
|
||||||
func (cs *LuetCompilationSpec) GetSourceAssertion() solver.PackagesAssertions {
|
func (cs *LuetCompilationSpec) GetSourceAssertion() solver.PackagesAssertions {
|
||||||
@@ -270,10 +290,13 @@ func (cs *LuetCompilationSpec) Hash() (string, error) {
|
|||||||
// build a signature, we want to be part of the hash only the fields that are relevant for build purposes
|
// build a signature, we want to be part of the hash only the fields that are relevant for build purposes
|
||||||
signature := cs.signature()
|
signature := cs.signature()
|
||||||
h, err := hashstructure.Hash(signature, hashstructure.FormatV2, nil)
|
h, err := hashstructure.Hash(signature, hashstructure.FormatV2, nil)
|
||||||
sum, err := dirhash.HashDir(cs.Package.Path, "", dirhash.DefaultHash)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
sum, err := dirhash.HashDir(cs.Package.Path, "", dirhash.DefaultHash)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Sprint(h), err
|
||||||
|
}
|
||||||
return fmt.Sprint(h, sum), err
|
return fmt.Sprint(h, sum), err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -107,6 +107,19 @@ type LuetSystemConfig struct {
|
|||||||
TmpDirBase string `yaml:"tmpdir_base" mapstructure:"tmpdir_base"`
|
TmpDirBase string `yaml:"tmpdir_base" mapstructure:"tmpdir_base"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *LuetSystemConfig) SetRootFS(path string) error {
|
||||||
|
pathToSet := path
|
||||||
|
if !filepath.IsAbs(path) {
|
||||||
|
abs, err := filepath.Abs(path)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
pathToSet = abs
|
||||||
|
}
|
||||||
|
s.Rootfs = pathToSet
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func (sc *LuetSystemConfig) GetRepoDatabaseDirPath(name string) string {
|
func (sc *LuetSystemConfig) GetRepoDatabaseDirPath(name string) string {
|
||||||
dbpath := filepath.Join(sc.Rootfs, sc.DatabasePath)
|
dbpath := filepath.Join(sc.Rootfs, sc.DatabasePath)
|
||||||
dbpath = filepath.Join(dbpath, "repos/"+name)
|
dbpath = filepath.Join(dbpath, "repos/"+name)
|
||||||
|
@@ -18,10 +18,12 @@ package client
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
"math"
|
||||||
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"path"
|
"path"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
"strconv"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/mudler/luet/pkg/compiler/types/artifact"
|
"github.com/mudler/luet/pkg/compiler/types/artifact"
|
||||||
@@ -42,6 +44,27 @@ func NewHttpClient(r RepoData) *HttpClient {
|
|||||||
return &HttpClient{RepoData: r}
|
return &HttpClient{RepoData: r}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func NewGrabClient() *grab.Client {
|
||||||
|
httpTimeout := 30
|
||||||
|
timeout := os.Getenv("HTTP_TIMEOUT")
|
||||||
|
if timeout != "" {
|
||||||
|
timeoutI, err := strconv.Atoi(timeout)
|
||||||
|
if err == nil {
|
||||||
|
httpTimeout = timeoutI
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return &grab.Client{
|
||||||
|
UserAgent: "grab",
|
||||||
|
HTTPClient: &http.Client{
|
||||||
|
Timeout: time.Duration(httpTimeout) * time.Second,
|
||||||
|
Transport: &http.Transport{
|
||||||
|
Proxy: http.ProxyFromEnvironment,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (c *HttpClient) PrepareReq(dst, url string) (*grab.Request, error) {
|
func (c *HttpClient) PrepareReq(dst, url string) (*grab.Request, error) {
|
||||||
|
|
||||||
req, err := grab.NewRequest(dst, url)
|
req, err := grab.NewRequest(dst, url)
|
||||||
@@ -86,7 +109,7 @@ func (c *HttpClient) DownloadArtifact(a *artifact.PackageArtifact) (*artifact.Pa
|
|||||||
}
|
}
|
||||||
defer os.RemoveAll(temp)
|
defer os.RemoveAll(temp)
|
||||||
|
|
||||||
client := grab.NewClient()
|
client := NewGrabClient()
|
||||||
|
|
||||||
for _, uri := range c.RepoData.Urls {
|
for _, uri := range c.RepoData.Urls {
|
||||||
Debug("Downloading artifact", artifactName, "from", uri)
|
Debug("Downloading artifact", artifactName, "from", uri)
|
||||||
@@ -186,7 +209,7 @@ func (c *HttpClient) DownloadFile(name string) (string, error) {
|
|||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
client := grab.NewClient()
|
client := NewGrabClient()
|
||||||
|
|
||||||
for _, uri := range c.RepoData.Urls {
|
for _, uri := range c.RepoData.Urls {
|
||||||
|
|
||||||
|
@@ -272,6 +272,15 @@ func (l *LuetInstaller) swap(o Option, syncedRepos Repositories, toRemove pkg.Pa
|
|||||||
if err := l.download(syncedRepos, match); err != nil {
|
if err := l.download(syncedRepos, match); err != nil {
|
||||||
return errors.Wrap(err, "Pre-downloading packages")
|
return errors.Wrap(err, "Pre-downloading packages")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := l.checkFileconflicts(match, false, s); err != nil {
|
||||||
|
if !l.Options.Force {
|
||||||
|
return errors.Wrap(err, "file conflict found")
|
||||||
|
} else {
|
||||||
|
Warning("file conflict found", err.Error())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if l.Options.DownloadOnly {
|
if l.Options.DownloadOnly {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@@ -756,7 +765,7 @@ func (l *LuetInstaller) getFinalizers(allRepos pkg.PackageDatabase, solution sol
|
|||||||
return toFinalize, nil
|
return toFinalize, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *LuetInstaller) checkFileconflicts(toInstall map[string]ArtifactMatch, s *System) error {
|
func (l *LuetInstaller) checkFileconflicts(toInstall map[string]ArtifactMatch, checkSystem bool, s *System) error {
|
||||||
Info("Checking for file conflicts..")
|
Info("Checking for file conflicts..")
|
||||||
defer s.Clean() // Release memory
|
defer s.Clean() // Release memory
|
||||||
|
|
||||||
@@ -777,7 +786,7 @@ func (l *LuetInstaller) checkFileconflicts(toInstall map[string]ArtifactMatch, s
|
|||||||
"file conflict between packages to be installed",
|
"file conflict between packages to be installed",
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
if checkSystem {
|
||||||
exists, p, err := s.ExistsPackageFile(f)
|
exists, p, err := s.ExistsPackageFile(f)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Wrap(err, "failed checking into system db")
|
return errors.Wrap(err, "failed checking into system db")
|
||||||
@@ -791,6 +800,7 @@ func (l *LuetInstaller) checkFileconflicts(toInstall map[string]ArtifactMatch, s
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
filesToInstall = append(filesToInstall, files...)
|
filesToInstall = append(filesToInstall, files...)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -805,7 +815,7 @@ func (l *LuetInstaller) install(o Option, syncedRepos Repositories, toInstall ma
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Check file conflicts
|
// Check file conflicts
|
||||||
if err := l.checkFileconflicts(toInstall, s); err != nil {
|
if err := l.checkFileconflicts(toInstall, true, s); err != nil {
|
||||||
if !l.Options.Force {
|
if !l.Options.Force {
|
||||||
return errors.Wrap(err, "file conflict found")
|
return errors.Wrap(err, "file conflict found")
|
||||||
} else {
|
} else {
|
||||||
|
6
tests/fixtures/fileconflicts_upgrade/conflict1/build.yaml
vendored
Normal file
6
tests/fixtures/fileconflicts_upgrade/conflict1/build.yaml
vendored
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
image: "alpine"
|
||||||
|
prelude:
|
||||||
|
- mkdir /foo
|
||||||
|
steps:
|
||||||
|
- echo conflict > /foo/test1
|
||||||
|
package_dir: /foo
|
13
tests/fixtures/fileconflicts_upgrade/conflict1/collection.yaml
vendored
Normal file
13
tests/fixtures/fileconflicts_upgrade/conflict1/collection.yaml
vendored
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
packages:
|
||||||
|
- category: "test1"
|
||||||
|
name: "conflict"
|
||||||
|
version: "1.0"
|
||||||
|
- category: "test2"
|
||||||
|
name: "conflict"
|
||||||
|
version: "1.0"
|
||||||
|
- category: "test1"
|
||||||
|
name: "conflict"
|
||||||
|
version: "1.1"
|
||||||
|
- category: "test2"
|
||||||
|
name: "conflict"
|
||||||
|
version: "1.1"
|
81
tests/integration/32_fileconflicts_upgrade.sh
Executable file
81
tests/integration/32_fileconflicts_upgrade.sh
Executable file
@@ -0,0 +1,81 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
export LUET_NOLOCK=true
|
||||||
|
|
||||||
|
oneTimeSetUp() {
|
||||||
|
export tmpdir="$(mktemp -d)"
|
||||||
|
}
|
||||||
|
|
||||||
|
oneTimeTearDown() {
|
||||||
|
rm -rf "$tmpdir"
|
||||||
|
}
|
||||||
|
|
||||||
|
testBuild() {
|
||||||
|
mkdir $tmpdir/testbuild
|
||||||
|
luet build --tree "$ROOT_DIR/tests/fixtures/fileconflicts_upgrade" --destination $tmpdir/testbuild --compression gzip --all
|
||||||
|
buildst=$?
|
||||||
|
assertEquals 'builds successfully' "$buildst" "0"
|
||||||
|
assertTrue 'create packages' "[ -e '$tmpdir/testbuild/conflict-test1-1.0.package.tar.gz' ]"
|
||||||
|
assertTrue 'create packages' "[ -e '$tmpdir/testbuild/conflict-test2-1.0.package.tar.gz' ]"
|
||||||
|
}
|
||||||
|
|
||||||
|
testRepo() {
|
||||||
|
assertTrue 'no repository' "[ ! -e '$tmpdir/testbuild/repository.yaml' ]"
|
||||||
|
luet create-repo --tree "$ROOT_DIR/tests/fixtures/fileconflicts_upgrade" \
|
||||||
|
--output $tmpdir/testbuild \
|
||||||
|
--packages $tmpdir/testbuild \
|
||||||
|
--name "test" \
|
||||||
|
--descr "Test Repo" \
|
||||||
|
--urls $tmpdir/testrootfs \
|
||||||
|
--type disk > /dev/null
|
||||||
|
|
||||||
|
createst=$?
|
||||||
|
assertEquals 'create repo successfully' "$createst" "0"
|
||||||
|
assertTrue 'create repository' "[ -e '$tmpdir/testbuild/repository.yaml' ]"
|
||||||
|
}
|
||||||
|
|
||||||
|
testConfig() {
|
||||||
|
mkdir $tmpdir/testrootfs
|
||||||
|
cat <<EOF > $tmpdir/luet.yaml
|
||||||
|
general:
|
||||||
|
debug: true
|
||||||
|
system:
|
||||||
|
rootfs: $tmpdir/testrootfs
|
||||||
|
database_path: "/"
|
||||||
|
database_engine: "boltdb"
|
||||||
|
config_from_host: true
|
||||||
|
repositories:
|
||||||
|
- name: "main"
|
||||||
|
type: "disk"
|
||||||
|
enable: true
|
||||||
|
urls:
|
||||||
|
- "$tmpdir/testbuild"
|
||||||
|
EOF
|
||||||
|
luet config --config $tmpdir/luet.yaml
|
||||||
|
res=$?
|
||||||
|
assertEquals 'config test successfully' "$res" "0"
|
||||||
|
}
|
||||||
|
|
||||||
|
testInstall() {
|
||||||
|
luet install -y --force --config $tmpdir/luet.yaml test1/conflict@1.0 test2/conflict@1.0
|
||||||
|
#luet install -y --config $tmpdir/luet.yaml test/c@1.0 > /dev/null
|
||||||
|
installst=$?
|
||||||
|
assertEquals 'install test succeded' "$installst" "0"
|
||||||
|
#assertTrue 'package installed' "[ -e '$tmpdir/testrootfs/c' ]"
|
||||||
|
}
|
||||||
|
|
||||||
|
testUpgrade() {
|
||||||
|
out=$(luet upgrade -y --config $tmpdir/luet.yaml)
|
||||||
|
installst=$?
|
||||||
|
assertEquals 'install test succeeded' "$installst" "1"
|
||||||
|
assertContains 'does find conflicts' "$out" "Error: file conflict found: file conflict between packages to be installed"
|
||||||
|
|
||||||
|
luet upgrade -y --config $tmpdir/luet.yaml --force
|
||||||
|
#luet install -y --config $tmpdir/luet.yaml test/c@1.0 > /dev/null
|
||||||
|
installst=$?
|
||||||
|
assertEquals 'install test succeeded' "$installst" "0"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Load shUnit2.
|
||||||
|
. "$ROOT_DIR/tests/integration/shunit2"/shunit2
|
||||||
|
|
Reference in New Issue
Block a user