2017-09-12 11:30:39 -04:00
|
|
|
package oci
|
2017-02-13 05:35:14 -05:00
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"os"
|
|
|
|
|
2017-04-07 06:20:33 -04:00
|
|
|
"github.com/hashicorp/packer/packer"
|
2017-02-13 05:35:14 -05:00
|
|
|
"github.com/mitchellh/multistep"
|
|
|
|
|
2017-09-12 11:30:39 -04:00
|
|
|
client "github.com/hashicorp/packer/builder/oracle/oci/client"
|
2017-02-13 05:35:14 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
// TODO(apryde): It would be good not to have to write a key file to disk to
|
|
|
|
// load the config.
|
|
|
|
func baseTestConfig() *Config {
|
|
|
|
_, keyFile, err := client.BaseTestConfig()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg, err := NewConfig(map[string]interface{}{
|
|
|
|
"availability_domain": "aaaa:PHX-AD-3",
|
|
|
|
|
|
|
|
// Image
|
|
|
|
"base_image_ocid": "ocd1...",
|
|
|
|
"shape": "VM.Standard1.1",
|
|
|
|
"image_name": "HelloWorld",
|
|
|
|
|
|
|
|
// Networking
|
|
|
|
"subnet_ocid": "ocd1...",
|
|
|
|
|
|
|
|
// AccessConfig
|
|
|
|
"user_ocid": "ocid1...",
|
|
|
|
"tenancy_ocid": "ocid1...",
|
|
|
|
"fingerprint": "00:00...",
|
|
|
|
"key_file": keyFile.Name(),
|
2017-02-13 07:37:27 -05:00
|
|
|
|
|
|
|
// Comm
|
|
|
|
"ssh_username": "opc",
|
2017-02-13 05:35:14 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
// Once we have a config object they key file isn't re-read so we can
|
|
|
|
// remove it now.
|
|
|
|
os.Remove(keyFile.Name())
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
return cfg
|
|
|
|
}
|
|
|
|
|
|
|
|
func testState() multistep.StateBag {
|
|
|
|
state := new(multistep.BasicStateBag)
|
|
|
|
state.Put("config", baseTestConfig())
|
|
|
|
state.Put("driver", &driverMock{})
|
|
|
|
state.Put("hook", &packer.MockHook{})
|
|
|
|
state.Put("ui", &packer.BasicUi{
|
|
|
|
Reader: new(bytes.Buffer),
|
|
|
|
Writer: new(bytes.Buffer),
|
|
|
|
})
|
|
|
|
return state
|
|
|
|
}
|