|
@@ -6,6 +6,7 @@ import (
|
|
|
"io"
|
|
|
"os"
|
|
|
"os/exec"
|
|
|
+ "path/filepath"
|
|
|
"strings"
|
|
|
"sync"
|
|
|
"testing"
|
|
@@ -169,7 +170,7 @@ func TestIntegrationLocalInstall(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
func TestIntegrationLocalInstallMissingDep(t *testing.T) {
|
|
|
- wantErr := "could not find dotnet-sdk<7"
|
|
|
+ wantErr := ErrPackagesNotFound
|
|
|
makepkgBin := t.TempDir() + "/makepkg"
|
|
|
pacmanBin := t.TempDir() + "/pacman"
|
|
|
gitBin := t.TempDir() + "/git"
|
|
@@ -270,8 +271,7 @@ func TestIntegrationLocalInstallMissingDep(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
err = handleCmd(context.Background(), config, cmdArgs, db)
|
|
|
- require.Error(t, err)
|
|
|
- require.EqualError(t, err, wantErr)
|
|
|
+ require.ErrorContains(t, err, wantErr.Error())
|
|
|
|
|
|
require.Len(t, mockRunner.ShowCalls, len(wantShow))
|
|
|
require.Len(t, mockRunner.CaptureCalls, len(wantCapture))
|
|
@@ -445,3 +445,300 @@ func TestIntegrationLocalInstallNeeded(t *testing.T) {
|
|
|
assert.Subset(t, strings.Split(show, " "), strings.Split(wantShow[i], " "), fmt.Sprintf("%d - %s", i, show))
|
|
|
}
|
|
|
}
|
|
|
+
|
|
|
+func TestIntegrationLocalInstallGenerateSRCINFO(t *testing.T) {
|
|
|
+ makepkgBin := t.TempDir() + "/makepkg"
|
|
|
+ pacmanBin := t.TempDir() + "/pacman"
|
|
|
+ gitBin := t.TempDir() + "/git"
|
|
|
+ tmpDir := t.TempDir()
|
|
|
+ f, err := os.OpenFile(makepkgBin, os.O_RDONLY|os.O_CREATE, 0o755)
|
|
|
+ require.NoError(t, err)
|
|
|
+ require.NoError(t, f.Close())
|
|
|
+
|
|
|
+ f, err = os.OpenFile(pacmanBin, os.O_RDONLY|os.O_CREATE, 0o755)
|
|
|
+ require.NoError(t, err)
|
|
|
+ require.NoError(t, f.Close())
|
|
|
+
|
|
|
+ f, err = os.OpenFile(gitBin, os.O_RDONLY|os.O_CREATE, 0o755)
|
|
|
+ require.NoError(t, err)
|
|
|
+ require.NoError(t, f.Close())
|
|
|
+
|
|
|
+ srcinfo, err := os.ReadFile("testdata/jfin/.SRCINFO")
|
|
|
+ require.NoError(t, err)
|
|
|
+ assert.True(t, strings.HasPrefix(string(srcinfo), "pkgbase = jellyfin"), string(srcinfo))
|
|
|
+
|
|
|
+ targetDir := t.TempDir()
|
|
|
+ f, err = os.OpenFile(filepath.Join(targetDir, "PKGBUILD"), os.O_RDONLY|os.O_CREATE, 0o755)
|
|
|
+ require.NoError(t, err)
|
|
|
+ require.NoError(t, f.Close())
|
|
|
+
|
|
|
+ tars := []string{
|
|
|
+ tmpDir + "/jellyfin-10.8.4-1-x86_64.pkg.tar.zst",
|
|
|
+ tmpDir + "/jellyfin-web-10.8.4-1-x86_64.pkg.tar.zst",
|
|
|
+ tmpDir + "/jellyfin-server-10.8.4-1-x86_64.pkg.tar.zst",
|
|
|
+ }
|
|
|
+
|
|
|
+ wantShow := []string{
|
|
|
+ "makepkg --verifysource -Ccf",
|
|
|
+ "pacman -S --config /etc/pacman.conf -- community/dotnet-sdk-6.0 community/dotnet-runtime-6.0",
|
|
|
+ "pacman -D -q --asdeps --config /etc/pacman.conf -- dotnet-runtime-6.0 dotnet-sdk-6.0",
|
|
|
+ "makepkg --nobuild -fC --ignorearch",
|
|
|
+ "makepkg -c --nobuild --noextract --ignorearch",
|
|
|
+ "makepkg --nobuild -fC --ignorearch",
|
|
|
+ "makepkg -c --nobuild --noextract --ignorearch",
|
|
|
+ "makepkg --nobuild -fC --ignorearch",
|
|
|
+ "makepkg -c --nobuild --noextract --ignorearch",
|
|
|
+ "pacman -U --config /etc/pacman.conf -- /testdir/jellyfin-server-10.8.4-1-x86_64.pkg.tar.zst /testdir/jellyfin-10.8.4-1-x86_64.pkg.tar.zst /testdir/jellyfin-web-10.8.4-1-x86_64.pkg.tar.zst",
|
|
|
+ "pacman -D -q --asexplicit --config /etc/pacman.conf -- jellyfin-server jellyfin jellyfin-web",
|
|
|
+ }
|
|
|
+
|
|
|
+ wantCapture := []string{
|
|
|
+ "makepkg --printsrcinfo",
|
|
|
+ "makepkg --packagelist",
|
|
|
+ "git -C testdata/jfin git reset --hard HEAD",
|
|
|
+ "git -C testdata/jfin git merge --no-edit --ff",
|
|
|
+ "makepkg --packagelist",
|
|
|
+ "makepkg --packagelist",
|
|
|
+ }
|
|
|
+
|
|
|
+ captureOverride := func(cmd *exec.Cmd) (stdout string, stderr string, err error) {
|
|
|
+ for _, arg := range cmd.Args {
|
|
|
+ if arg == "--printsrcinfo" {
|
|
|
+ return string(srcinfo), "", nil
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return strings.Join(tars, "\n"), "", nil
|
|
|
+ }
|
|
|
+
|
|
|
+ once := sync.Once{}
|
|
|
+
|
|
|
+ showOverride := func(cmd *exec.Cmd) error {
|
|
|
+ once.Do(func() {
|
|
|
+ for _, tar := range tars {
|
|
|
+ f, err := os.OpenFile(tar, os.O_RDONLY|os.O_CREATE, 0o666)
|
|
|
+ require.NoError(t, err)
|
|
|
+ require.NoError(t, f.Close())
|
|
|
+ }
|
|
|
+ })
|
|
|
+ return nil
|
|
|
+ }
|
|
|
+
|
|
|
+ mockRunner := &exe.MockRunner{CaptureFn: captureOverride, ShowFn: showOverride}
|
|
|
+ cmdBuilder := &exe.CmdBuilder{
|
|
|
+ MakepkgBin: makepkgBin,
|
|
|
+ SudoBin: "su",
|
|
|
+ PacmanBin: pacmanBin,
|
|
|
+ PacmanConfigPath: "/etc/pacman.conf",
|
|
|
+ GitBin: "git",
|
|
|
+ Runner: mockRunner,
|
|
|
+ SudoLoopEnabled: false,
|
|
|
+ }
|
|
|
+
|
|
|
+ cmdArgs := parser.MakeArguments()
|
|
|
+ cmdArgs.AddArg("B")
|
|
|
+ cmdArgs.AddArg("i")
|
|
|
+ cmdArgs.AddTarget(targetDir)
|
|
|
+ settings.NoConfirm = true
|
|
|
+ defer func() { settings.NoConfirm = false }()
|
|
|
+ db := &mock.DBExecutor{
|
|
|
+ AlpmArchitecturesFn: func() ([]string, error) {
|
|
|
+ return []string{"x86_64"}, nil
|
|
|
+ },
|
|
|
+ LocalSatisfierExistsFn: func(s string) bool {
|
|
|
+ switch s {
|
|
|
+ case "dotnet-sdk>=6", "dotnet-sdk<7", "dotnet-runtime>=6", "dotnet-runtime<7", "jellyfin-server=10.8.4", "jellyfin-web=10.8.4":
|
|
|
+ return false
|
|
|
+ }
|
|
|
+
|
|
|
+ return true
|
|
|
+ },
|
|
|
+ SyncSatisfierFn: func(s string) mock.IPackage {
|
|
|
+ switch s {
|
|
|
+ case "dotnet-runtime>=6", "dotnet-runtime<7":
|
|
|
+ return &mock.Package{
|
|
|
+ PName: "dotnet-runtime-6.0",
|
|
|
+ PBase: "dotnet-runtime-6.0",
|
|
|
+ PVersion: "6.0.100-1",
|
|
|
+ PDB: mock.NewDB("community"),
|
|
|
+ }
|
|
|
+ case "dotnet-sdk>=6", "dotnet-sdk<7":
|
|
|
+ return &mock.Package{
|
|
|
+ PName: "dotnet-sdk-6.0",
|
|
|
+ PBase: "dotnet-sdk-6.0",
|
|
|
+ PVersion: "6.0.100-1",
|
|
|
+ PDB: mock.NewDB("community"),
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return nil
|
|
|
+ },
|
|
|
+ }
|
|
|
+
|
|
|
+ config := &settings.Configuration{
|
|
|
+ RemoveMake: "no",
|
|
|
+ Debug: false,
|
|
|
+ Runtime: &settings.Runtime{
|
|
|
+ Logger: text.NewLogger(io.Discard, strings.NewReader(""), true, "test"),
|
|
|
+ CmdBuilder: cmdBuilder,
|
|
|
+ VCSStore: &vcs.Mock{},
|
|
|
+ AURCache: &mockaur.MockAUR{
|
|
|
+ GetFn: func(ctx context.Context, query *aur.Query) ([]aur.Pkg, error) {
|
|
|
+ return []aur.Pkg{}, nil
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ }
|
|
|
+
|
|
|
+ err = handleCmd(context.Background(), config, cmdArgs, db)
|
|
|
+ require.NoError(t, err)
|
|
|
+
|
|
|
+ require.Len(t, mockRunner.ShowCalls, len(wantShow))
|
|
|
+ require.Len(t, mockRunner.CaptureCalls, len(wantCapture))
|
|
|
+
|
|
|
+ for i, call := range mockRunner.ShowCalls {
|
|
|
+ show := call.Args[0].(*exec.Cmd).String()
|
|
|
+ show = strings.ReplaceAll(show, tmpDir, "/testdir") // replace the temp dir with a static path
|
|
|
+ show = strings.ReplaceAll(show, makepkgBin, "makepkg")
|
|
|
+ show = strings.ReplaceAll(show, pacmanBin, "pacman")
|
|
|
+ show = strings.ReplaceAll(show, gitBin, "pacman")
|
|
|
+
|
|
|
+ // options are in a different order on different systems and on CI root user is used
|
|
|
+ assert.Subset(t, strings.Split(show, " "), strings.Split(wantShow[i], " "), fmt.Sprintf("%d - %s", i, show))
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+func TestIntegrationLocalInstallMissingFiles(t *testing.T) {
|
|
|
+ makepkgBin := t.TempDir() + "/makepkg"
|
|
|
+ pacmanBin := t.TempDir() + "/pacman"
|
|
|
+ gitBin := t.TempDir() + "/git"
|
|
|
+ tmpDir := t.TempDir()
|
|
|
+ f, err := os.OpenFile(makepkgBin, os.O_RDONLY|os.O_CREATE, 0o755)
|
|
|
+ require.NoError(t, err)
|
|
|
+ require.NoError(t, f.Close())
|
|
|
+
|
|
|
+ f, err = os.OpenFile(pacmanBin, os.O_RDONLY|os.O_CREATE, 0o755)
|
|
|
+ require.NoError(t, err)
|
|
|
+ require.NoError(t, f.Close())
|
|
|
+
|
|
|
+ f, err = os.OpenFile(gitBin, os.O_RDONLY|os.O_CREATE, 0o755)
|
|
|
+ require.NoError(t, err)
|
|
|
+ require.NoError(t, f.Close())
|
|
|
+
|
|
|
+ srcinfo, err := os.ReadFile("testdata/jfin/.SRCINFO")
|
|
|
+ require.NoError(t, err)
|
|
|
+
|
|
|
+ targetDir := t.TempDir()
|
|
|
+
|
|
|
+ tars := []string{
|
|
|
+ tmpDir + "/jellyfin-10.8.4-1-x86_64.pkg.tar.zst",
|
|
|
+ tmpDir + "/jellyfin-web-10.8.4-1-x86_64.pkg.tar.zst",
|
|
|
+ tmpDir + "/jellyfin-server-10.8.4-1-x86_64.pkg.tar.zst",
|
|
|
+ }
|
|
|
+
|
|
|
+ wantShow := []string{}
|
|
|
+
|
|
|
+ wantCapture := []string{}
|
|
|
+
|
|
|
+ captureOverride := func(cmd *exec.Cmd) (stdout string, stderr string, err error) {
|
|
|
+ fmt.Println(cmd.Args)
|
|
|
+ if cmd.Args[1] == "--printsrcinfo" {
|
|
|
+ return string(srcinfo), "", nil
|
|
|
+ }
|
|
|
+ return strings.Join(tars, "\n"), "", nil
|
|
|
+ }
|
|
|
+
|
|
|
+ once := sync.Once{}
|
|
|
+
|
|
|
+ showOverride := func(cmd *exec.Cmd) error {
|
|
|
+ once.Do(func() {
|
|
|
+ for _, tar := range tars {
|
|
|
+ f, err := os.OpenFile(tar, os.O_RDONLY|os.O_CREATE, 0o666)
|
|
|
+ require.NoError(t, err)
|
|
|
+ require.NoError(t, f.Close())
|
|
|
+ }
|
|
|
+ })
|
|
|
+ return nil
|
|
|
+ }
|
|
|
+
|
|
|
+ mockRunner := &exe.MockRunner{CaptureFn: captureOverride, ShowFn: showOverride}
|
|
|
+ cmdBuilder := &exe.CmdBuilder{
|
|
|
+ MakepkgBin: makepkgBin,
|
|
|
+ SudoBin: "su",
|
|
|
+ PacmanBin: pacmanBin,
|
|
|
+ PacmanConfigPath: "/etc/pacman.conf",
|
|
|
+ GitBin: "git",
|
|
|
+ Runner: mockRunner,
|
|
|
+ SudoLoopEnabled: false,
|
|
|
+ }
|
|
|
+
|
|
|
+ cmdArgs := parser.MakeArguments()
|
|
|
+ cmdArgs.AddArg("B")
|
|
|
+ cmdArgs.AddArg("i")
|
|
|
+ cmdArgs.AddTarget(targetDir)
|
|
|
+ settings.NoConfirm = true
|
|
|
+ defer func() { settings.NoConfirm = false }()
|
|
|
+ db := &mock.DBExecutor{
|
|
|
+ AlpmArchitecturesFn: func() ([]string, error) {
|
|
|
+ return []string{"x86_64"}, nil
|
|
|
+ },
|
|
|
+ LocalSatisfierExistsFn: func(s string) bool {
|
|
|
+ switch s {
|
|
|
+ case "dotnet-sdk>=6", "dotnet-sdk<7", "dotnet-runtime>=6", "dotnet-runtime<7", "jellyfin-server=10.8.4", "jellyfin-web=10.8.4":
|
|
|
+ return false
|
|
|
+ }
|
|
|
+
|
|
|
+ return true
|
|
|
+ },
|
|
|
+ SyncSatisfierFn: func(s string) mock.IPackage {
|
|
|
+ switch s {
|
|
|
+ case "dotnet-runtime>=6", "dotnet-runtime<7":
|
|
|
+ return &mock.Package{
|
|
|
+ PName: "dotnet-runtime-6.0",
|
|
|
+ PBase: "dotnet-runtime-6.0",
|
|
|
+ PVersion: "6.0.100-1",
|
|
|
+ PDB: mock.NewDB("community"),
|
|
|
+ }
|
|
|
+ case "dotnet-sdk>=6", "dotnet-sdk<7":
|
|
|
+ return &mock.Package{
|
|
|
+ PName: "dotnet-sdk-6.0",
|
|
|
+ PBase: "dotnet-sdk-6.0",
|
|
|
+ PVersion: "6.0.100-1",
|
|
|
+ PDB: mock.NewDB("community"),
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return nil
|
|
|
+ },
|
|
|
+ }
|
|
|
+
|
|
|
+ config := &settings.Configuration{
|
|
|
+ RemoveMake: "no",
|
|
|
+ Runtime: &settings.Runtime{
|
|
|
+ Logger: text.NewLogger(io.Discard, strings.NewReader(""), true, "test"),
|
|
|
+ CmdBuilder: cmdBuilder,
|
|
|
+ VCSStore: &vcs.Mock{},
|
|
|
+ AURCache: &mockaur.MockAUR{
|
|
|
+ GetFn: func(ctx context.Context, query *aur.Query) ([]aur.Pkg, error) {
|
|
|
+ return []aur.Pkg{}, nil
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ }
|
|
|
+
|
|
|
+ err = handleCmd(context.Background(), config, cmdArgs, db)
|
|
|
+ require.ErrorIs(t, err, ErrNoBuildFiles)
|
|
|
+
|
|
|
+ require.Len(t, mockRunner.ShowCalls, len(wantShow))
|
|
|
+ require.Len(t, mockRunner.CaptureCalls, len(wantCapture))
|
|
|
+
|
|
|
+ for i, call := range mockRunner.ShowCalls {
|
|
|
+ show := call.Args[0].(*exec.Cmd).String()
|
|
|
+ show = strings.ReplaceAll(show, tmpDir, "/testdir") // replace the temp dir with a static path
|
|
|
+ show = strings.ReplaceAll(show, makepkgBin, "makepkg")
|
|
|
+ show = strings.ReplaceAll(show, pacmanBin, "pacman")
|
|
|
+ show = strings.ReplaceAll(show, gitBin, "pacman")
|
|
|
+
|
|
|
+ // options are in a different order on different systems and on CI root user is used
|
|
|
+ assert.Subset(t, strings.Split(show, " "), strings.Split(wantShow[i], " "), fmt.Sprintf("%d - %s", i, show))
|
|
|
+ }
|
|
|
+}
|