mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-22 04:08:49 +02:00
61bead8989
* refactor: improve middleware Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: upload tests Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: twitter tests Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: source tests Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: snapshot tests Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * test: improved some tests Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: snapcraft skip Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip slack Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip sign Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip scoop Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip reddit Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip discord Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip publish Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip nfpm Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip milestone Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip custompublishers Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip checksums Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip changelog Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip brew Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip blob Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip before Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip artifactory Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip announce Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip defaults Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: cmds Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip docker Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * chore: todo Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: go.mod Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip release Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: remove old skip pipe errors Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip teams Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip brew Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix/test: skip smtp Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: lint issues Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip docker Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip brew and scoop Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip docker Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * fix: skip http/artifactory Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * test: increase coverage Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com> * test: fix Signed-off-by: Carlos Alexandro Becker <caarlos0@gmail.com>
731 lines
21 KiB
Go
731 lines
21 KiB
Go
package upload
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
h "net/http"
|
|
"net/http/httptest"
|
|
"os"
|
|
"path/filepath"
|
|
"sync"
|
|
"testing"
|
|
|
|
"github.com/goreleaser/goreleaser/internal/artifact"
|
|
"github.com/goreleaser/goreleaser/internal/pipe"
|
|
"github.com/goreleaser/goreleaser/pkg/config"
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
var (
|
|
// mux is the HTTP request multiplexer used with the test server.
|
|
mux *http.ServeMux
|
|
|
|
// server is a test HTTP server used to provide mock API responses.
|
|
server *httptest.Server
|
|
)
|
|
|
|
func setup() {
|
|
// test server
|
|
mux = http.NewServeMux()
|
|
server = httptest.NewServer(mux)
|
|
}
|
|
|
|
// teardown closes the test HTTP server.
|
|
func teardown() {
|
|
server.Close()
|
|
}
|
|
|
|
func requireMethodPut(t *testing.T, r *http.Request) {
|
|
t.Helper()
|
|
require.Equal(t, http.MethodPut, r.Method)
|
|
}
|
|
|
|
func requireHeader(t *testing.T, r *http.Request, header, want string) {
|
|
t.Helper()
|
|
require.Equal(t, want, r.Header.Get(header))
|
|
}
|
|
|
|
// TODO: improve all tests below by checking wether the mocked handlers
|
|
// were called or not.
|
|
|
|
func TestRunPipe_ModeBinary(t *testing.T) {
|
|
setup()
|
|
defer teardown()
|
|
|
|
folder := t.TempDir()
|
|
dist := filepath.Join(folder, "dist")
|
|
require.NoError(t, os.Mkdir(dist, 0o755))
|
|
require.NoError(t, os.Mkdir(filepath.Join(dist, "mybin"), 0o755))
|
|
binPath := filepath.Join(dist, "mybin", "mybin")
|
|
d1 := []byte("hello\ngo\n")
|
|
require.NoError(t, os.WriteFile(binPath, d1, 0o666))
|
|
|
|
// Dummy http server
|
|
mux.HandleFunc("/example-repo-local/mybin/darwin/amd64/mybin", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
requireHeader(t, r, "Content-Length", "9")
|
|
// Basic auth of user "deployuser" with secret "deployuser-secret"
|
|
requireHeader(t, r, "Authorization", "Basic ZGVwbG95dXNlcjpkZXBsb3l1c2VyLXNlY3JldA==")
|
|
|
|
w.Header().Set("Location", "/production-repo-remote/mybin/linux/amd64/mybin")
|
|
w.WriteHeader(http.StatusCreated)
|
|
})
|
|
mux.HandleFunc("/example-repo-local/mybin/linux/amd64/mybin", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
requireHeader(t, r, "Content-Length", "9")
|
|
// Basic auth of user "deployuser" with secret "deployuser-secret"
|
|
requireHeader(t, r, "Authorization", "Basic ZGVwbG95dXNlcjpkZXBsb3l1c2VyLXNlY3JldA==")
|
|
|
|
w.Header().Set("Location", "/production-repo-remote/mybin/linux/amd64/mybin")
|
|
w.WriteHeader(http.StatusCreated)
|
|
})
|
|
mux.HandleFunc("/production-repo-remote/mybin/darwin/amd64/mybin", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
requireHeader(t, r, "Content-Length", "9")
|
|
// Basic auth of user "productionuser" with secret "productionuser-apikey"
|
|
requireHeader(t, r, "Authorization", "Basic cHJvZHVjdGlvbnVzZXI6cHJvZHVjdGlvbnVzZXItYXBpa2V5")
|
|
|
|
w.Header().Set("Location", "/production-repo-remote/mybin/linux/amd64/mybin")
|
|
w.WriteHeader(http.StatusCreated)
|
|
})
|
|
mux.HandleFunc("/production-repo-remote/mybin/linux/amd64/mybin", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
requireHeader(t, r, "Content-Length", "9")
|
|
// Basic auth of user "productionuser" with secret "productionuser-apikey"
|
|
requireHeader(t, r, "Authorization", "Basic cHJvZHVjdGlvbnVzZXI6cHJvZHVjdGlvbnVzZXItYXBpa2V5")
|
|
|
|
w.Header().Set("Location", "/production-repo-remote/mybin/linux/amd64/mybin")
|
|
w.WriteHeader(http.StatusCreated)
|
|
})
|
|
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "mybin",
|
|
Dist: dist,
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production-us",
|
|
Mode: "binary",
|
|
Target: fmt.Sprintf("%s/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}", server.URL),
|
|
Username: "deployuser",
|
|
},
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production-eu",
|
|
Mode: "binary",
|
|
Target: fmt.Sprintf("%s/production-repo-remote/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}", server.URL),
|
|
Username: "productionuser",
|
|
},
|
|
},
|
|
Archives: []config.Archive{
|
|
{},
|
|
},
|
|
})
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION-US_SECRET": "deployuser-secret",
|
|
"UPLOAD_PRODUCTION-EU_SECRET": "productionuser-apikey",
|
|
}
|
|
for _, goos := range []string{"linux", "darwin"} {
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Name: "mybin",
|
|
Path: binPath,
|
|
Goarch: "amd64",
|
|
Goos: goos,
|
|
Type: artifact.UploadableBinary,
|
|
})
|
|
}
|
|
|
|
require.NoError(t, Pipe{}.Publish(ctx))
|
|
}
|
|
|
|
func TestRunPipe_ModeArchive(t *testing.T) {
|
|
setup()
|
|
defer teardown()
|
|
|
|
folder := t.TempDir()
|
|
tarfile, err := os.Create(filepath.Join(folder, "bin.tar.gz"))
|
|
require.NoError(t, err)
|
|
require.NoError(t, tarfile.Close())
|
|
debfile, err := os.Create(filepath.Join(folder, "bin.deb"))
|
|
require.NoError(t, err)
|
|
require.NoError(t, debfile.Close())
|
|
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "goreleaser",
|
|
Dist: folder,
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Mode: "archive",
|
|
Target: fmt.Sprintf("%s/example-repo-local/{{ .ProjectName }}/{{ .Version }}/", server.URL),
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
Archives: []config.Archive{
|
|
{},
|
|
},
|
|
})
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
}
|
|
ctx.Version = "1.0.0"
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Type: artifact.UploadableArchive,
|
|
Name: "bin.tar.gz",
|
|
Path: tarfile.Name(),
|
|
})
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Type: artifact.LinuxPackage,
|
|
Name: "bin.deb",
|
|
Path: debfile.Name(),
|
|
})
|
|
|
|
var uploads sync.Map
|
|
|
|
// Dummy http server
|
|
mux.HandleFunc("/example-repo-local/goreleaser/1.0.0/bin.tar.gz", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
// Basic auth of user "deployuser" with secret "deployuser-secret"
|
|
requireHeader(t, r, "Authorization", "Basic ZGVwbG95dXNlcjpkZXBsb3l1c2VyLXNlY3JldA==")
|
|
|
|
w.Header().Set("Location", "/example-repo-local/goreleaser/1.0.0/bin.tar.gz")
|
|
w.WriteHeader(http.StatusCreated)
|
|
uploads.Store("targz", true)
|
|
})
|
|
mux.HandleFunc("/example-repo-local/goreleaser/1.0.0/bin.deb", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
// Basic auth of user "deployuser" with secret "deployuser-secret"
|
|
requireHeader(t, r, "Authorization", "Basic ZGVwbG95dXNlcjpkZXBsb3l1c2VyLXNlY3JldA==")
|
|
|
|
w.Header().Set("Location", "/example-repo-local/goreleaser/1.0.0/bin.deb")
|
|
w.WriteHeader(http.StatusCreated)
|
|
uploads.Store("deb", true)
|
|
})
|
|
|
|
require.NoError(t, Pipe{}.Publish(ctx))
|
|
_, ok := uploads.Load("targz")
|
|
require.True(t, ok, "tar.gz file was not uploaded")
|
|
_, ok = uploads.Load("deb")
|
|
require.True(t, ok, "deb file was not uploaded")
|
|
}
|
|
|
|
func TestRunPipe_ModeBinary_CustomArtifactName(t *testing.T) {
|
|
setup()
|
|
defer teardown()
|
|
|
|
folder := t.TempDir()
|
|
dist := filepath.Join(folder, "dist")
|
|
require.NoError(t, os.Mkdir(dist, 0o755))
|
|
require.NoError(t, os.Mkdir(filepath.Join(dist, "mybin"), 0o755))
|
|
binPath := filepath.Join(dist, "mybin", "mybin")
|
|
d1 := []byte("hello\ngo\n")
|
|
require.NoError(t, os.WriteFile(binPath, d1, 0o666))
|
|
|
|
// Dummy http server
|
|
mux.HandleFunc("/example-repo-local/mybin/darwin/amd64/mybin;deb.distribution=xenial", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
requireHeader(t, r, "Content-Length", "9")
|
|
// Basic auth of user "deployuser" with secret "deployuser-secret"
|
|
requireHeader(t, r, "Authorization", "Basic ZGVwbG95dXNlcjpkZXBsb3l1c2VyLXNlY3JldA==")
|
|
|
|
w.Header().Set("Location", "/production-repo-remote/mybin/linux/amd64/mybin;deb.distribution=xenial")
|
|
w.WriteHeader(http.StatusCreated)
|
|
})
|
|
mux.HandleFunc("/example-repo-local/mybin/linux/amd64/mybin;deb.distribution=xenial", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
requireHeader(t, r, "Content-Length", "9")
|
|
// Basic auth of user "deployuser" with secret "deployuser-secret"
|
|
requireHeader(t, r, "Authorization", "Basic ZGVwbG95dXNlcjpkZXBsb3l1c2VyLXNlY3JldA==")
|
|
|
|
w.Header().Set("Location", "/example-repo-local/mybin/linux/amd64/mybin;deb.distribution=xenial")
|
|
w.WriteHeader(http.StatusCreated)
|
|
})
|
|
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "mybin",
|
|
Dist: dist,
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production-us",
|
|
Mode: "binary",
|
|
Target: fmt.Sprintf("%s/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}/{{ .ArtifactName }};deb.distribution=xenial", server.URL),
|
|
Username: "deployuser",
|
|
CustomArtifactName: true,
|
|
},
|
|
},
|
|
Archives: []config.Archive{
|
|
{},
|
|
},
|
|
})
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION-US_SECRET": "deployuser-secret",
|
|
}
|
|
for _, goos := range []string{"linux", "darwin"} {
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Name: "mybin",
|
|
Path: binPath,
|
|
Goarch: "amd64",
|
|
Goos: goos,
|
|
Type: artifact.UploadableBinary,
|
|
})
|
|
}
|
|
|
|
require.NoError(t, Pipe{}.Publish(ctx))
|
|
}
|
|
|
|
func TestRunPipe_ModeArchive_CustomArtifactName(t *testing.T) {
|
|
setup()
|
|
defer teardown()
|
|
|
|
folder := t.TempDir()
|
|
tarfile, err := os.Create(filepath.Join(folder, "bin.tar.gz"))
|
|
require.NoError(t, err)
|
|
require.NoError(t, tarfile.Close())
|
|
debfile, err := os.Create(filepath.Join(folder, "bin.deb"))
|
|
require.NoError(t, err)
|
|
require.NoError(t, debfile.Close())
|
|
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "goreleaser",
|
|
Dist: folder,
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Mode: "archive",
|
|
Target: fmt.Sprintf("%s/example-repo-local/{{ .ProjectName }}/{{ .Version }}/{{ .ArtifactName }};deb.distribution=xenial", server.URL),
|
|
Username: "deployuser",
|
|
CustomArtifactName: true,
|
|
},
|
|
},
|
|
Archives: []config.Archive{
|
|
{},
|
|
},
|
|
})
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
}
|
|
ctx.Version = "1.0.0"
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Type: artifact.UploadableArchive,
|
|
Name: "bin.tar.gz",
|
|
Path: tarfile.Name(),
|
|
})
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Type: artifact.LinuxPackage,
|
|
Name: "bin.deb",
|
|
Path: debfile.Name(),
|
|
})
|
|
|
|
var uploads sync.Map
|
|
|
|
// Dummy http server
|
|
mux.HandleFunc("/example-repo-local/goreleaser/1.0.0/bin.tar.gz;deb.distribution=xenial", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
// Basic auth of user "deployuser" with secret "deployuser-secret"
|
|
requireHeader(t, r, "Authorization", "Basic ZGVwbG95dXNlcjpkZXBsb3l1c2VyLXNlY3JldA==")
|
|
|
|
w.Header().Set("Location", "/example-repo-local/goreleaser/1.0.0/bin.tar.gz;deb.distribution=xenial")
|
|
w.WriteHeader(http.StatusCreated)
|
|
uploads.Store("targz", true)
|
|
})
|
|
mux.HandleFunc("/example-repo-local/goreleaser/1.0.0/bin.deb;deb.distribution=xenial", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
// Basic auth of user "deployuser" with secret "deployuser-secret"
|
|
requireHeader(t, r, "Authorization", "Basic ZGVwbG95dXNlcjpkZXBsb3l1c2VyLXNlY3JldA==")
|
|
|
|
w.Header().Set("Location", "/example-repo-local/goreleaser/1.0.0/bin.deb;deb.distribution=xenial")
|
|
w.WriteHeader(http.StatusCreated)
|
|
uploads.Store("deb", true)
|
|
})
|
|
|
|
require.NoError(t, Pipe{}.Publish(ctx))
|
|
_, ok := uploads.Load("targz")
|
|
require.True(t, ok, "tar.gz file was not uploaded")
|
|
_, ok = uploads.Load("deb")
|
|
require.True(t, ok, "deb file was not uploaded")
|
|
}
|
|
|
|
func TestRunPipe_ArtifactoryDown(t *testing.T) {
|
|
folder := t.TempDir()
|
|
tarfile, err := os.Create(filepath.Join(folder, "bin.tar.gz"))
|
|
require.NoError(t, err)
|
|
require.NoError(t, tarfile.Close())
|
|
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "goreleaser",
|
|
Dist: folder,
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Mode: "archive",
|
|
Target: "http://localhost:1234/example-repo-local/{{ .ProjectName }}/{{ .Version }}/",
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
})
|
|
ctx.Version = "2.0.0"
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
}
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Type: artifact.UploadableArchive,
|
|
Name: "bin.tar.gz",
|
|
Path: tarfile.Name(),
|
|
})
|
|
err = Pipe{}.Publish(ctx)
|
|
require.Error(t, err)
|
|
require.Contains(t, err.Error(), "connection refused")
|
|
}
|
|
|
|
func TestRunPipe_TargetTemplateError(t *testing.T) {
|
|
folder := t.TempDir()
|
|
dist := filepath.Join(folder, "dist")
|
|
binPath := filepath.Join(dist, "mybin", "mybin")
|
|
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "mybin",
|
|
Dist: dist,
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Mode: "binary",
|
|
// This template is not correct and should fail
|
|
Target: "http://storage.company.com/example-repo-local/{{ .ProjectName /{{ .Version }}/",
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
Archives: []config.Archive{
|
|
{},
|
|
},
|
|
})
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
}
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Name: "mybin",
|
|
Path: binPath,
|
|
Goarch: "amd64",
|
|
Goos: "darwin",
|
|
Type: artifact.UploadableBinary,
|
|
})
|
|
err := Pipe{}.Publish(ctx)
|
|
require.Error(t, err)
|
|
require.Contains(t, err.Error(), `upload: error while building the target url: template: tmpl:1: unexpected "/" in operand`)
|
|
}
|
|
|
|
func TestRunPipe_BadCredentials(t *testing.T) {
|
|
setup()
|
|
defer teardown()
|
|
|
|
folder := t.TempDir()
|
|
dist := filepath.Join(folder, "dist")
|
|
require.NoError(t, os.Mkdir(dist, 0o755))
|
|
require.NoError(t, os.Mkdir(filepath.Join(dist, "mybin"), 0o755))
|
|
binPath := filepath.Join(dist, "mybin", "mybin")
|
|
d1 := []byte("hello\ngo\n")
|
|
require.NoError(t, os.WriteFile(binPath, d1, 0o666))
|
|
|
|
// Dummy http server
|
|
mux.HandleFunc("/example-repo-local/mybin/darwin/amd64/mybin", func(w http.ResponseWriter, r *http.Request) {
|
|
requireMethodPut(t, r)
|
|
requireHeader(t, r, "Content-Length", "9")
|
|
// Basic auth of user "deployuser" with secret "deployuser-secret"
|
|
requireHeader(t, r, "Authorization", "Basic ZGVwbG95dXNlcjpkZXBsb3l1c2VyLXNlY3JldA==")
|
|
|
|
w.WriteHeader(http.StatusUnauthorized)
|
|
})
|
|
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "mybin",
|
|
Dist: dist,
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Mode: "binary",
|
|
Target: fmt.Sprintf("%s/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}", server.URL),
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
Archives: []config.Archive{
|
|
{},
|
|
},
|
|
})
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
}
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Name: "mybin",
|
|
Path: binPath,
|
|
Goarch: "amd64",
|
|
Goos: "darwin",
|
|
Type: artifact.UploadableBinary,
|
|
})
|
|
|
|
err := Pipe{}.Publish(ctx)
|
|
require.Error(t, err)
|
|
require.Contains(t, err.Error(), "Unauthorized")
|
|
}
|
|
|
|
func TestRunPipe_FileNotFound(t *testing.T) {
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "mybin",
|
|
Dist: "archivetest/dist",
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Mode: "binary",
|
|
Target: "http://artifacts.company.com/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}",
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
Archives: []config.Archive{
|
|
{},
|
|
},
|
|
})
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
}
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Name: "mybin",
|
|
Path: "archivetest/dist/mybin/mybin",
|
|
Goarch: "amd64",
|
|
Goos: "darwin",
|
|
Type: artifact.UploadableBinary,
|
|
})
|
|
|
|
require.EqualError(t, Pipe{}.Publish(ctx), `open archivetest/dist/mybin/mybin: no such file or directory`)
|
|
}
|
|
|
|
func TestRunPipe_UnparsableTarget(t *testing.T) {
|
|
folder := t.TempDir()
|
|
dist := filepath.Join(folder, "dist")
|
|
require.NoError(t, os.Mkdir(dist, 0o755))
|
|
require.NoError(t, os.Mkdir(filepath.Join(dist, "mybin"), 0o755))
|
|
binPath := filepath.Join(dist, "mybin", "mybin")
|
|
d1 := []byte("hello\ngo\n")
|
|
require.NoError(t, os.WriteFile(binPath, d1, 0o666))
|
|
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "mybin",
|
|
Dist: dist,
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Mode: "binary",
|
|
Target: "://artifacts.company.com/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}",
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
Archives: []config.Archive{
|
|
{},
|
|
},
|
|
})
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
}
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Name: "mybin",
|
|
Path: binPath,
|
|
Goarch: "amd64",
|
|
Goos: "darwin",
|
|
Type: artifact.UploadableBinary,
|
|
})
|
|
|
|
require.EqualError(t, Pipe{}.Publish(ctx), `upload: upload failed: parse "://artifacts.company.com/example-repo-local/mybin/darwin/amd64/mybin": missing protocol scheme`)
|
|
}
|
|
|
|
func TestRunPipe_DirUpload(t *testing.T) {
|
|
folder := t.TempDir()
|
|
dist := filepath.Join(folder, "dist")
|
|
require.NoError(t, os.Mkdir(dist, 0o755))
|
|
require.NoError(t, os.Mkdir(filepath.Join(dist, "mybin"), 0o755))
|
|
binPath := filepath.Join(dist, "mybin")
|
|
|
|
ctx := context.New(config.Project{
|
|
ProjectName: "mybin",
|
|
Dist: dist,
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Mode: "binary",
|
|
Target: "http://artifacts.company.com/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}",
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
Archives: []config.Archive{
|
|
{},
|
|
},
|
|
})
|
|
ctx.Env = map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
}
|
|
ctx.Artifacts.Add(&artifact.Artifact{
|
|
Name: "mybin",
|
|
Path: filepath.Dir(binPath),
|
|
Goarch: "amd64",
|
|
Goos: "darwin",
|
|
Type: artifact.UploadableBinary,
|
|
})
|
|
|
|
require.EqualError(t, Pipe{}.Publish(ctx), `upload: upload failed: the asset to upload can't be a directory`)
|
|
}
|
|
|
|
func TestDescription(t *testing.T) {
|
|
require.NotEmpty(t, Pipe{}.String())
|
|
}
|
|
|
|
func TestPutsWithoutTarget(t *testing.T) {
|
|
ctx := &context.Context{
|
|
Env: map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
},
|
|
Config: config.Project{
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
require.True(t, pipe.IsSkip(Pipe{}.Publish(ctx)))
|
|
}
|
|
|
|
func TestPutsWithoutUsername(t *testing.T) {
|
|
ctx := &context.Context{
|
|
Env: map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
},
|
|
Config: config.Project{
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Target: "http://artifacts.company.com/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}",
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
require.True(t, pipe.IsSkip(Pipe{}.Publish(ctx)))
|
|
}
|
|
|
|
func TestPutsWithoutName(t *testing.T) {
|
|
require.True(t, pipe.IsSkip(Pipe{}.Publish(context.New(config.Project{
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Username: "deployuser",
|
|
Target: "http://artifacts.company.com/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}",
|
|
},
|
|
},
|
|
}))))
|
|
}
|
|
|
|
func TestPutsWithoutSecret(t *testing.T) {
|
|
require.True(t, pipe.IsSkip(Pipe{}.Publish(context.New(config.Project{
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Target: "http://artifacts.company.com/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}",
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
}))))
|
|
}
|
|
|
|
func TestPutsWithInvalidMode(t *testing.T) {
|
|
ctx := &context.Context{
|
|
Env: map[string]string{
|
|
"UPLOAD_PRODUCTION_SECRET": "deployuser-secret",
|
|
},
|
|
Config: config.Project{
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPut,
|
|
Name: "production",
|
|
Mode: "does-not-exists",
|
|
Target: "http://artifacts.company.com/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}",
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
},
|
|
}
|
|
require.Error(t, Pipe{}.Publish(ctx))
|
|
}
|
|
|
|
func TestDefault(t *testing.T) {
|
|
ctx := &context.Context{
|
|
Config: config.Project{
|
|
Uploads: []config.Upload{
|
|
{
|
|
Name: "production",
|
|
Target: "http://artifacts.company.com/example-repo-local/{{ .ProjectName }}/{{ .Os }}/{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}",
|
|
Username: "deployuser",
|
|
},
|
|
},
|
|
},
|
|
}
|
|
require.NoError(t, Pipe{}.Default(ctx))
|
|
require.Len(t, ctx.Config.Uploads, 1)
|
|
upload := ctx.Config.Uploads[0]
|
|
require.Equal(t, "archive", upload.Mode)
|
|
require.Equal(t, h.MethodPut, upload.Method)
|
|
}
|
|
|
|
func TestDefaultNoPuts(t *testing.T) {
|
|
ctx := &context.Context{
|
|
Config: config.Project{
|
|
Uploads: []config.Upload{},
|
|
},
|
|
}
|
|
require.NoError(t, Pipe{}.Default(ctx))
|
|
require.Empty(t, ctx.Config.Uploads)
|
|
}
|
|
|
|
func TestDefaultSet(t *testing.T) {
|
|
ctx := &context.Context{
|
|
Config: config.Project{
|
|
Uploads: []config.Upload{
|
|
{
|
|
Method: h.MethodPost,
|
|
Mode: "custom",
|
|
},
|
|
},
|
|
},
|
|
}
|
|
require.NoError(t, Pipe{}.Default(ctx))
|
|
require.Len(t, ctx.Config.Uploads, 1)
|
|
upload := ctx.Config.Uploads[0]
|
|
require.Equal(t, "custom", upload.Mode)
|
|
require.Equal(t, h.MethodPost, upload.Method)
|
|
}
|
|
|
|
func TestSkip(t *testing.T) {
|
|
t.Run("skip", func(t *testing.T) {
|
|
require.True(t, Pipe{}.Skip(context.New(config.Project{})))
|
|
})
|
|
|
|
t.Run("dont skip", func(t *testing.T) {
|
|
ctx := context.New(config.Project{
|
|
Uploads: []config.Upload{
|
|
{},
|
|
},
|
|
})
|
|
require.False(t, Pipe{}.Skip(ctx))
|
|
})
|
|
}
|