command/push: actual upload to named build config
This commit is contained in:
parent
0f5ef2ce2b
commit
2f60707463
|
@ -7,6 +7,7 @@ import (
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
"github.com/hashicorp/harmony-go"
|
||||||
"github.com/hashicorp/harmony-go/archive"
|
"github.com/hashicorp/harmony-go/archive"
|
||||||
"github.com/mitchellh/packer/packer"
|
"github.com/mitchellh/packer/packer"
|
||||||
)
|
)
|
||||||
|
@ -17,6 +18,8 @@ const archiveTemplateEntry = ".packer-template.json"
|
||||||
type PushCommand struct {
|
type PushCommand struct {
|
||||||
Meta
|
Meta
|
||||||
|
|
||||||
|
client *harmony.Client
|
||||||
|
|
||||||
// For tests:
|
// For tests:
|
||||||
uploadFn func(io.Reader, *uploadOpts) (<-chan struct{}, <-chan error, error)
|
uploadFn func(io.Reader, *uploadOpts) (<-chan struct{}, <-chan error, error)
|
||||||
}
|
}
|
||||||
|
@ -52,6 +55,10 @@ func (c *PushCommand) Run(args []string) int {
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Build our client
|
||||||
|
c.client = harmony.DefaultClient()
|
||||||
|
defer func() { c.client = nil }()
|
||||||
|
|
||||||
// Build the archiving options
|
// Build the archiving options
|
||||||
var opts archive.ArchiveOpts
|
var opts archive.ArchiveOpts
|
||||||
opts.Include = tpl.Push.Include
|
opts.Include = tpl.Push.Include
|
||||||
|
@ -76,6 +83,10 @@ func (c *PushCommand) Run(args []string) int {
|
||||||
var uploadOpts uploadOpts
|
var uploadOpts uploadOpts
|
||||||
uploadOpts.Slug = tpl.Push.Name
|
uploadOpts.Slug = tpl.Push.Name
|
||||||
uploadOpts.Token = token
|
uploadOpts.Token = token
|
||||||
|
uploadOpts.Builds = make(map[string]string)
|
||||||
|
for _, b := range tpl.Builders {
|
||||||
|
uploadOpts.Builds[b.Name] = b.Type
|
||||||
|
}
|
||||||
|
|
||||||
// Start the archiving process
|
// Start the archiving process
|
||||||
r, archiveErrCh, err := archive.Archive(path, &opts)
|
r, archiveErrCh, err := archive.Archive(path, &opts)
|
||||||
|
@ -136,11 +147,49 @@ func (c *PushCommand) upload(
|
||||||
return c.uploadFn(r, opts)
|
return c.uploadFn(r, opts)
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil, nil, nil
|
// Separate the slug into the user and name components
|
||||||
|
user, name, err := harmony.ParseSlug(opts.Slug)
|
||||||
|
if err != nil {
|
||||||
|
return nil, nil, fmt.Errorf("upload: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the app
|
||||||
|
bc, err := c.client.BuildConfig(user, name)
|
||||||
|
if err != nil {
|
||||||
|
return nil, nil, fmt.Errorf("upload: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Build the version to send up
|
||||||
|
version := harmony.BuildConfigVersion{
|
||||||
|
User: bc.User,
|
||||||
|
Name: bc.Name,
|
||||||
|
Builds: make([]harmony.BuildConfigBuild, 0, len(opts.Builds)),
|
||||||
|
}
|
||||||
|
for name, t := range opts.Builds {
|
||||||
|
version.Builds = append(version.Builds, harmony.BuildConfigBuild{
|
||||||
|
Name: name,
|
||||||
|
Type: t,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Start the upload
|
||||||
|
doneCh, errCh := make(chan struct{}), make(chan error)
|
||||||
|
go func() {
|
||||||
|
err := c.client.UploadBuildConfigVersion(&version, r)
|
||||||
|
if err != nil {
|
||||||
|
errCh <- err
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
close(doneCh)
|
||||||
|
}()
|
||||||
|
|
||||||
|
return doneCh, errCh, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
type uploadOpts struct {
|
type uploadOpts struct {
|
||||||
URL string
|
URL string
|
||||||
Slug string
|
Slug string
|
||||||
Token string
|
Token string
|
||||||
|
Builds map[string]string
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,6 +58,11 @@ func TestPush(t *testing.T) {
|
||||||
if !reflect.DeepEqual(actual, expected) {
|
if !reflect.DeepEqual(actual, expected) {
|
||||||
t.Fatalf("bad: %#v", actual)
|
t.Fatalf("bad: %#v", actual)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
expectedBuilds := map[string]string{"dummy": "dummy"}
|
||||||
|
if !reflect.DeepEqual(actualOpts.Builds, expectedBuilds) {
|
||||||
|
t.Fatalf("bad: %#v", actualOpts.Builds)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestPush_noName(t *testing.T) {
|
func TestPush_noName(t *testing.T) {
|
||||||
|
|
Loading…
Reference in New Issue