1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-03-17 20:47:50 +02:00
This commit is contained in:
Carlos Alexandro Becker 2017-07-23 16:27:46 -03:00
parent 0e6b6451b5
commit 57753af876
No known key found for this signature in database
GPG Key ID: E61E2F7DC14AB940
4 changed files with 68 additions and 53 deletions

View File

@ -0,0 +1,24 @@
// Package testlib contains test helpers for goreleaser tests.
package testlib
import (
"io/ioutil"
"os"
"testing"
"github.com/stretchr/testify/assert"
)
// Mktmp creates a new tempdir, cd into it and provides a back function that
// cd into the previous directory.
func Mktmp(t *testing.T) (folder string, back func()) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
current, err := os.Getwd()
assert.NoError(err)
assert.NoError(os.Chdir(folder))
return folder, func() {
assert.NoError(os.Chdir(current))
}
}

View File

@ -0,0 +1,20 @@
package testlib
import (
"os"
"testing"
"github.com/stretchr/testify/assert"
)
func TestMkTemp(t *testing.T) {
var assert = assert.New(t)
current, err := os.Getwd()
assert.NoError(err)
folder, back := Mktmp(t)
assert.NotEmpty(folder)
back()
newCurrent, err := os.Getwd()
assert.NoError(err)
assert.Equal(current, newCurrent)
}

View File

@ -1,13 +1,13 @@
package archive
import (
"io/ioutil"
"os"
"path/filepath"
"testing"
"github.com/goreleaser/goreleaser/config"
"github.com/goreleaser/goreleaser/context"
"github.com/goreleaser/goreleaser/internal/testlib"
"github.com/stretchr/testify/assert"
)
@ -17,19 +17,13 @@ func TestDescription(t *testing.T) {
func TestRunPipe(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "archivetest")
assert.NoError(err)
current, err := os.Getwd()
assert.NoError(err)
assert.NoError(os.Chdir(folder))
defer func() {
assert.NoError(os.Chdir(current))
}()
folder, back := testlib.Mktmp(t)
defer back()
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(os.Mkdir(filepath.Join(dist, "mybin_darwin_amd64"), 0755))
assert.NoError(os.Mkdir(filepath.Join(dist, "mybin_windows_amd64"), 0755))
_, err = os.Create(filepath.Join(dist, "mybin_darwin_amd64", "mybin"))
_, err := os.Create(filepath.Join(dist, "mybin_darwin_amd64", "mybin"))
assert.NoError(err)
_, err = os.Create(filepath.Join(dist, "mybin_windows_amd64", "mybin.exe"))
assert.NoError(err)
@ -63,19 +57,13 @@ func TestRunPipe(t *testing.T) {
func TestRunPipeBinary(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "archivetest")
assert.NoError(err)
current, err := os.Getwd()
assert.NoError(err)
assert.NoError(os.Chdir(folder))
defer func() {
assert.NoError(os.Chdir(current))
}()
folder, back := testlib.Mktmp(t)
defer back()
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(os.Mkdir(filepath.Join(dist, "mybin_darwin"), 0755))
assert.NoError(os.Mkdir(filepath.Join(dist, "mybin_win"), 0755))
_, err = os.Create(filepath.Join(dist, "mybin_darwin", "mybin"))
_, err := os.Create(filepath.Join(dist, "mybin_darwin", "mybin"))
assert.NoError(err)
_, err = os.Create(filepath.Join(dist, "mybin_win", "mybin.exe"))
assert.NoError(err)
@ -132,14 +120,8 @@ func TestRunPipeInvalidGlob(t *testing.T) {
func TestRunPipeGlobFailsToAdd(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "archivetest")
assert.NoError(err)
current, err := os.Getwd()
assert.NoError(err)
assert.NoError(os.Chdir(folder))
defer func() {
assert.NoError(os.Chdir(current))
}()
folder, back := testlib.Mktmp(t)
defer back()
assert.NoError(os.MkdirAll(filepath.Join(folder, "folder", "another"), 0755))
var ctx = &context.Context{

View File

@ -8,6 +8,7 @@ import (
"github.com/goreleaser/goreleaser/config"
"github.com/goreleaser/goreleaser/context"
"github.com/goreleaser/goreleaser/internal/testlib"
"github.com/goreleaser/goreleaser/pipeline/defaults"
"github.com/stretchr/testify/assert"
)
@ -18,7 +19,7 @@ func TestDescription(t *testing.T) {
func TestNotAGitFolder(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
var ctx = &context.Context{
Config: config.Project{},
@ -28,7 +29,7 @@ func TestNotAGitFolder(t *testing.T) {
func TestSingleCommit(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitCommit(t, "commit1")
@ -42,7 +43,7 @@ func TestSingleCommit(t *testing.T) {
func TestNewRepository(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
var ctx = &context.Context{
@ -53,7 +54,7 @@ func TestNewRepository(t *testing.T) {
func TestNoTagsSnapshot(t *testing.T) {
assert := assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitCommit(t, "first")
@ -72,7 +73,7 @@ func TestNoTagsSnapshot(t *testing.T) {
func TestNoTagsSnapshotInvalidTemplate(t *testing.T) {
assert := assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitCommit(t, "first")
@ -93,7 +94,7 @@ func TestNoTagsSnapshotInvalidTemplate(t *testing.T) {
// to set the --snapshot flag otherwise an error is returned.
func TestNoTagsNoSnapshot(t *testing.T) {
assert := assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitCommit(t, "first")
@ -111,7 +112,7 @@ func TestNoTagsNoSnapshot(t *testing.T) {
func TestInvalidTagFormat(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitCommit(t, "commit2")
@ -126,7 +127,7 @@ func TestInvalidTagFormat(t *testing.T) {
func TestDirty(t *testing.T) {
var assert = assert.New(t)
folder, back := createAndChdir(t)
folder, back := testlib.Mktmp(t)
defer back()
gitInit(t)
dummy, err := os.Create(filepath.Join(folder, "dummy"))
@ -146,7 +147,7 @@ func TestDirty(t *testing.T) {
func TestTagIsNotLastCommit(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitCommit(t, "commit3")
@ -163,7 +164,7 @@ func TestTagIsNotLastCommit(t *testing.T) {
func TestValidState(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitCommit(t, "commit3")
@ -182,7 +183,7 @@ func TestValidState(t *testing.T) {
func TestNoValidate(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitAdd(t)
@ -198,7 +199,7 @@ func TestNoValidate(t *testing.T) {
func TestChangelog(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitCommit(t, "first")
@ -219,7 +220,7 @@ func TestChangelog(t *testing.T) {
func TestChangelogOfFirstRelease(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
var msgs = []string{
@ -245,7 +246,7 @@ func TestChangelogOfFirstRelease(t *testing.T) {
func TestCustomReleaseNotes(t *testing.T) {
var assert = assert.New(t)
_, back := createAndChdir(t)
_, back := testlib.Mktmp(t)
defer back()
gitInit(t)
gitCommit(t, "first")
@ -263,18 +264,6 @@ func TestCustomReleaseNotes(t *testing.T) {
// helper functions
//
func createAndChdir(t *testing.T) (current string, back func()) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
previous, err := os.Getwd()
assert.NoError(err)
assert.NoError(os.Chdir(folder))
return folder, func() {
assert.NoError(os.Chdir(previous))
}
}
func gitInit(t *testing.T) {
var assert = assert.New(t)
out, err := git("init")