Commit 2f607074 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

command/push: actual upload to named build config

parent 0f5ef2ce
...@@ -7,6 +7,7 @@ import ( ...@@ -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" ...@@ -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 { ...@@ -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 { ...@@ -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( ...@@ -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) { ...@@ -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) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment