command/push: send artifact true/false if we're post-processing
This commit is contained in:
parent
2dfc5d3e71
commit
c9504d50ba
|
@ -7,8 +7,8 @@ import (
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/hashicorp/atlas-go/v1"
|
|
||||||
"github.com/hashicorp/atlas-go/archive"
|
"github.com/hashicorp/atlas-go/archive"
|
||||||
|
"github.com/hashicorp/atlas-go/v1"
|
||||||
"github.com/mitchellh/packer/packer"
|
"github.com/mitchellh/packer/packer"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -21,9 +21,14 @@ type PushCommand struct {
|
||||||
client *atlas.Client
|
client *atlas.Client
|
||||||
|
|
||||||
// For tests:
|
// For tests:
|
||||||
uploadFn func(io.Reader, *uploadOpts) (<-chan struct{}, <-chan error, error)
|
uploadFn pushUploadFn
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// pushUploadFn is the callback type used for tests to stub out the uploading
|
||||||
|
// logic of the push command.
|
||||||
|
type pushUploadFn func(
|
||||||
|
io.Reader, *uploadOpts) (<-chan struct{}, <-chan error, error)
|
||||||
|
|
||||||
func (c *PushCommand) Run(args []string) int {
|
func (c *PushCommand) Run(args []string) int {
|
||||||
var create bool
|
var create bool
|
||||||
var token string
|
var token string
|
||||||
|
@ -114,12 +119,32 @@ func (c *PushCommand) Run(args []string) int {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Find the Atlas post-processors, if possible
|
||||||
|
var atlasPPs []packer.RawPostProcessorConfig
|
||||||
|
for _, list := range tpl.PostProcessors {
|
||||||
|
for _, pp := range list {
|
||||||
|
if pp.Type == "atlas" {
|
||||||
|
atlasPPs = append(atlasPPs, pp)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Build the upload options
|
// Build the upload options
|
||||||
var uploadOpts uploadOpts
|
var uploadOpts uploadOpts
|
||||||
uploadOpts.Slug = tpl.Push.Name
|
uploadOpts.Slug = tpl.Push.Name
|
||||||
uploadOpts.Builds = make(map[string]string)
|
uploadOpts.Builds = make(map[string]*uploadBuildInfo)
|
||||||
for _, b := range tpl.Builders {
|
for _, b := range tpl.Builders {
|
||||||
uploadOpts.Builds[b.Name] = b.Type
|
info := &uploadBuildInfo{Type: b.Type}
|
||||||
|
|
||||||
|
// Determine if we're artifacting this build
|
||||||
|
for _, pp := range atlasPPs {
|
||||||
|
if !pp.Skip(b.Name) {
|
||||||
|
info.Artifact = true
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uploadOpts.Builds[b.Name] = info
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create the build config if it doesn't currently exist.
|
// Create the build config if it doesn't currently exist.
|
||||||
|
@ -206,7 +231,7 @@ func (c *PushCommand) create(name string, create bool) error {
|
||||||
// Otherwise, show an error if we're not creating.
|
// Otherwise, show an error if we're not creating.
|
||||||
if !create {
|
if !create {
|
||||||
return fmt.Errorf(
|
return fmt.Errorf(
|
||||||
"Push target doesn't exist: %s. Either create this online via\n" +
|
"Push target doesn't exist: %s. Either create this online via\n"+
|
||||||
"the website or pass the -create flag.", name)
|
"the website or pass the -create flag.", name)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -242,10 +267,11 @@ func (c *PushCommand) upload(
|
||||||
Name: bc.Name,
|
Name: bc.Name,
|
||||||
Builds: make([]atlas.BuildConfigBuild, 0, len(opts.Builds)),
|
Builds: make([]atlas.BuildConfigBuild, 0, len(opts.Builds)),
|
||||||
}
|
}
|
||||||
for name, t := range opts.Builds {
|
for name, info := range opts.Builds {
|
||||||
version.Builds = append(version.Builds, atlas.BuildConfigBuild{
|
version.Builds = append(version.Builds, atlas.BuildConfigBuild{
|
||||||
Name: name,
|
Name: name,
|
||||||
Type: t,
|
Type: info.Type,
|
||||||
|
Artifact: info.Artifact,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,5 +293,10 @@ func (c *PushCommand) upload(
|
||||||
type uploadOpts struct {
|
type uploadOpts struct {
|
||||||
URL string
|
URL string
|
||||||
Slug string
|
Slug string
|
||||||
Builds map[string]string
|
Builds map[string]*uploadBuildInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
type uploadBuildInfo struct {
|
||||||
|
Type string
|
||||||
|
Artifact bool
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
package command
|
package command
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"archive/tar"
|
"archive/tar"
|
||||||
"bytes"
|
"bytes"
|
||||||
"compress/gzip"
|
"compress/gzip"
|
||||||
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"reflect"
|
"reflect"
|
||||||
|
@ -59,7 +59,46 @@ func TestPush(t *testing.T) {
|
||||||
t.Fatalf("bad: %#v", actual)
|
t.Fatalf("bad: %#v", actual)
|
||||||
}
|
}
|
||||||
|
|
||||||
expectedBuilds := map[string]string{"dummy": "dummy"}
|
expectedBuilds := map[string]*uploadBuildInfo{
|
||||||
|
"dummy": &uploadBuildInfo{
|
||||||
|
Type: "dummy",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(actualOpts.Builds, expectedBuilds) {
|
||||||
|
t.Fatalf("bad: %#v", actualOpts.Builds)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPush_builds(t *testing.T) {
|
||||||
|
var actualOpts *uploadOpts
|
||||||
|
uploadFn := func(
|
||||||
|
r io.Reader, opts *uploadOpts) (<-chan struct{}, <-chan error, error) {
|
||||||
|
actualOpts = opts
|
||||||
|
|
||||||
|
doneCh := make(chan struct{})
|
||||||
|
close(doneCh)
|
||||||
|
return doneCh, nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
c := &PushCommand{
|
||||||
|
Meta: testMeta(t),
|
||||||
|
uploadFn: uploadFn,
|
||||||
|
}
|
||||||
|
|
||||||
|
args := []string{filepath.Join(testFixture("push-builds"), "template.json")}
|
||||||
|
if code := c.Run(args); code != 0 {
|
||||||
|
fatalCommand(t, c.Meta)
|
||||||
|
}
|
||||||
|
|
||||||
|
expectedBuilds := map[string]*uploadBuildInfo{
|
||||||
|
"dummy": &uploadBuildInfo{
|
||||||
|
Type: "dummy",
|
||||||
|
Artifact: true,
|
||||||
|
},
|
||||||
|
"foo": &uploadBuildInfo{
|
||||||
|
Type: "dummy",
|
||||||
|
},
|
||||||
|
}
|
||||||
if !reflect.DeepEqual(actualOpts.Builds, expectedBuilds) {
|
if !reflect.DeepEqual(actualOpts.Builds, expectedBuilds) {
|
||||||
t.Fatalf("bad: %#v", actualOpts.Builds)
|
t.Fatalf("bad: %#v", actualOpts.Builds)
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
{
|
||||||
|
"builders": [
|
||||||
|
{"type": "dummy"},
|
||||||
|
{"type": "dummy", "name": "foo"}
|
||||||
|
],
|
||||||
|
|
||||||
|
"post-processors": [{
|
||||||
|
"type": "atlas",
|
||||||
|
"only": ["dummy"]
|
||||||
|
}],
|
||||||
|
|
||||||
|
"push": {
|
||||||
|
"name": "foo/bar"
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue