123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- package download
- import (
- "fmt"
- "io/ioutil"
- "net/http"
- "net/http/httptest"
- "os"
- "path/filepath"
- "testing"
- "github.com/stretchr/testify/assert"
- "github.com/Jguer/yay/v10/pkg/settings/exe"
- )
- func TestGetAURPkgbuild(t *testing.T) {
- pkgBuildHandler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
- w.WriteHeader(200)
- w.Write([]byte(gitExtrasPKGBUILD))
- })
- notFoundHandler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
- w.WriteHeader(404)
- })
- PKGBuild := httptest.NewServer(pkgBuildHandler)
- type args struct {
- handler http.Handler
- pkgName string
- }
- tests := []struct {
- name string
- args args
- want string
- wantErr bool
- }{
- {
- name: "found package",
- args: args{
- handler: pkgBuildHandler,
- pkgName: "git-extras",
- },
- want: gitExtrasPKGBUILD,
- wantErr: false,
- },
- {
- name: "not found package",
- args: args{
- handler: notFoundHandler,
- pkgName: "git-extras",
- },
- want: "",
- wantErr: true,
- },
- }
- for _, tt := range tests {
- t.Run(tt.name, func(t *testing.T) {
- PKGBuild.Config.Handler = tt.args.handler
- got, err := AURPKGBUILD(PKGBuild.Client(), tt.args.pkgName, PKGBuild.URL)
- if tt.wantErr {
- assert.Error(t, err)
- } else {
- assert.NoError(t, err)
- }
- assert.Equal(t, tt.want, string(got))
- })
- }
- }
- // GIVEN no previous existing folder
- // WHEN AURPKGBUILDRepo is called
- // THEN a clone command should be formed
- func TestAURPKGBUILDRepo(t *testing.T) {
- cmdRunner := &testRunner{}
- cmdBuilder := &testGitBuilder{
- index: 0,
- test: t,
- want: "/usr/local/bin/git --no-replace-objects -C /tmp/doesnt-exist clone --no-progress https://aur.archlinux.org/yay-bin.git yay-bin",
- parentBuilder: &exe.CmdBuilder{
- Runner: cmdRunner,
- GitBin: "/usr/local/bin/git",
- GitFlags: []string{"--no-replace-objects"},
- },
- }
- newCloned, err := AURPKGBUILDRepo(cmdBuilder, "https://aur.archlinux.org", "yay-bin", "/tmp/doesnt-exist", false)
- assert.NoError(t, err)
- assert.Equal(t, true, newCloned)
- }
- // GIVEN a previous existing folder with permissions
- // WHEN AURPKGBUILDRepo is called
- // THEN a pull command should be formed
- func TestAURPKGBUILDRepoExistsPerms(t *testing.T) {
- dir, _ := ioutil.TempDir("/tmp/", "yay-test")
- defer os.RemoveAll(dir)
- os.MkdirAll(filepath.Join(dir, "yay-bin", ".git"), 0o777)
- cmdRunner := &testRunner{}
- cmdBuilder := &testGitBuilder{
- index: 0,
- test: t,
- want: fmt.Sprintf("/usr/local/bin/git --no-replace-objects -C %s/yay-bin pull --ff-only", dir),
- parentBuilder: &exe.CmdBuilder{
- Runner: cmdRunner,
- GitBin: "/usr/local/bin/git",
- GitFlags: []string{"--no-replace-objects"},
- },
- }
- cloned, err := AURPKGBUILDRepo(cmdBuilder, "https://aur.archlinux.org", "yay-bin", dir, false)
- assert.NoError(t, err)
- assert.Equal(t, false, cloned)
- }
- // GIVEN
- func TestAURPKGBUILDRepos(t *testing.T) {
- dir, _ := ioutil.TempDir("/tmp/", "yay-test")
- defer os.RemoveAll(dir)
- os.MkdirAll(filepath.Join(dir, "yay-bin", ".git"), 0o777)
- targets := []string{"yay", "yay-bin", "yay-git"}
- cmdRunner := &testRunner{}
- cmdBuilder := &testGitBuilder{
- index: 0,
- test: t,
- want: "",
- parentBuilder: &exe.CmdBuilder{
- Runner: cmdRunner,
- GitBin: "/usr/local/bin/git",
- GitFlags: []string{},
- },
- }
- cloned, err := AURPKGBUILDRepos(cmdBuilder, targets, "https://aur.archlinux.org", dir, false)
- assert.NoError(t, err)
- assert.EqualValues(t, map[string]bool{"yay": true, "yay-bin": false, "yay-git": true}, cloned)
- }
|