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:
parent
753359a63a
commit
82a24d048d
@ -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
|
||||||
|
@ -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")
|
||||||
|
3
pipeline/checksums/doc.go
Normal file
3
pipeline/checksums/doc.go
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
// Package checksums provides a Pipe that creates .checksums files for
|
||||||
|
// each artifact.
|
||||||
|
package checksums
|
Loading…
x
Reference in New Issue
Block a user