1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-03-19 20:57:53 +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 package checksums
import ( import (
@ -60,6 +58,7 @@ func (Pipe) Run(ctx *context.Context) (err error) {
artifact.Or( artifact.Or(
artifact.ByType(artifact.UploadableArchive), artifact.ByType(artifact.UploadableArchive),
artifact.ByType(artifact.UploadableBinary), artifact.ByType(artifact.UploadableBinary),
artifact.ByType(artifact.LinuxPackage),
), ),
).List() { ).List() {
artifact := artifact artifact := artifact

View File

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