builder/amazonebs: Config validation, testing

This commit is contained in:
Mitchell Hashimoto 2013-06-08 17:41:56 -07:00
parent a5bcb3d0e6
commit 6a23cb726c
2 changed files with 102 additions and 21 deletions

View File

@ -6,6 +6,7 @@
package amazonebs package amazonebs
import ( import (
"errors"
"github.com/mitchellh/goamz/aws" "github.com/mitchellh/goamz/aws"
"github.com/mitchellh/goamz/ec2" "github.com/mitchellh/goamz/ec2"
"github.com/mitchellh/mapstructure" "github.com/mitchellh/mapstructure"
@ -44,17 +45,32 @@ func (b *Builder) Prepare(raw interface{}) (err error) {
return return
} }
log.Printf("Config: %+v", b.config) if b.config.SSHPort == 0 {
b.config.SSHPort = 22
}
// Accumulate any errors
errs := make([]error, 0)
if b.config.AccessKey == "" {
errs = append(errs, errors.New("An access_key must be specified"))
}
if b.config.SecretKey == "" {
errs = append(errs, errors.New("A secret_key must be specified"))
}
if len(errs) > 0 {
return &packer.MultiError{errs}
}
// TODO: config validation and asking for fields: // TODO: config validation and asking for fields:
// * access key
// * secret key
// * region (exists and valid) // * region (exists and valid)
// * source ami // * source ami
// * instance type // * instance type
// * SSH username // * SSH username
// * SSH port? (or default to 22?)
log.Printf("Config: %+v", b.config)
return return
} }

View File

@ -1,16 +1,23 @@
package amazonebs package amazonebs
import ( import (
"cgl.tideland.biz/asserts"
"github.com/mitchellh/packer/packer" "github.com/mitchellh/packer/packer"
"testing" "testing"
) )
func TestBuilder_ImplementsBuilder(t *testing.T) { func testConfig() map[string]interface{} {
assert := asserts.NewTestingAsserts(t, true) return map[string]interface{}{
"access_key": "foo",
"secret_key": "bar",
}
}
var actual packer.Builder func TestBuilder_ImplementsBuilder(t *testing.T) {
assert.Implementor(&Builder{}, &actual, "should be a Builder") var raw interface{}
raw = &Builder{}
if _, ok := raw.(packer.Builder); !ok {
t.Fatalf("Builder should be a builder")
}
} }
func TestBuilder_Prepare_BadType(t *testing.T) { func TestBuilder_Prepare_BadType(t *testing.T) {
@ -25,19 +32,77 @@ func TestBuilder_Prepare_BadType(t *testing.T) {
} }
} }
func TestBuilder_Prepare_Good(t *testing.T) { func TestBuilderPrepare_AccessKey(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true) var b Builder
config := testConfig()
b := &Builder{} // Test good
c := map[string]interface{}{ config["access_key"] = "foo"
"access_key": "foo", err := b.Prepare(config)
"secret_key": "bar", if err != nil {
"source_ami": "123456", t.Fatalf("should not have error: %s", err)
} }
err := b.Prepare(c) if b.config.AccessKey != "foo" {
assert.Nil(err, "should not have an error") t.Errorf("access key invalid: %s", b.config.AccessKey)
assert.Equal(b.config.AccessKey, "foo", "should be valid access key") }
assert.Equal(b.config.SecretKey, "bar", "should be valid secret key")
assert.Equal(b.config.SourceAmi, "123456", "should have source AMI") // Test bad
delete(config, "access_key")
b = Builder{}
err = b.Prepare(config)
if err == nil {
t.Fatal("should have error")
}
}
func TestBuilderPrepare_SecretKey(t *testing.T) {
var b Builder
config := testConfig()
// Test good
config["secret_key"] = "foo"
err := b.Prepare(config)
if err != nil {
t.Fatalf("should not have error: %s", err)
}
if b.config.SecretKey != "foo" {
t.Errorf("secret key invalid: %s", b.config.SecretKey)
}
// Test bad
delete(config, "secret_key")
b = Builder{}
err = b.Prepare(config)
if err == nil {
t.Fatal("should have error")
}
}
func TestBuilderPrepare_SSHPort(t *testing.T) {
var b Builder
config := testConfig()
// Test default
err := b.Prepare(config)
if err != nil {
t.Fatalf("should not have error: %s", err)
}
if b.config.SSHPort != 22 {
t.Errorf("invalid: %d", b.config.SSHPort)
}
// Test set
config["ssh_port"] = 35
b = Builder{}
err = b.Prepare(config)
if err != nil {
t.Fatalf("should not have error: %s", err)
}
if b.config.SSHPort != 35 {
t.Errorf("invalid: %d", b.config.SSHPort)
}
} }