2013-08-09 01:50:23 -04:00
|
|
|
package common
|
|
|
|
|
|
|
|
import (
|
2013-08-22 17:58:21 -04:00
|
|
|
"reflect"
|
2013-08-09 01:50:23 -04:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func testAMIConfig() *AMIConfig {
|
|
|
|
return &AMIConfig{
|
|
|
|
AMIName: "foo",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-22 17:58:21 -04:00
|
|
|
func TestAMIConfigPrepare_name(t *testing.T) {
|
2013-08-09 01:50:23 -04:00
|
|
|
c := testAMIConfig()
|
|
|
|
if err := c.Prepare(nil); err != nil {
|
|
|
|
t.Fatalf("shouldn't have err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
c.AMIName = ""
|
|
|
|
if err := c.Prepare(nil); err == nil {
|
|
|
|
t.Fatal("should have error")
|
|
|
|
}
|
|
|
|
}
|
2013-08-22 17:58:21 -04:00
|
|
|
|
|
|
|
func TestAMIConfigPrepare_regions(t *testing.T) {
|
|
|
|
c := testAMIConfig()
|
|
|
|
c.AMIRegions = nil
|
|
|
|
if err := c.Prepare(nil); err != nil {
|
|
|
|
t.Fatalf("shouldn't have err: %s", err)
|
|
|
|
}
|
|
|
|
|
2016-01-12 22:03:21 -05:00
|
|
|
c.AMIRegions = listEC2Regions()
|
2016-01-11 16:02:38 -05:00
|
|
|
if err := c.Prepare(nil); err != nil {
|
|
|
|
t.Fatalf("shouldn't have err: %s", err)
|
|
|
|
}
|
|
|
|
|
2013-08-22 17:58:21 -04:00
|
|
|
c.AMIRegions = []string{"foo"}
|
|
|
|
if err := c.Prepare(nil); err == nil {
|
|
|
|
t.Fatal("should have error")
|
|
|
|
}
|
|
|
|
|
|
|
|
c.AMIRegions = []string{"us-east-1", "us-west-1", "us-east-1"}
|
|
|
|
if err := c.Prepare(nil); err != nil {
|
|
|
|
t.Fatalf("bad: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := []string{"us-east-1", "us-west-1"}
|
|
|
|
if !reflect.DeepEqual(c.AMIRegions, expected) {
|
|
|
|
t.Fatalf("bad: %#v", c.AMIRegions)
|
|
|
|
}
|
2016-06-06 14:17:12 -04:00
|
|
|
|
|
|
|
c.AMIRegions = []string{"custom"}
|
|
|
|
c.AMISkipRegionValidation = true
|
|
|
|
if err := c.Prepare(nil); err != nil {
|
|
|
|
t.Fatal("shouldn't have error")
|
|
|
|
}
|
|
|
|
c.AMISkipRegionValidation = false
|
|
|
|
|
2013-08-22 17:58:21 -04:00
|
|
|
}
|
2016-05-12 12:21:44 -04:00
|
|
|
|
2016-12-02 05:30:14 -05:00
|
|
|
func TestAMIConfigPrepare_Share_EncryptedBoot(t *testing.T) {
|
2016-05-12 12:21:44 -04:00
|
|
|
c := testAMIConfig()
|
|
|
|
c.AMIUsers = []string{"testAccountID"}
|
|
|
|
c.AMIEncryptBootVolume = true
|
2016-12-02 05:30:14 -05:00
|
|
|
|
|
|
|
c.AMIKmsKeyId = ""
|
2016-05-12 12:21:44 -04:00
|
|
|
if err := c.Prepare(nil); err == nil {
|
2016-12-04 09:14:53 -05:00
|
|
|
t.Fatal("shouldn't be able to share ami with encrypted boot volume")
|
2016-12-02 05:30:14 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
c.AMIKmsKeyId = "89c3fb9a-de87-4f2a-aedc-fddc5138193c"
|
2016-12-04 09:14:53 -05:00
|
|
|
if err := c.Prepare(nil); err == nil {
|
|
|
|
t.Fatal("shouldn't be able to share ami with encrypted boot volume")
|
2016-05-12 12:21:44 -04:00
|
|
|
}
|
|
|
|
}
|