1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-24 04:16:27 +02:00

Merge pull request #371 from goreleaser/lint

Lint on build
This commit is contained in:
Carlos Alexandro Becker 2017-10-01 09:55:23 -03:00 committed by GitHub
commit ef68fce2a8
30 changed files with 361 additions and 483 deletions

View File

@ -13,7 +13,7 @@ install:
- export PATH=/snap/bin:$PATH
- sudo snap install snapcraft --candidate --classic
script:
- make test
- make ci
- test -n "$TRAVIS_TAG" || go run main.go --skip-validate --skip-publish
after_success:
- bash <(curl -s https://codecov.io/bash)

View File

@ -11,31 +11,28 @@ import (
)
func TestChecksums(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var file = filepath.Join(folder, "subject")
assert.NoError(ioutil.WriteFile(file, []byte("lorem ipsum"), 0644))
assert.NoError(t, ioutil.WriteFile(file, []byte("lorem ipsum"), 0644))
sum, err := SHA256(file)
assert.NoError(err)
assert.Equal("5e2bf57d3f40c4b6df69daf1936cb766f832374b4fc0259a7cbff06e2f70f269", sum)
assert.NoError(t, err)
assert.Equal(t, "5e2bf57d3f40c4b6df69daf1936cb766f832374b4fc0259a7cbff06e2f70f269", sum)
}
func TestOpenFailure(t *testing.T) {
var assert = assert.New(t)
sum, err := SHA256("/tmp/this-file-wont-exist-I-hope")
assert.Empty(sum)
assert.Error(err)
assert.Empty(t, sum)
assert.Error(t, err)
}
func TestFileDoesntExist(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var path = filepath.Join(folder, "subject")
file, err := os.Create(path)
assert.NoError(err)
assert.NoError(file.Close())
assert.NoError(t, err)
assert.NoError(t, file.Close())
_, err = doCalculate(sha256.New(), file)
assert.Error(err)
assert.Error(t, err)
}

View File

@ -12,9 +12,8 @@ import (
)
func TestRepo(t *testing.T) {
var assert = assert.New(t)
r := Repo{Owner: "goreleaser", Name: "godownloader"}
assert.Equal("goreleaser/godownloader", r.String(), "not equal")
assert.Equal(t, "goreleaser/godownloader", r.String(), "not equal")
}
func TestLoadReader(t *testing.T) {
@ -22,12 +21,11 @@ func TestLoadReader(t *testing.T) {
fpm:
homepage: http://goreleaser.github.io
`
var assert = assert.New(t)
buf := strings.NewReader(conf)
prop, err := LoadReader(buf)
assert.Nil(err)
assert.Equal("http://goreleaser.github.io", prop.FPM.Homepage, "yaml did not load correctly")
assert.NoError(t, err)
assert.Equal(t, "http://goreleaser.github.io", prop.FPM.Homepage, "yaml did not load correctly")
}
type errorReader struct{}
@ -36,33 +34,28 @@ func (errorReader) Read(p []byte) (n int, err error) {
return 1, fmt.Errorf("error")
}
func TestLoadBadReader(t *testing.T) {
var assert = assert.New(t)
_, err := LoadReader(errorReader{})
assert.Error(err)
assert.Error(t, err)
}
func TestFile(t *testing.T) {
var assert = assert.New(t)
f, err := ioutil.TempFile(os.TempDir(), "config")
assert.NoError(err)
assert.NoError(t, err)
_, err = Load(filepath.Join(f.Name()))
assert.NoError(err)
assert.NoError(t, err)
}
func TestFileNotFound(t *testing.T) {
var assert = assert.New(t)
_, err := Load("/nope/no-way.yml")
assert.Error(err)
assert.Error(t, err)
}
func TestInvalidFields(t *testing.T) {
var assert = assert.New(t)
_, err := Load("testdata/invalid_config.yml")
assert.EqualError(err, "unknown fields in the config file: invalid_root, archive.invalid_archive, archive.format_overrides[0].invalid_archive_fmtoverrides, brew.invalid_brew, brew.github.invalid_brew_github, builds[0].invalid_builds, builds[0].hooks.invalid_builds_hooks, builds[0].ignored_builds[0].invalid_builds_ignore, fpm.invalid_fpm, release.invalid_release, release.github.invalid_release_github, build.invalid_build, builds.hooks.invalid_build_hook, builds.ignored_builds[0].invalid_build_ignore, snapshot.invalid_snapshot, docker[0].invalid_docker")
assert.EqualError(t, err, "unknown fields in the config file: invalid_root, archive.invalid_archive, archive.format_overrides[0].invalid_archive_fmtoverrides, brew.invalid_brew, brew.github.invalid_brew_github, builds[0].invalid_builds, builds[0].hooks.invalid_builds_hooks, builds[0].ignored_builds[0].invalid_builds_ignore, fpm.invalid_fpm, release.invalid_release, release.github.invalid_release_github, build.invalid_build, builds.hooks.invalid_build_hook, builds.ignored_builds[0].invalid_build_ignore, snapshot.invalid_snapshot, docker[0].invalid_docker")
}
func TestInvalidYaml(t *testing.T) {
var assert = assert.New(t)
_, err := Load("testdata/invalid.yml")
assert.EqualError(err, "yaml: line 1: did not find expected node content")
assert.EqualError(t, err, "yaml: line 1: did not find expected node content")
}

View File

@ -9,7 +9,6 @@ import (
)
func TestMultipleAdds(t *testing.T) {
var assert = assert.New(t)
var artifacts = []string{
"dist/a",
"dist/b",
@ -32,7 +31,7 @@ func TestMultipleAdds(t *testing.T) {
return nil
})
}
assert.NoError(g.Wait())
assert.NoError(t, g.Wait())
for _, d := range dockerfiles {
d := d
g.Go(func() error {
@ -40,15 +39,14 @@ func TestMultipleAdds(t *testing.T) {
return nil
})
}
assert.NoError(g.Wait())
assert.Len(ctx.Artifacts, len(artifacts))
assert.Contains(ctx.Artifacts, "a", "b", "c", "d")
assert.Len(ctx.Dockers, len(dockerfiles))
assert.Contains(ctx.Dockers, "a/b:1.0.0", "c/d:2.0.0", "e/f:3.0.0")
assert.NoError(t, g.Wait())
assert.Len(t, ctx.Artifacts, len(artifacts))
assert.Contains(t, ctx.Artifacts, "a", "b", "c", "d")
assert.Len(t, ctx.Dockers, len(dockerfiles))
assert.Contains(t, ctx.Dockers, "a/b:1.0.0", "c/d:2.0.0", "e/f:3.0.0")
}
func TestMultipleBinaryAdds(t *testing.T) {
var assert = assert.New(t)
var list = map[string]string{
"a": "folder/a",
"b": "folder/b",
@ -67,7 +65,7 @@ func TestMultipleBinaryAdds(t *testing.T) {
return nil
})
}
assert.NoError(g.Wait())
assert.Len(ctx.Binaries["linuxamd64"], len(list))
assert.Len(ctx.Binaries, 1)
assert.NoError(t, g.Wait())
assert.Len(t, ctx.Binaries["linuxamd64"], len(list))
assert.Len(t, ctx.Binaries, 1)
}

View File

@ -18,7 +18,6 @@ func init() {
}
func TestRelease(t *testing.T) {
var assert = assert.New(t)
_, back := setup(t)
defer back()
var flags = fakeFlags{
@ -29,11 +28,10 @@ func TestRelease(t *testing.T) {
"parallelism": "4",
},
}
assert.NoError(Release(flags))
assert.NoError(t, Release(flags))
}
func TestSnapshotRelease(t *testing.T) {
var assert = assert.New(t)
_, back := setup(t)
defer back()
var flags = fakeFlags{
@ -42,17 +40,16 @@ func TestSnapshotRelease(t *testing.T) {
"parallelism": "4",
},
}
assert.NoError(Release(flags))
assert.NoError(t, Release(flags))
}
func TestConfigFileIsSetAndDontExist(t *testing.T) {
var assert = assert.New(t)
var flags = fakeFlags{
flags: map[string]string{
"config": "/this/wont/exist",
},
}
assert.Error(Release(flags))
assert.Error(t, Release(flags))
}
func TestConfigFlagNotSetButExists(t *testing.T) {
@ -81,17 +78,15 @@ func TestConfigFlagNotSetButExists(t *testing.T) {
}
func TestReleaseNotesFileDontExist(t *testing.T) {
var assert = assert.New(t)
var flags = fakeFlags{
flags: map[string]string{
"release-notes": "/this/also/wont/exist",
},
}
assert.Error(Release(flags))
assert.Error(t, Release(flags))
}
func TestCustomReleaseNotesFile(t *testing.T) {
var assert = assert.New(t)
folder, back := setup(t)
defer back()
var releaseNotes = filepath.Join(folder, "notes.md")
@ -104,11 +99,10 @@ func TestCustomReleaseNotesFile(t *testing.T) {
"parallelism": "4",
},
}
assert.NoError(Release(flags))
assert.NoError(t, Release(flags))
}
func TestBrokenPipe(t *testing.T) {
var assert = assert.New(t)
_, back := setup(t)
defer back()
createFile(t, "main.go", "not a valid go file")
@ -119,41 +113,38 @@ func TestBrokenPipe(t *testing.T) {
"parallelism": "4",
},
}
assert.Error(Release(flags))
assert.Error(t, Release(flags))
}
func TestInitProject(t *testing.T) {
var assert = assert.New(t)
_, back := setup(t)
defer back()
var filename = "test_goreleaser.yml"
assert.NoError(InitProject(filename))
assert.NoError(t, InitProject(filename))
file, err := os.Open(filename)
assert.NoError(err)
assert.NoError(t, err)
out, err := ioutil.ReadAll(file)
assert.NoError(err)
assert.NoError(t, err)
var config = config.Project{}
assert.NoError(yaml.Unmarshal(out, &config))
assert.NoError(t, yaml.Unmarshal(out, &config))
}
func TestInitProjectFileExist(t *testing.T) {
var assert = assert.New(t)
_, back := setup(t)
defer back()
var filename = "test_goreleaser.yml"
createFile(t, filename, "")
assert.Error(InitProject(filename))
assert.Error(t, InitProject(filename))
}
func TestInitProjectDefaultPipeFails(t *testing.T) {
var assert = assert.New(t)
_, back := setup(t)
defer back()
var filename = "test_goreleaser.yml"
assert.NoError(os.RemoveAll(".git"))
assert.Error(InitProject(filename))
assert.NoError(t, os.RemoveAll(".git"))
assert.Error(t, InitProject(filename))
}
// fakeFlags is a mock of the cli flags
@ -179,12 +170,11 @@ func (f fakeFlags) Bool(s string) bool {
}
func setup(t *testing.T) (current string, back func()) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleaser")
assert.NoError(err)
assert.NoError(t, err)
previous, err := os.Getwd()
assert.NoError(err)
assert.NoError(os.Chdir(folder))
assert.NoError(t, err)
assert.NoError(t, os.Chdir(folder))
createGoreleaserYaml(t)
createMainGo(t)
testlib.GitInit(t)
@ -197,13 +187,12 @@ func setup(t *testing.T) (current string, back func()) {
testlib.GitTag(t, "v0.0.2")
testlib.GitRemoteAdd(t, "git@github.com:goreleaser/fake.git")
return folder, func() {
assert.NoError(os.Chdir(previous))
assert.NoError(t, os.Chdir(previous))
}
}
func createFile(t *testing.T, filename, contents string) {
var assert = assert.New(t)
assert.NoError(ioutil.WriteFile(filename, []byte(contents), 0644))
assert.NoError(t, ioutil.WriteFile(filename, []byte(contents), 0644))
}
func createMainGo(t *testing.T) {

View File

@ -9,7 +9,6 @@ import (
)
func TestFormatFor(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{
Archive: config.Archive{
@ -23,6 +22,6 @@ func TestFormatFor(t *testing.T) {
},
},
}
assert.Equal("zip", For(ctx, "windowsamd64"))
assert.Equal("tar.gz", For(ctx, "linux386"))
assert.Equal(t, "zip", For(ctx, "windowsamd64"))
assert.Equal(t, "tar.gz", For(ctx, "linux386"))
}

View File

@ -7,24 +7,24 @@ import (
)
func TestEnv(t *testing.T) {
var assert = assert.New(t)
assert.Equal(
t,
[]string{"GOOS=linux", "GOARCH=arm64", "GOARM=6"},
New("linux", "arm64", "6").Env(),
)
}
func TestString(t *testing.T) {
var assert = assert.New(t)
assert.Equal(
t,
"linuxarm7",
New("linux", "arm", "7").String(),
)
}
func TestPrettyString(t *testing.T) {
var assert = assert.New(t)
assert.Equal(
t,
"linux/arm646",
New("linux", "arm64", "6").PrettyString(),
)

View File

@ -9,7 +9,6 @@ import (
)
func TestAllBuildTargets(t *testing.T) {
var assert = assert.New(t)
var build = config.Build{
Goos: []string{
"linux",
@ -41,7 +40,7 @@ func TestAllBuildTargets(t *testing.T) {
},
},
}
assert.Equal([]Target{
assert.Equal(t, []Target{
New("linux", "386", ""),
New("linux", "amd64", ""),
New("linux", "arm", "6"),

View File

@ -1,25 +1,21 @@
package git_test
package git
import (
"testing"
"github.com/goreleaser/goreleaser/internal/git"
"github.com/goreleaser/goreleaser/internal/testlib"
"github.com/stretchr/testify/assert"
)
func TestGit(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
out, err := git.Run("init")
assert.NoError(err)
assert.Contains(out, "Initialized empty Git repository")
out, err := Run("status")
assert.NoError(t, err)
assert.NotEmpty(t, out)
out, err = git.Run("command-that-dont-exist")
assert.Error(err)
assert.Empty(out)
out, err = Run("command-that-dont-exist")
assert.Error(t, err)
assert.Empty(t, out)
assert.Equal(
t,
"git: 'command-that-dont-exist' is not a git command. See 'git --help'.\n",
err.Error(),
)

View File

@ -11,8 +11,6 @@ import (
)
func TestChecksums(t *testing.T) {
var assert = assert.New(t)
var config = config.Project{
Checksum: config.Checksum{
NameTemplate: "{{.ProjectName }}_{{.Tag}}_{{.Version}}_checksums.txt",
@ -28,13 +26,11 @@ func TestChecksums(t *testing.T) {
}
name, err := ForChecksums(ctx)
assert.NoError(err)
assert.Equal("testcheck_v1.0.0_1.0.0_checksums.txt", name)
assert.NoError(t, err)
assert.Equal(t, "testcheck_v1.0.0_1.0.0_checksums.txt", name)
}
func TestNameFor(t *testing.T) {
var assert = assert.New(t)
var config = config.Project{
Archive: config.Archive{
NameTemplate: "{{.Binary}}_{{.Os}}_{{.Arch}}_{{.Tag}}_{{.Version}}",
@ -54,13 +50,11 @@ func TestNameFor(t *testing.T) {
}
name, err := For(ctx, buildtarget.New("darwin", "amd64", ""))
assert.NoError(err)
assert.Equal("test_Darwin_x86_64_v1.2.3_1.2.3", name)
assert.NoError(t, err)
assert.Equal(t, "test_Darwin_x86_64_v1.2.3_1.2.3", name)
}
func TestNameForBuild(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{
Archive: config.Archive{
@ -83,12 +77,11 @@ func TestNameForBuild(t *testing.T) {
config.Build{Binary: "foo"},
buildtarget.New("darwin", "amd64", ""),
)
assert.NoError(err)
assert.Equal("foo_Darwin_x86_64_v1.2.3_1.2.3", name)
assert.NoError(t, err)
assert.Equal(t, "foo_Darwin_x86_64_v1.2.3_1.2.3", name)
}
func TestInvalidNameTemplate(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{
Archive: config.Archive{
@ -102,11 +95,10 @@ func TestInvalidNameTemplate(t *testing.T) {
}
_, err := For(ctx, buildtarget.New("darwin", "amd64", ""))
assert.Error(err)
assert.Error(t, err)
}
func TestNameDefaultTemplate(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{
Archive: config.Archive{
@ -123,8 +115,8 @@ func TestNameDefaultTemplate(t *testing.T) {
} {
t.Run(key, func(t *testing.T) {
name, err := For(ctx, target)
assert.NoError(err)
assert.Equal(key, name)
assert.NoError(t, err)
assert.Equal(t, key, name)
})
}
}

View File

@ -9,43 +9,38 @@ import (
// GitInit inits a new git project
func GitInit(t *testing.T) {
var assert = assert.New(t)
out, err := fakeGit("init")
assert.NoError(err)
assert.Contains(out, "Initialized empty Git repository")
assert.NoError(err)
assert.NoError(t, err)
assert.Contains(t, out, "Initialized empty Git repository")
assert.NoError(t, err)
}
// GitRemoteAdd adds the given url as remote
func GitRemoteAdd(t *testing.T, url string) {
var assert = assert.New(t)
out, err := fakeGit("remote", "add", "origin", url)
assert.NoError(err)
assert.Empty(out)
assert.NoError(t, err)
assert.Empty(t, out)
}
// GitCommit creates a git commits
func GitCommit(t *testing.T, msg string) {
var assert = assert.New(t)
out, err := fakeGit("commit", "--allow-empty", "-m", msg)
assert.NoError(err)
assert.Contains(out, "master", msg)
assert.NoError(t, err)
assert.Contains(t, out, "master", msg)
}
// GitTag creates a git tag
func GitTag(t *testing.T, tag string) {
var assert = assert.New(t)
out, err := fakeGit("tag", tag)
assert.NoError(err)
assert.Empty(out)
assert.NoError(t, err)
assert.Empty(t, out)
}
// GitAdd adds all files to stage
func GitAdd(t *testing.T) {
var assert = assert.New(t)
out, err := fakeGit("add", "-A")
assert.NoError(err)
assert.Empty(out)
assert.NoError(t, err)
assert.Empty(t, out)
}
func fakeGit(args ...string) (string, error) {

View File

@ -12,13 +12,12 @@ import (
// 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)
assert.NoError(t, err)
current, err := os.Getwd()
assert.NoError(err)
assert.NoError(os.Chdir(folder))
assert.NoError(t, err)
assert.NoError(t, os.Chdir(folder))
return folder, func() {
assert.NoError(os.Chdir(current))
assert.NoError(t, os.Chdir(current))
}
}

View File

@ -8,13 +8,12 @@ import (
)
func TestMkTemp(t *testing.T) {
var assert = assert.New(t)
current, err := os.Getwd()
assert.NoError(err)
assert.NoError(t, err)
folder, back := Mktmp(t)
assert.NotEmpty(folder)
assert.NotEmpty(t, folder)
back()
newCurrent, err := os.Getwd()
assert.NoError(err)
assert.Equal(current, newCurrent)
assert.NoError(t, err)
assert.Equal(t, current, newCurrent)
}

View File

@ -16,19 +16,18 @@ func TestDescription(t *testing.T) {
}
func TestRunPipe(t *testing.T) {
var assert = assert.New(t)
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))
assert.NoError(t, os.Mkdir(dist, 0755))
assert.NoError(t, os.Mkdir(filepath.Join(dist, "mybin_darwin_amd64"), 0755))
assert.NoError(t, os.Mkdir(filepath.Join(dist, "mybin_windows_amd64"), 0755))
_, err := os.Create(filepath.Join(dist, "mybin_darwin_amd64", "mybin"))
assert.NoError(err)
assert.NoError(t, err)
_, err = os.Create(filepath.Join(dist, "mybin_windows_amd64", "mybin.exe"))
assert.NoError(err)
assert.NoError(t, err)
_, err = os.Create(filepath.Join(folder, "README.md"))
assert.NoError(err)
assert.NoError(t, err)
var ctx = &context.Context{
Config: config.Project{
Dist: dist,
@ -50,25 +49,24 @@ func TestRunPipe(t *testing.T) {
for _, format := range []string{"tar.gz", "zip"} {
t.Run("Archive format "+format, func(t *testing.T) {
ctx.Config.Archive.Format = format
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
})
}
}
func TestRunPipeBinary(t *testing.T) {
var assert = assert.New(t)
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))
assert.NoError(t, os.Mkdir(dist, 0755))
assert.NoError(t, os.Mkdir(filepath.Join(dist, "mybin_darwin"), 0755))
assert.NoError(t, os.Mkdir(filepath.Join(dist, "mybin_win"), 0755))
_, err := os.Create(filepath.Join(dist, "mybin_darwin", "mybin"))
assert.NoError(err)
assert.NoError(t, err)
_, err = os.Create(filepath.Join(dist, "mybin_win", "mybin.exe"))
assert.NoError(err)
assert.NoError(t, err)
_, err = os.Create(filepath.Join(folder, "README.md"))
assert.NoError(err)
assert.NoError(t, err)
var ctx = &context.Context{
Config: config.Project{
Dist: dist,
@ -82,14 +80,13 @@ func TestRunPipeBinary(t *testing.T) {
}
ctx.AddBinary("darwinamd64", "mybin_darwin", "mybin", filepath.Join(dist, "mybin_darwin", "mybin"))
ctx.AddBinary("windowsamd64", "mybin_win", "mybin.exe", filepath.Join(dist, "mybin_win", "mybin.exe"))
assert.NoError(Pipe{}.Run(ctx))
assert.Contains(ctx.Artifacts, "mybin_darwin/mybin")
assert.Contains(ctx.Artifacts, "mybin_win/mybin.exe")
assert.Len(ctx.Artifacts, 2)
assert.NoError(t, Pipe{}.Run(ctx))
assert.Contains(t, ctx.Artifacts, "mybin_darwin/mybin")
assert.Contains(t, ctx.Artifacts, "mybin_win/mybin.exe")
assert.Len(t, ctx.Artifacts, 2)
}
func TestRunPipeDistRemoved(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{
Dist: "/path/nope",
@ -99,11 +96,10 @@ func TestRunPipeDistRemoved(t *testing.T) {
},
}
ctx.AddBinary("windowsamd64", "nope", "no", "blah")
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}
func TestRunPipeInvalidGlob(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{
Dist: "/tmp",
@ -115,14 +111,13 @@ func TestRunPipeInvalidGlob(t *testing.T) {
},
}
ctx.AddBinary("windowsamd64", "whatever", "foo", "bar")
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}
func TestRunPipeGlobFailsToAdd(t *testing.T) {
var assert = assert.New(t)
folder, back := testlib.Mktmp(t)
defer back()
assert.NoError(os.MkdirAll(filepath.Join(folder, "folder", "another"), 0755))
assert.NoError(t, os.MkdirAll(filepath.Join(folder, "folder", "another"), 0755))
var ctx = &context.Context{
Config: config.Project{
@ -135,5 +130,5 @@ func TestRunPipeGlobFailsToAdd(t *testing.T) {
},
}
ctx.AddBinary("windows386", "mybin", "mybin", "dist/mybin")
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}

View File

@ -45,16 +45,14 @@ var defaultTemplateData = templateData{
}
func assertDefaultTemplateData(t *testing.T, formulae string) {
assert := assert.New(t)
assert.Contains(formulae, "class Test < Formula")
assert.Contains(formulae, `homepage "https://google.com"`)
assert.Contains(formulae, `url "https://github.com/caarlos0/test/releases/download/v0.1.3/test_Darwin_x86_64.tar.gz"`)
assert.Contains(formulae, `sha256 "1633f61598ab0791e213135923624eb342196b3494909c91899bcd0560f84c68"`)
assert.Contains(formulae, `version "0.1.3"`)
assert.Contains(t, formulae, "class Test < Formula")
assert.Contains(t, formulae, `homepage "https://google.com"`)
assert.Contains(t, formulae, `url "https://github.com/caarlos0/test/releases/download/v0.1.3/test_Darwin_x86_64.tar.gz"`)
assert.Contains(t, formulae, `sha256 "1633f61598ab0791e213135923624eb342196b3494909c91899bcd0560f84c68"`)
assert.Contains(t, formulae, `version "0.1.3"`)
}
func TestFullFormulae(t *testing.T) {
assert := assert.New(t)
data := defaultTemplateData
data.Caveats = "Here are some caveats"
data.Dependencies = []string{"gtk+"}
@ -63,37 +61,34 @@ func TestFullFormulae(t *testing.T) {
data.Install = []string{"custom install script", "another install script"}
data.Tests = []string{`system "#{bin}/foo -version"`}
out, err := doBuildFormula(data)
assert.NoError(err)
assert.NoError(t, err)
formulae := out.String()
bts, err := ioutil.ReadFile("testdata/test.rb")
assert.NoError(err)
assert.NoError(t, err)
// ioutil.WriteFile("testdata/test.rb", []byte(formulae), 0644)
assert.Equal(string(bts), formulae)
assert.Equal(t, string(bts), formulae)
}
func TestFormulaeSimple(t *testing.T) {
assert := assert.New(t)
out, err := doBuildFormula(defaultTemplateData)
assert.NoError(err)
assert.NoError(t, err)
formulae := out.String()
assertDefaultTemplateData(t, formulae)
assert.NotContains(formulae, "def caveats")
assert.NotContains(formulae, "depends_on")
assert.NotContains(formulae, "def plist;")
assert.NotContains(t, formulae, "def caveats")
assert.NotContains(t, formulae, "depends_on")
assert.NotContains(t, formulae, "def plist;")
}
func TestSplit(t *testing.T) {
var assert = assert.New(t)
var parts = split("system \"true\"\nsystem \"#{bin}/foo -h\"")
assert.Equal([]string{"system \"true\"", "system \"#{bin}/foo -h\""}, parts)
assert.Equal(t, []string{"system \"true\"", "system \"#{bin}/foo -h\""}, parts)
}
func TestRunPipe(t *testing.T) {
assert := assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var ctx = &context.Context{
Git: context.GitInfo{
CurrentTag: "v1.0.1",
@ -131,27 +126,27 @@ func TestRunPipe(t *testing.T) {
var path = filepath.Join(folder, "bin.tar.gz")
ctx.AddBinary("darwinamd64", "bin", "bin", path)
client := &DummyClient{}
assert.Error(doRun(ctx, client))
assert.False(client.CreatedFile)
assert.Error(t, doRun(ctx, client))
assert.False(t, client.CreatedFile)
_, err = os.Create(path)
assert.NoError(err)
assert.NoError(doRun(ctx, client))
assert.True(client.CreatedFile)
assert.NoError(t, err)
assert.NoError(t, doRun(ctx, client))
assert.True(t, client.CreatedFile)
bts, err := ioutil.ReadFile("testdata/run_pipe.rb")
assert.NoError(err)
assert.NoError(t, err)
// assert.NoError(ioutil.WriteFile("testdata/run_pipe.rb", []byte(client.Content), 0644))
assert.Equal(string(bts), client.Content)
assert.Equal(t, string(bts), client.Content)
}
func TestRunPipeFormatOverride(t *testing.T) {
assert := assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var path = filepath.Join(folder, "bin.zip")
_, err = os.Create(path)
assert.NoError(err)
assert.NoError(t, err)
var ctx = &context.Context{
Config: config.Project{
Dist: folder,
@ -175,13 +170,12 @@ func TestRunPipeFormatOverride(t *testing.T) {
}
ctx.AddBinary("darwinamd64", "bin", "bin", path)
client := &DummyClient{}
assert.NoError(doRun(ctx, client))
assert.True(client.CreatedFile)
assert.Contains(client.Content, "bin.zip")
assert.NoError(t, doRun(ctx, client))
assert.True(t, client.CreatedFile)
assert.Contains(t, client.Content, "bin.zip")
}
func TestRunPipeNoDarwin64Build(t *testing.T) {
assert := assert.New(t)
var ctx = &context.Context{
Config: config.Project{
Archive: config.Archive{
@ -197,23 +191,21 @@ func TestRunPipeNoDarwin64Build(t *testing.T) {
Publish: true,
}
client := &DummyClient{}
assert.Equal(ErrNoDarwin64Build, doRun(ctx, client))
assert.False(client.CreatedFile)
assert.Equal(t, ErrNoDarwin64Build, doRun(ctx, client))
assert.False(t, client.CreatedFile)
}
func TestRunPipeBrewNotSetup(t *testing.T) {
assert := assert.New(t)
var ctx = &context.Context{
Config: config.Project{},
Publish: true,
}
client := &DummyClient{}
testlib.AssertSkipped(t, doRun(ctx, client))
assert.False(client.CreatedFile)
assert.False(t, client.CreatedFile)
}
func TestRunPipeBinaryRelease(t *testing.T) {
assert := assert.New(t)
var ctx = &context.Context{
Publish: true,
Config: config.Project{
@ -231,21 +223,19 @@ func TestRunPipeBinaryRelease(t *testing.T) {
ctx.AddBinary("darwinamd64", "foo", "bar", "baz")
client := &DummyClient{}
testlib.AssertSkipped(t, doRun(ctx, client))
assert.False(client.CreatedFile)
assert.False(t, client.CreatedFile)
}
func TestRunPipeNoPublish(t *testing.T) {
assert := assert.New(t)
var ctx = &context.Context{
Publish: false,
}
client := &DummyClient{}
testlib.AssertSkipped(t, doRun(ctx, client))
assert.False(client.CreatedFile)
assert.False(t, client.CreatedFile)
}
func TestRunPipeDraftRelease(t *testing.T) {
assert := assert.New(t)
var ctx = &context.Context{
Publish: true,
Config: config.Project{
@ -262,11 +252,10 @@ func TestRunPipeDraftRelease(t *testing.T) {
}
client := &DummyClient{}
testlib.AssertSkipped(t, doRun(ctx, client))
assert.False(client.CreatedFile)
assert.False(t, client.CreatedFile)
}
func TestRunPipeFormatBinary(t *testing.T) {
assert := assert.New(t)
var ctx = &context.Context{
Config: config.Project{
Archive: config.Archive{
@ -276,7 +265,7 @@ func TestRunPipeFormatBinary(t *testing.T) {
}
client := &DummyClient{}
testlib.AssertSkipped(t, doRun(ctx, client))
assert.False(client.CreatedFile)
assert.False(t, client.CreatedFile)
}
type DummyClient struct {

View File

@ -28,7 +28,6 @@ func TestRunInvalidCommand(t *testing.T) {
}
func TestBuild(t *testing.T) {
assert := assert.New(t)
var config = config.Project{
Builds: []config.Build{
{
@ -39,13 +38,12 @@ func TestBuild(t *testing.T) {
},
}
var ctx = context.New(config)
assert.NoError(doBuild(ctx, ctx.Config.Builds[0], buildtarget.Runtime))
assert.NoError(t, doBuild(ctx, ctx.Config.Builds[0], buildtarget.Runtime))
}
func TestRunFullPipe(t *testing.T) {
assert := assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var binary = filepath.Join(folder, "testing")
var pre = filepath.Join(folder, "pre")
var post = filepath.Join(folder, "post")
@ -69,16 +67,15 @@ func TestRunFullPipe(t *testing.T) {
},
},
}
assert.NoError(Pipe{}.Run(context.New(config)))
assert.True(exists(binary), binary)
assert.True(exists(pre), pre)
assert.True(exists(post), post)
assert.NoError(t, Pipe{}.Run(context.New(config)))
assert.True(t, exists(binary), binary)
assert.True(t, exists(pre), pre)
assert.True(t, exists(post), post)
}
func TestRunPipeFormatBinary(t *testing.T) {
assert := assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var binary = filepath.Join(folder, "binary-testing")
var config = config.Project{
ProjectName: "testing",
@ -99,14 +96,13 @@ func TestRunPipeFormatBinary(t *testing.T) {
NameTemplate: "binary-{{.Binary}}",
},
}
assert.NoError(Pipe{}.Run(context.New(config)))
assert.True(exists(binary))
assert.NoError(t, Pipe{}.Run(context.New(config)))
assert.True(t, exists(binary))
}
func TestRunPipeArmBuilds(t *testing.T) {
assert := assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var binary = filepath.Join(folder, "armtesting")
var config = config.Project{
Dist: folder,
@ -128,12 +124,11 @@ func TestRunPipeArmBuilds(t *testing.T) {
},
},
}
assert.NoError(Pipe{}.Run(context.New(config)))
assert.True(exists(binary), binary)
assert.NoError(t, Pipe{}.Run(context.New(config)))
assert.True(t, exists(binary), binary)
}
func TestBuildFailed(t *testing.T) {
assert := assert.New(t)
var config = config.Project{
Builds: []config.Build{
{
@ -147,11 +142,10 @@ func TestBuildFailed(t *testing.T) {
},
},
}
assert.Error(Pipe{}.Run(context.New(config)))
assert.Error(t, Pipe{}.Run(context.New(config)))
}
func TestRunPipeWithInvalidOS(t *testing.T) {
assert := assert.New(t)
var config = config.Project{
Builds: []config.Build{
{
@ -165,11 +159,10 @@ func TestRunPipeWithInvalidOS(t *testing.T) {
},
},
}
assert.NoError(Pipe{}.Run(context.New(config)))
assert.NoError(t, Pipe{}.Run(context.New(config)))
}
func TestRunInvalidNametemplate(t *testing.T) {
var assert = assert.New(t)
for _, format := range []string{"tar.gz", "zip", "binary"} {
var config = config.Project{
ProjectName: "nameeeee",
@ -190,12 +183,11 @@ func TestRunInvalidNametemplate(t *testing.T) {
NameTemplate: "{{.Binary}",
},
}
assert.Error(Pipe{}.Run(context.New(config)))
assert.Error(t, Pipe{}.Run(context.New(config)))
}
}
func TestRunInvalidLdflags(t *testing.T) {
var assert = assert.New(t)
var config = config.Project{
Builds: []config.Build{
{
@ -211,11 +203,10 @@ func TestRunInvalidLdflags(t *testing.T) {
},
},
}
assert.Error(Pipe{}.Run(context.New(config)))
assert.Error(t, Pipe{}.Run(context.New(config)))
}
func TestRunPipeFailingHooks(t *testing.T) {
assert := assert.New(t)
var config = config.Project{
Builds: []config.Build{
{
@ -232,11 +223,11 @@ func TestRunPipeFailingHooks(t *testing.T) {
var ctx = context.New(config)
t.Run("pre-hook", func(t *testing.T) {
ctx.Config.Builds[0].Hooks.Pre = "exit 1"
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
})
t.Run("post-hook", func(t *testing.T) {
ctx.Config.Builds[0].Hooks.Post = "exit 1"
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
})
}

View File

@ -9,7 +9,6 @@ import (
)
func TestLdFlagsFullTemplate(t *testing.T) {
assert := assert.New(t)
var config = config.Project{
Builds: []config.Build{
{
@ -26,16 +25,15 @@ func TestLdFlagsFullTemplate(t *testing.T) {
Config: config,
}
flags, err := ldflags(ctx, ctx.Config.Builds[0])
assert.NoError(err)
assert.Contains(flags, "-s -w")
assert.Contains(flags, "-X main.version=1.2.3")
assert.Contains(flags, "-X main.tag=v1.2.3")
assert.Contains(flags, "-X main.commit=123")
assert.Contains(flags, "-X main.date=")
assert.NoError(t, err)
assert.Contains(t, flags, "-s -w")
assert.Contains(t, flags, "-X main.version=1.2.3")
assert.Contains(t, flags, "-X main.tag=v1.2.3")
assert.Contains(t, flags, "-X main.commit=123")
assert.Contains(t, flags, "-X main.date=")
}
func TestInvalidTemplate(t *testing.T) {
assert := assert.New(t)
var config = config.Project{
Builds: []config.Build{
{Ldflags: "{invalid{.Template}}}{{}}}"},
@ -45,6 +43,6 @@ func TestInvalidTemplate(t *testing.T) {
Config: config,
}
flags, err := ldflags(ctx, ctx.Config.Builds[0])
assert.Error(err)
assert.Equal(flags, "")
assert.Error(t, err)
assert.Equal(t, flags, "")
}

View File

@ -15,13 +15,12 @@ func TestDescription(t *testing.T) {
}
func TestPipe(t *testing.T) {
var assert = assert.New(t)
var binary = "binary"
var checksums = binary + "_checksums.txt"
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var file = filepath.Join(folder, binary)
assert.NoError(ioutil.WriteFile(file, []byte("some string"), 0644))
assert.NoError(t, ioutil.WriteFile(file, []byte("some string"), 0644))
var ctx = &context.Context{
Config: config.Project{
Dist: folder,
@ -32,17 +31,16 @@ func TestPipe(t *testing.T) {
},
}
ctx.AddArtifact(file)
assert.NoError(Pipe{}.Run(ctx))
assert.Contains(ctx.Artifacts, checksums, binary)
assert.NoError(t, Pipe{}.Run(ctx))
assert.Contains(t, ctx.Artifacts, checksums, binary)
bts, err := ioutil.ReadFile(filepath.Join(folder, checksums))
assert.NoError(err)
assert.Equal(string(bts), "61d034473102d7dac305902770471fd50f4c5b26f6831a56dd90b5184b3c30fc binary\n")
assert.NoError(t, err)
assert.Equal(t, string(bts), "61d034473102d7dac305902770471fd50f4c5b26f6831a56dd90b5184b3c30fc binary\n")
}
func TestPipeFileNotExist(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var ctx = &context.Context{
Config: config.Project{
Dist: folder,
@ -53,14 +51,13 @@ func TestPipeFileNotExist(t *testing.T) {
}
ctx.AddArtifact("nope")
err = Pipe{}.Run(ctx)
assert.Error(err)
assert.Contains(err.Error(), "/nope: no such file or directory")
assert.Error(t, err)
assert.Contains(t, err.Error(), "/nope: no such file or directory")
}
func TestPipeInvalidNameTemplate(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var ctx = &context.Context{
Config: config.Project{
Dist: folder,
@ -72,16 +69,15 @@ func TestPipeInvalidNameTemplate(t *testing.T) {
}
ctx.AddArtifact("whatever")
err = Pipe{}.Run(ctx)
assert.Error(err)
assert.Equal(`template: name:1: unexpected "}" in operand`, err.Error())
assert.Error(t, err)
assert.Equal(t, `template: name:1: unexpected "}" in operand`, err.Error())
}
func TestPipeCouldNotOpenChecksumsTxt(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
var file = filepath.Join(folder, "checksums.txt")
assert.NoError(ioutil.WriteFile(file, []byte("some string"), 0000))
assert.NoError(t, ioutil.WriteFile(file, []byte("some string"), 0000))
var ctx = &context.Context{
Config: config.Project{
Dist: folder,
@ -92,6 +88,6 @@ func TestPipeCouldNotOpenChecksumsTxt(t *testing.T) {
}
ctx.AddArtifact("nope")
err = Pipe{}.Run(ctx)
assert.Error(err)
assert.Contains(err.Error(), "/checksums.txt: permission denied")
assert.Error(t, err)
assert.Contains(t, err.Error(), "/checksums.txt: permission denied")
}

View File

@ -12,8 +12,8 @@ import (
)
func TestDistDoesNotExist(t *testing.T) {
var assert = assert.New(t)
assert.NoError(
t,
Pipe{}.Run(
&context.Context{
Config: config.Project{
@ -25,42 +25,39 @@ func TestDistDoesNotExist(t *testing.T) {
}
func TestPopulatedDistExists(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "disttest")
assert.NoError(err)
assert.NoError(t, err)
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(t, os.Mkdir(dist, 0755))
_, err = os.Create(filepath.Join(dist, "mybin"))
assert.NoError(err)
assert.NoError(t, err)
var ctx = &context.Context{
Config: config.Project{
Dist: dist,
},
}
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
ctx.RmDist = true
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
_, err = os.Stat(dist)
assert.False(os.IsExist(err))
assert.False(t, os.IsExist(err))
}
func TestEmptyDistExists(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "disttest")
assert.NoError(err)
assert.NoError(t, err)
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(t, os.Mkdir(dist, 0755))
var ctx = &context.Context{
Config: config.Project{
Dist: dist,
},
}
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
_, err = os.Stat(dist)
assert.False(os.IsExist(err))
assert.False(t, os.IsExist(err))
}
func TestDescription(t *testing.T) {
var assert = assert.New(t)
assert.NotEmpty(Pipe{}.Description())
assert.NotEmpty(t, Pipe{}.Description())
}

View File

@ -15,27 +15,27 @@ func TestDescription(t *testing.T) {
}
func TestFillBasicData(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{},
}
assert.NoError(Pipe{}.Run(ctx))
assert.Equal("goreleaser", ctx.Config.Release.GitHub.Owner)
assert.Equal("goreleaser", ctx.Config.Release.GitHub.Name)
assert.NotEmpty(ctx.Config.Builds)
assert.Equal("goreleaser", ctx.Config.Builds[0].Binary)
assert.Equal(".", ctx.Config.Builds[0].Main)
assert.Contains(ctx.Config.Builds[0].Goos, "darwin")
assert.Contains(ctx.Config.Builds[0].Goos, "linux")
assert.Contains(ctx.Config.Builds[0].Goarch, "386")
assert.Contains(ctx.Config.Builds[0].Goarch, "amd64")
assert.Equal("tar.gz", ctx.Config.Archive.Format)
assert.Contains(ctx.Config.Brew.Install, "bin.install \"goreleaser\"")
assert.Contains(ctx.Config.Brew.CommitAuthor.Name, "goreleaserbot")
assert.Contains(ctx.Config.Brew.CommitAuthor.Email, "goreleaser@carlosbecker.com")
assert.Empty(ctx.Config.Dockers)
assert.NoError(t, Pipe{}.Run(ctx))
assert.Equal(t, "goreleaser", ctx.Config.Release.GitHub.Owner)
assert.Equal(t, "goreleaser", ctx.Config.Release.GitHub.Name)
assert.NotEmpty(t, ctx.Config.Builds)
assert.Equal(t, "goreleaser", ctx.Config.Builds[0].Binary)
assert.Equal(t, ".", ctx.Config.Builds[0].Main)
assert.Contains(t, ctx.Config.Builds[0].Goos, "darwin")
assert.Contains(t, ctx.Config.Builds[0].Goos, "linux")
assert.Contains(t, ctx.Config.Builds[0].Goarch, "386")
assert.Contains(t, ctx.Config.Builds[0].Goarch, "amd64")
assert.Equal(t, "tar.gz", ctx.Config.Archive.Format)
assert.Contains(t, ctx.Config.Brew.Install, "bin.install \"goreleaser\"")
assert.Empty(t, ctx.Config.Dockers)
assert.Equal(t, ctx.Config.Brew.CommitAuthor.Name, "goreleaserbot")
assert.Equal(t, ctx.Config.Brew.CommitAuthor.Email, "goreleaser@carlosbecker.com")
assert.NotEmpty(
t,
ctx.Config.Archive.NameTemplate,
ctx.Config.Builds[0].Ldflags,
ctx.Config.Archive.Files,
@ -43,7 +43,6 @@ func TestFillBasicData(t *testing.T) {
}
func TestFillPartial(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{
@ -73,18 +72,17 @@ func TestFillPartial(t *testing.T) {
},
},
}
assert.NoError(Pipe{}.Run(ctx))
assert.Len(ctx.Config.Archive.Files, 1)
assert.Equal(`bin.install "testreleaser"`, ctx.Config.Brew.Install)
assert.NotEmpty(ctx.Config.Dockers[0].Binary)
assert.NotEmpty(ctx.Config.Dockers[0].Goos)
assert.NotEmpty(ctx.Config.Dockers[0].Goarch)
assert.NotEmpty(ctx.Config.Dockers[0].Dockerfile)
assert.Empty(ctx.Config.Dockers[0].Goarm)
assert.NoError(t, Pipe{}.Run(ctx))
assert.Len(t, ctx.Config.Archive.Files, 1)
assert.Equal(t, `bin.install "testreleaser"`, ctx.Config.Brew.Install)
assert.NotEmpty(t, ctx.Config.Dockers[0].Binary)
assert.NotEmpty(t, ctx.Config.Dockers[0].Goos)
assert.NotEmpty(t, ctx.Config.Dockers[0].Goarch)
assert.NotEmpty(t, ctx.Config.Dockers[0].Dockerfile)
assert.Empty(t, ctx.Config.Dockers[0].Goarm)
}
func TestFillSingleBuild(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{
@ -93,23 +91,22 @@ func TestFillSingleBuild(t *testing.T) {
},
},
}
assert.NoError(Pipe{}.Run(ctx))
assert.Len(ctx.Config.Builds, 1)
assert.Equal(ctx.Config.Builds[0].Binary, "goreleaser")
assert.NoError(t, Pipe{}.Run(ctx))
assert.Len(t, ctx.Config.Builds, 1)
assert.Equal(t, ctx.Config.Builds[0].Binary, "goreleaser")
}
func TestNotAGitRepo(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
previous, err := os.Getwd()
assert.NoError(err)
assert.NoError(os.Chdir(folder))
assert.NoError(t, err)
assert.NoError(t, os.Chdir(folder))
defer func() {
assert.NoError(os.Chdir(previous))
assert.NoError(t, os.Chdir(previous))
}()
var ctx = &context.Context{
Config: config.Project{},
}
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}

View File

@ -7,20 +7,17 @@ import (
)
func TestRepoName(t *testing.T) {
var assert = assert.New(t)
repo, err := remoteRepo()
assert.NoError(err)
assert.Equal("goreleaser/goreleaser", repo.String())
assert.NoError(t, err)
assert.Equal(t, "goreleaser/goreleaser", repo.String())
}
func TestExtractReporFromGitURL(t *testing.T) {
var assert = assert.New(t)
repo := extractRepoFromURL("git@github.com:goreleaser/goreleaser.git")
assert.Equal("goreleaser/goreleaser", repo.String())
assert.Equal(t, "goreleaser/goreleaser", repo.String())
}
func TestExtractReporFromHttpsURL(t *testing.T) {
var assert = assert.New(t)
repo := extractRepoFromURL("https://github.com/goreleaser/goreleaser.git")
assert.Equal("goreleaser/goreleaser", repo.String())
assert.Equal(t, "goreleaser/goreleaser", repo.String())
}

View File

@ -85,6 +85,10 @@ func process(ctx *context.Context, folder string, docker config.Docker, binary c
}
}
return publish(ctx, docker, image, latest)
}
func publish(ctx *context.Context, docker config.Docker, image, latest string) error {
// TODO: improve this so it can log it to stdout
if !ctx.Publish {
return pipeline.Skip("--skip-publish is set")

View File

@ -15,15 +15,14 @@ import (
)
func TestRunPipe(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "archivetest")
assert.NoError(err)
assert.NoError(t, err)
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(os.Mkdir(filepath.Join(dist, "mybin"), 0755))
assert.NoError(t, os.Mkdir(dist, 0755))
assert.NoError(t, os.Mkdir(filepath.Join(dist, "mybin"), 0755))
var binPath = filepath.Join(dist, "mybin", "mybin")
_, err = os.Create(binPath)
assert.NoError(err)
assert.NoError(t, err)
var images = []string{
"goreleaser/test_run_pipe:1.0.0",
"goreleaser/test_run_pipe:latest",
@ -60,34 +59,31 @@ func TestRunPipe(t *testing.T) {
for _, plat := range []string{"linuxamd64", "linux386", "darwinamd64"} {
ctx.AddBinary(plat, "mybin", "mybin", binPath)
}
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
// this might should not fail as the image should have been created when
// the step ran
for _, img := range images {
assert.NoError(exec.Command("docker", "rmi", img).Run())
assert.NoError(t, exec.Command("docker", "rmi", img).Run())
}
// the test_run_pipe_nope image should not have been created, so deleting
// it should fail
assert.Error(
assert.Error(t,
exec.Command("docker", "rmi", "goreleaser/test_run_pipe_nope:1.0.0").Run(),
)
}
func TestDescription(t *testing.T) {
var assert = assert.New(t)
assert.NotEmpty(Pipe{}.Description())
assert.NotEmpty(t, Pipe{}.Description())
}
func TestNoDockers(t *testing.T) {
var assert = assert.New(t)
assert.True(pipeline.IsSkip(Pipe{}.Run(context.New(config.Project{}))))
assert.True(t, pipeline.IsSkip(Pipe{}.Run(context.New(config.Project{}))))
}
func TestNoDockerWithoutImageName(t *testing.T) {
var assert = assert.New(t)
assert.True(pipeline.IsSkip(Pipe{}.Run(context.New(config.Project{
assert.True(t, pipeline.IsSkip(Pipe{}.Run(context.New(config.Project{
Dockers: []config.Docker{
{
Goos: "linux",
@ -97,12 +93,11 @@ func TestNoDockerWithoutImageName(t *testing.T) {
}
func TestDockerNotInPath(t *testing.T) {
var assert = assert.New(t)
var path = os.Getenv("PATH")
defer func() {
assert.NoError(os.Setenv("PATH", path))
assert.NoError(t, os.Setenv("PATH", path))
}()
assert.NoError(os.Setenv("PATH", ""))
assert.NoError(t, os.Setenv("PATH", ""))
var ctx = &context.Context{
Version: "1.0.0",
Config: config.Project{
@ -113,5 +108,5 @@ func TestDockerNotInPath(t *testing.T) {
},
},
}
assert.EqualError(Pipe{}.Run(ctx), ErrNoDocker.Error())
assert.EqualError(t, Pipe{}.Run(ctx), ErrNoDocker.Error())
}

View File

@ -16,25 +16,23 @@ func TestDescription(t *testing.T) {
}
func TestValidEnv(t *testing.T) {
assert := assert.New(t)
assert.NoError(os.Setenv("GITHUB_TOKEN", "asdf"))
assert.NoError(t, os.Setenv("GITHUB_TOKEN", "asdf"))
var ctx = &context.Context{
Config: config.Project{},
Validate: true,
Publish: true,
}
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
}
func TestInvalidEnv(t *testing.T) {
assert := assert.New(t)
assert.NoError(os.Unsetenv("GITHUB_TOKEN"))
assert.NoError(t, os.Unsetenv("GITHUB_TOKEN"))
var ctx = &context.Context{
Config: config.Project{},
Validate: true,
Publish: true,
}
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}
type flags struct {
@ -54,8 +52,7 @@ func TestInvalidEnvChecksSkipped(t *testing.T) {
},
} {
t.Run(fmt.Sprintf("%v", flag), func(t *testing.T) {
var assert = assert.New(t)
assert.NoError(os.Unsetenv("GITHUB_TOKEN"))
assert.NoError(t, os.Unsetenv("GITHUB_TOKEN"))
var ctx = &context.Context{
Config: config.Project{},
Validate: flag.Validate,

View File

@ -25,15 +25,14 @@ func TestRunPipeNoFormats(t *testing.T) {
}
func TestRunPipe(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "archivetest")
assert.NoError(err)
assert.NoError(t, err)
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(os.Mkdir(filepath.Join(dist, "mybin"), 0755))
assert.NoError(t, os.Mkdir(dist, 0755))
assert.NoError(t, os.Mkdir(filepath.Join(dist, "mybin"), 0755))
var binPath = filepath.Join(dist, "mybin", "mybin")
_, err = os.Create(binPath)
assert.NoError(err)
assert.NoError(t, err)
var ctx = &context.Context{
Version: "1.0.0",
Config: config.Project{
@ -54,16 +53,15 @@ func TestRunPipe(t *testing.T) {
for _, plat := range []string{"linuxamd64", "linux386", "darwinamd64"} {
ctx.AddBinary(plat, "mybin", "mybin", binPath)
}
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
}
func TestNoFPMInPath(t *testing.T) {
var assert = assert.New(t)
var path = os.Getenv("PATH")
defer func() {
assert.NoError(os.Setenv("PATH", path))
assert.NoError(t, os.Setenv("PATH", path))
}()
assert.NoError(os.Setenv("PATH", ""))
assert.NoError(t, os.Setenv("PATH", ""))
var ctx = &context.Context{
Version: "1.0.0",
Config: config.Project{
@ -72,16 +70,15 @@ func TestNoFPMInPath(t *testing.T) {
},
},
}
assert.EqualError(Pipe{}.Run(ctx), ErrNoFPM.Error())
assert.EqualError(t, Pipe{}.Run(ctx), ErrNoFPM.Error())
}
func TestCreateFileDoesntExist(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "archivetest")
assert.NoError(err)
assert.NoError(t, err)
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(os.Mkdir(filepath.Join(dist, "mybin"), 0755))
assert.NoError(t, os.Mkdir(dist, 0755))
assert.NoError(t, os.Mkdir(filepath.Join(dist, "mybin"), 0755))
var ctx = &context.Context{
Version: "1.0.0",
Config: config.Project{
@ -95,11 +92,10 @@ func TestCreateFileDoesntExist(t *testing.T) {
},
}
ctx.AddBinary("linuxamd64", "mybin", "mybin", filepath.Join(dist, "mybin", "mybin"))
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}
func TestRunPipeWithExtraFiles(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Version: "1.0.0",
Config: config.Project{
@ -108,5 +104,5 @@ func TestRunPipeWithExtraFiles(t *testing.T) {
},
},
}
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
}

View File

@ -18,17 +18,15 @@ func TestDescription(t *testing.T) {
}
func TestNotAGitFolder(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
var ctx = &context.Context{
Config: config.Project{},
}
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}
func TestSingleCommit(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -38,22 +36,20 @@ func TestSingleCommit(t *testing.T) {
Config: config.Project{},
}
testlib.AssertSkipped(t, Pipe{}.Run(ctx))
assert.Equal("v0.0.1", ctx.Git.CurrentTag)
assert.Equal(t, "v0.0.1", ctx.Git.CurrentTag)
}
func TestNewRepository(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
var ctx = &context.Context{
Config: config.Project{},
}
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}
func TestNoTagsSnapshot(t *testing.T) {
assert := assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -68,11 +64,10 @@ func TestNoTagsSnapshot(t *testing.T) {
Publish: false,
}
testlib.AssertSkipped(t, Pipe{}.Run(ctx))
assert.Contains(ctx.Version, "SNAPSHOT-")
assert.Contains(t, ctx.Version, "SNAPSHOT-")
}
func TestNoTagsSnapshotInvalidTemplate(t *testing.T) {
assert := assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -86,14 +81,13 @@ func TestNoTagsSnapshotInvalidTemplate(t *testing.T) {
Snapshot: true,
Publish: false,
}
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}
// TestNoTagsNoSnapshot covers the situation where a repository
// only contains simple commits and no tags. In this case you have
// to set the --snapshot flag otherwise an error is returned.
func TestNoTagsNoSnapshot(t *testing.T) {
assert := assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -107,11 +101,10 @@ func TestNoTagsNoSnapshot(t *testing.T) {
Snapshot: false,
Publish: false,
}
assert.Error(Pipe{}.Run(ctx))
assert.Error(t, Pipe{}.Run(ctx))
}
func TestInvalidTagFormat(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -121,32 +114,30 @@ func TestInvalidTagFormat(t *testing.T) {
Config: config.Project{},
Validate: true,
}
assert.EqualError(Pipe{}.Run(ctx), "sadasd is not in a valid version format")
assert.Equal("sadasd", ctx.Git.CurrentTag)
assert.EqualError(t, Pipe{}.Run(ctx), "sadasd is not in a valid version format")
assert.Equal(t, "sadasd", ctx.Git.CurrentTag)
}
func TestDirty(t *testing.T) {
var assert = assert.New(t)
folder, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
dummy, err := os.Create(filepath.Join(folder, "dummy"))
assert.NoError(err)
assert.NoError(t, err)
testlib.GitAdd(t)
testlib.GitCommit(t, "commit2")
testlib.GitTag(t, "v0.0.1")
assert.NoError(ioutil.WriteFile(dummy.Name(), []byte("lorem ipsum"), 0644))
assert.NoError(t, ioutil.WriteFile(dummy.Name(), []byte("lorem ipsum"), 0644))
var ctx = &context.Context{
Config: config.Project{},
Validate: true,
}
err = Pipe{}.Run(ctx)
assert.Error(err)
assert.Contains(err.Error(), "git is currently in a dirty state:")
assert.Error(t, err)
assert.Contains(t, err.Error(), "git is currently in a dirty state:")
}
func TestTagIsNotLastCommit(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -158,12 +149,11 @@ func TestTagIsNotLastCommit(t *testing.T) {
Validate: true,
}
err := Pipe{}.Run(ctx)
assert.Error(err)
assert.Contains(err.Error(), "git tag v0.0.1 was not made against commit")
assert.Error(t, err)
assert.Contains(t, err.Error(), "git tag v0.0.1 was not made against commit")
}
func TestValidState(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -175,10 +165,10 @@ func TestValidState(t *testing.T) {
Config: config.Project{},
Validate: true,
}
assert.NoError(Pipe{}.Run(ctx))
assert.Equal("v0.0.2", ctx.Git.CurrentTag)
assert.NotContains("commit4", ctx.ReleaseNotes)
assert.NotContains("commit3", ctx.ReleaseNotes)
assert.NoError(t, Pipe{}.Run(ctx))
assert.Equal(t, "v0.0.2", ctx.Git.CurrentTag)
assert.NotContains(t, "commit4", ctx.ReleaseNotes)
assert.NotContains(t, "commit3", ctx.ReleaseNotes)
}
func TestNoValidate(t *testing.T) {
@ -197,7 +187,6 @@ func TestNoValidate(t *testing.T) {
}
func TestChangelog(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -210,15 +199,14 @@ func TestChangelog(t *testing.T) {
Config: config.Project{},
}
testlib.AssertSkipped(t, Pipe{}.Run(ctx))
assert.Equal("v0.0.2", ctx.Git.CurrentTag)
assert.Contains(ctx.ReleaseNotes, "## Changelog")
assert.NotContains(ctx.ReleaseNotes, "first")
assert.Contains(ctx.ReleaseNotes, "added feature 1")
assert.Contains(ctx.ReleaseNotes, "fixed bug 2")
assert.Equal(t, "v0.0.2", ctx.Git.CurrentTag)
assert.Contains(t, ctx.ReleaseNotes, "## Changelog")
assert.NotContains(t, ctx.ReleaseNotes, "first")
assert.Contains(t, ctx.ReleaseNotes, "added feature 1")
assert.Contains(t, ctx.ReleaseNotes, "fixed bug 2")
}
func TestChangelogOfFirstRelease(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -236,15 +224,14 @@ func TestChangelogOfFirstRelease(t *testing.T) {
Config: config.Project{},
}
testlib.AssertSkipped(t, Pipe{}.Run(ctx))
assert.Equal("v0.0.1", ctx.Git.CurrentTag)
assert.Contains(ctx.ReleaseNotes, "## Changelog")
assert.Equal(t, "v0.0.1", ctx.Git.CurrentTag)
assert.Contains(t, ctx.ReleaseNotes, "## Changelog")
for _, msg := range msgs {
assert.Contains(ctx.ReleaseNotes, msg)
assert.Contains(t, ctx.ReleaseNotes, msg)
}
}
func TestCustomReleaseNotes(t *testing.T) {
var assert = assert.New(t)
_, back := testlib.Mktmp(t)
defer back()
testlib.GitInit(t)
@ -255,6 +242,6 @@ func TestCustomReleaseNotes(t *testing.T) {
ReleaseNotes: "custom",
}
testlib.AssertSkipped(t, Pipe{}.Run(ctx))
assert.Equal("v0.0.1", ctx.Git.CurrentTag)
assert.Equal(ctx.ReleaseNotes, "custom")
assert.Equal(t, "v0.0.1", ctx.Git.CurrentTag)
assert.Equal(t, ctx.ReleaseNotes, "custom")
}

View File

@ -8,15 +8,13 @@ import (
)
func TestSkipPipe(t *testing.T) {
var assert = assert.New(t)
var reason = "this is a test"
var err = Skip(reason)
assert.Error(err)
assert.Equal(reason, err.Error())
assert.Error(t, err)
assert.Equal(t, reason, err.Error())
}
func TestIsSkip(t *testing.T) {
var assert = assert.New(t)
assert.True(IsSkip(Skip("whatever")))
assert.False(IsSkip(errors.New("nope")))
assert.True(t, IsSkip(Skip("whatever")))
assert.False(t, IsSkip(errors.New("nope")))
}

View File

@ -10,7 +10,6 @@ import (
)
func TestDescribeBody(t *testing.T) {
var assert = assert.New(t)
var changelog = "\nfeature1: description\nfeature2: other description"
var ctx = &context.Context{
ReleaseNotes: changelog,
@ -20,52 +19,49 @@ func TestDescribeBody(t *testing.T) {
},
}
out, err := describeBodyVersion(ctx, "go version go1.9 darwin/amd64")
assert.NoError(err)
assert.NoError(t, err)
bts, err := ioutil.ReadFile("testdata/release1.txt")
assert.NoError(err)
ioutil.WriteFile("testdata/release1.txt", out.Bytes(), 0755)
assert.NoError(t, err)
// ioutil.WriteFile("testdata/release1.txt", out.Bytes(), 0755)
assert.Equal(string(bts), out.String())
assert.Equal(t, string(bts), out.String())
}
func TestDescribeBodyNoDockerImages(t *testing.T) {
var assert = assert.New(t)
var changelog = "\nfeature1: description\nfeature2: other description"
var ctx = &context.Context{
ReleaseNotes: changelog,
}
out, err := describeBodyVersion(ctx, "go version go1.9 darwin/amd64")
assert.NoError(err)
assert.NoError(t, err)
bts, err := ioutil.ReadFile("testdata/release2.txt")
assert.NoError(err)
ioutil.WriteFile("testdata/release2.txt", out.Bytes(), 0755)
assert.NoError(t, err)
// ioutil.WriteFile("testdata/release2.txt", out.Bytes(), 0755)
assert.Equal(string(bts), out.String())
assert.Equal(t, string(bts), out.String())
}
func TestDontEscapeHTML(t *testing.T) {
var assert = assert.New(t)
var changelog = "<h1>test</h1>"
var ctx = &context.Context{
ReleaseNotes: changelog,
}
out, err := describeBody(ctx)
assert.NoError(err)
assert.Contains(out.String(), changelog)
assert.NoError(t, err)
assert.Contains(t, out.String(), changelog)
}
func TestGoVersionFails(t *testing.T) {
var assert = assert.New(t)
var path = os.Getenv("PATH")
defer func() {
assert.NoError(os.Setenv("PATH", path))
assert.NoError(t, os.Setenv("PATH", path))
}()
assert.NoError(os.Setenv("PATH", ""))
assert.NoError(t, os.Setenv("PATH", ""))
var ctx = &context.Context{
ReleaseNotes: "changelog",
}
_, err := describeBody(ctx)
assert.Error(err)
assert.Error(t, err)
}

View File

@ -19,13 +19,12 @@ func TestPipeDescription(t *testing.T) {
}
func TestRunPipe(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
tarfile, err := os.Create(filepath.Join(folder, "bin.tar.gz"))
assert.NoError(err)
assert.NoError(t, err)
debfile, err := os.Create(filepath.Join(folder, "bin.deb"))
assert.NoError(err)
assert.NoError(t, err)
var config = config.Project{
Dist: folder,
Release: config.Release{
@ -41,15 +40,14 @@ func TestRunPipe(t *testing.T) {
ctx.AddArtifact(tarfile.Name())
ctx.AddArtifact(debfile.Name())
client := &DummyClient{}
assert.NoError(doRun(ctx, client))
assert.True(client.CreatedRelease)
assert.True(client.UploadedFile)
assert.Contains(client.UploadedFileNames, "bin.deb")
assert.Contains(client.UploadedFileNames, "bin.tar.gz")
assert.NoError(t, doRun(ctx, client))
assert.True(t, client.CreatedRelease)
assert.True(t, client.UploadedFile)
assert.Contains(t, client.UploadedFileNames, "bin.deb")
assert.Contains(t, client.UploadedFileNames, "bin.tar.gz")
}
func TestRunPipeReleaseCreationFailed(t *testing.T) {
var assert = assert.New(t)
var config = config.Project{
Release: config.Release{
GitHub: config.Repo{
@ -64,13 +62,12 @@ func TestRunPipeReleaseCreationFailed(t *testing.T) {
client := &DummyClient{
FailToCreateRelease: true,
}
assert.Error(doRun(ctx, client))
assert.False(client.CreatedRelease)
assert.False(client.UploadedFile)
assert.Error(t, doRun(ctx, client))
assert.False(t, client.CreatedRelease)
assert.False(t, client.UploadedFile)
}
func TestRunPipeWithFileThatDontExist(t *testing.T) {
var assert = assert.New(t)
var config = config.Project{
Release: config.Release{
GitHub: config.Repo{
@ -84,17 +81,16 @@ func TestRunPipeWithFileThatDontExist(t *testing.T) {
ctx.Publish = true
ctx.AddArtifact("this-file-wont-exist-hopefully")
client := &DummyClient{}
assert.Error(doRun(ctx, client))
assert.True(client.CreatedRelease)
assert.False(client.UploadedFile)
assert.Error(t, doRun(ctx, client))
assert.True(t, client.CreatedRelease)
assert.False(t, client.UploadedFile)
}
func TestRunPipeUploadFailure(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(err)
assert.NoError(t, err)
tarfile, err := os.Create(filepath.Join(folder, "bin.tar.gz"))
assert.NoError(err)
assert.NoError(t, err)
var config = config.Project{
Release: config.Release{
GitHub: config.Repo{
@ -110,21 +106,20 @@ func TestRunPipeUploadFailure(t *testing.T) {
client := &DummyClient{
FailToUpload: true,
}
assert.Error(doRun(ctx, client))
assert.True(client.CreatedRelease)
assert.False(client.UploadedFile)
assert.Error(t, doRun(ctx, client))
assert.True(t, client.CreatedRelease)
assert.False(t, client.UploadedFile)
}
func TestSkipPublish(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Publish: false,
Parallelism: 1,
}
client := &DummyClient{}
testlib.AssertSkipped(t, doRun(ctx, client))
assert.False(client.CreatedRelease)
assert.False(client.UploadedFile)
assert.False(t, client.CreatedRelease)
assert.False(t, client.UploadedFile)
}
type DummyClient struct {

View File

@ -29,24 +29,22 @@ func TestRunPipeMissingInfo(t *testing.T) {
pipeline.Skip("no summary nor description were provided"): {},
} {
t.Run(fmt.Sprintf("testing if %v happens", eerr), func(t *testing.T) {
var assert = assert.New(t)
var ctx = &context.Context{
Config: config.Project{
Snapcraft: snap,
},
}
assert.Equal(eerr, Pipe{}.Run(ctx))
assert.Equal(t, eerr, Pipe{}.Run(ctx))
})
}
}
func TestRunPipe(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "archivetest")
assert.NoError(err)
assert.NoError(t, err)
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(err)
assert.NoError(t, os.Mkdir(dist, 0755))
assert.NoError(t, err)
var ctx = &context.Context{
Version: "testversion",
Config: config.Project{
@ -59,16 +57,15 @@ func TestRunPipe(t *testing.T) {
},
}
addBinaries(t, ctx, "mybin", dist)
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
}
func TestRunPipeWithName(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "archivetest")
assert.NoError(err)
assert.NoError(t, err)
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(err)
assert.NoError(t, os.Mkdir(dist, 0755))
assert.NoError(t, err)
var ctx = &context.Context{
Version: "testversion",
Config: config.Project{
@ -82,22 +79,21 @@ func TestRunPipeWithName(t *testing.T) {
},
}
addBinaries(t, ctx, "testprojectname", dist)
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
yamlFile, err := ioutil.ReadFile(filepath.Join(dist, "testprojectname_linuxamd64", "prime", "meta", "snap.yaml"))
assert.NoError(err)
assert.NoError(t, err)
var metadata Metadata
err = yaml.Unmarshal(yamlFile, &metadata)
assert.NoError(err)
assert.Equal(metadata.Name, "testsnapname")
assert.NoError(t, err)
assert.Equal(t, metadata.Name, "testsnapname")
}
func TestRunPipeWithPlugsAndDaemon(t *testing.T) {
var assert = assert.New(t)
folder, err := ioutil.TempDir("", "archivetest")
assert.NoError(err)
assert.NoError(t, err)
var dist = filepath.Join(folder, "dist")
assert.NoError(os.Mkdir(dist, 0755))
assert.NoError(err)
assert.NoError(t, os.Mkdir(dist, 0755))
assert.NoError(t, err)
var ctx = &context.Context{
Version: "testversion",
Config: config.Project{
@ -116,23 +112,22 @@ func TestRunPipeWithPlugsAndDaemon(t *testing.T) {
},
}
addBinaries(t, ctx, "mybin", dist)
assert.NoError(Pipe{}.Run(ctx))
assert.NoError(t, Pipe{}.Run(ctx))
yamlFile, err := ioutil.ReadFile(filepath.Join(dist, "mybin_linuxamd64", "prime", "meta", "snap.yaml"))
assert.NoError(err)
assert.NoError(t, err)
var metadata Metadata
err = yaml.Unmarshal(yamlFile, &metadata)
assert.NoError(err)
assert.Equal(metadata.Apps["mybin"].Plugs, []string{"home", "network"})
assert.Equal(metadata.Apps["mybin"].Daemon, "simple")
assert.NoError(t, err)
assert.Equal(t, metadata.Apps["mybin"].Plugs, []string{"home", "network"})
assert.Equal(t, metadata.Apps["mybin"].Daemon, "simple")
}
func TestNoSnapcraftInPath(t *testing.T) {
var assert = assert.New(t)
var path = os.Getenv("PATH")
defer func() {
assert.NoError(os.Setenv("PATH", path))
assert.NoError(t, os.Setenv("PATH", path))
}()
assert.NoError(os.Setenv("PATH", ""))
assert.NoError(t, os.Setenv("PATH", ""))
var ctx = &context.Context{
Config: config.Project{
Snapcraft: config.Snapcraft{
@ -141,11 +136,10 @@ func TestNoSnapcraftInPath(t *testing.T) {
},
},
}
assert.EqualError(Pipe{}.Run(ctx), ErrNoSnapcraft.Error())
assert.EqualError(t, Pipe{}.Run(ctx), ErrNoSnapcraft.Error())
}
func addBinaries(t *testing.T, ctx *context.Context, name, dist string) {
var assert = assert.New(t)
for _, plat := range []string{
"linuxamd64",
"linux386",
@ -155,10 +149,10 @@ func addBinaries(t *testing.T, ctx *context.Context, name, dist string) {
"linuxwtf",
} {
var folder = name + "_" + plat
assert.NoError(os.Mkdir(filepath.Join(dist, folder), 0755))
assert.NoError(t, os.Mkdir(filepath.Join(dist, folder), 0755))
var binPath = filepath.Join(dist, folder, name)
_, err := os.Create(binPath)
assert.NoError(err)
assert.NoError(t, err)
ctx.AddBinary(plat, folder, name, binPath)
}
}