1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-03-17 20:47:50 +02:00

test: fixed checksums pipe tests

This commit is contained in:
Carlos Alexandro Becker 2017-12-17 20:33:28 -02:00
parent 753359a63a
commit 82a24d048d
No known key found for this signature in database
GPG Key ID: E61E2F7DC14AB940
3 changed files with 41 additions and 19 deletions

View File

@ -1,5 +1,3 @@
// Package checksums provides a Pipe that creates .checksums files for
// each artifact.
package checksums
import (
@ -60,6 +58,7 @@ func (Pipe) Run(ctx *context.Context) (err error) {
artifact.Or(
artifact.ByType(artifact.UploadableArchive),
artifact.ByType(artifact.UploadableBinary),
artifact.ByType(artifact.LinuxPackage),
),
).List() {
artifact := artifact

View File

@ -5,6 +5,8 @@ import (
"path/filepath"
"testing"
"github.com/goreleaser/goreleaser/internal/artifact"
"github.com/goreleaser/goreleaser/config"
"github.com/goreleaser/goreleaser/context"
"github.com/stretchr/testify/assert"
@ -21,18 +23,26 @@ func TestPipe(t *testing.T) {
assert.NoError(t, err)
var file = filepath.Join(folder, binary)
assert.NoError(t, ioutil.WriteFile(file, []byte("some string"), 0644))
var ctx = &context.Context{
Config: config.Project{
var ctx = context.New(
config.Project{
Dist: folder,
ProjectName: binary,
Checksum: config.Checksum{
NameTemplate: "{{ .ProjectName }}_checksums.txt",
},
},
}
ctx.AddArtifact(file)
)
ctx.Artifacts.Add(artifact.Artifact{
Name: binary,
Path: file,
Type: artifact.UploadableBinary,
})
assert.NoError(t, Pipe{}.Run(ctx))
assert.Contains(t, ctx.Artifacts, checksums, binary)
var artifacts []string
for _, a := range ctx.Artifacts.List() {
artifacts = append(artifacts, a.Name)
}
assert.Contains(t, artifacts, checksums, binary)
bts, err := ioutil.ReadFile(filepath.Join(folder, checksums))
assert.NoError(t, err)
assert.Equal(t, "61d034473102d7dac305902770471fd50f4c5b26f6831a56dd90b5184b3c30fc binary\n", string(bts))
@ -41,15 +51,19 @@ func TestPipe(t *testing.T) {
func TestPipeFileNotExist(t *testing.T) {
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(t, err)
var ctx = &context.Context{
Config: config.Project{
var ctx = context.New(
config.Project{
Dist: folder,
Checksum: config.Checksum{
NameTemplate: "checksums.txt",
},
},
}
ctx.AddArtifact("nope")
)
ctx.Artifacts.Add(artifact.Artifact{
Name: "nope",
Path: "/nope",
Type: artifact.UploadableBinary,
})
err = Pipe{}.Run(ctx)
assert.Error(t, err)
assert.Contains(t, err.Error(), "/nope: no such file or directory")
@ -58,16 +72,19 @@ func TestPipeFileNotExist(t *testing.T) {
func TestPipeInvalidNameTemplate(t *testing.T) {
folder, err := ioutil.TempDir("", "goreleasertest")
assert.NoError(t, err)
var ctx = &context.Context{
Config: config.Project{
var ctx = context.New(
config.Project{
Dist: folder,
ProjectName: "name",
Checksum: config.Checksum{
NameTemplate: "{{ .Pro }_checksums.txt",
},
},
}
ctx.AddArtifact("whatever")
)
ctx.Artifacts.Add(artifact.Artifact{
Name: "whatever",
Type: artifact.UploadableBinary,
})
err = Pipe{}.Run(ctx)
assert.Error(t, err)
assert.Equal(t, `template: checksums:1: unexpected "}" in operand`, err.Error())
@ -78,15 +95,18 @@ func TestPipeCouldNotOpenChecksumsTxt(t *testing.T) {
assert.NoError(t, err)
var file = filepath.Join(folder, "checksums.txt")
assert.NoError(t, ioutil.WriteFile(file, []byte("some string"), 0000))
var ctx = &context.Context{
Config: config.Project{
var ctx = context.New(
config.Project{
Dist: folder,
Checksum: config.Checksum{
NameTemplate: "checksums.txt",
},
},
}
ctx.AddArtifact("nope")
)
ctx.Artifacts.Add(artifact.Artifact{
Name: "whatever",
Type: artifact.UploadableBinary,
})
err = Pipe{}.Run(ctx)
assert.Error(t, err)
assert.Contains(t, err.Error(), "/checksums.txt: permission denied")

View File

@ -0,0 +1,3 @@
// Package checksums provides a Pipe that creates .checksums files for
// each artifact.
package checksums