7776bf596b
fixes: #5476 Based on this new template addition: ``` { "variables": { "image_version": "", "triton_account": "", "triton_key_id": "", "triton_key_material": "" }, "builders": [{ "type": "triton", "triton_account": "{{user `triton_account`}}", "triton_key_id": "{{user `triton_key_id`}}", "triton_key_material": "{{user `triton_key_material`}}", "source_machine_package": "g4-highcpu-128M", "source_machine_image_filter": { "name": "ubuntu-16.04", "most_recent": "true" }, "ssh_username": "root", "image_version": "{{user `image_version`}}", "image_name": "teamcity-server" }], "provisioners": [ { "type": "shell", "start_retry_timeout": "10m", "inline": [ "sudo apt-get update -y", "sudo apt-get install -y nginx" ] } ] } ``` I got the following output from packer: ``` packer-testing % make image packer build \ -var "triton_account=stack72_joyent" \ -var "triton_key_id=40:9d:d3:f9:0b:86:62:48:f4:2e:a5:8e:43:00:2a:9b" \ -var "triton_key_material=""" \ -var "image_version=1.0.0" \ new-template.json triton output will be in this color. ==> triton: Selecting an image based on search criteria ==> triton: Based, on given search criteria, Machine ID is: "7b5981c4-1889-11e7-b4c5-3f3bdfc9b88b" ==> triton: Waiting for source machine to become available... ==> triton: Waiting for SSH to become available... ==> triton: Connected to SSH! ==> triton: Provisioning with shell script: /var/folders/_p/2_zj9lqn4n11fx20qy787p7c0000gn/T/packer-shell797317310 triton: Get:1 http://security.ubuntu.com/ubuntu xenial-security InRelease [102 kB] triton: Hit:2 http://archive.ubuntu.com/ubuntu xenial InRelease ``` I can verify from the triton cli tools that the id `7b5981c4` (from the packer output) is indeed the correct ID ``` terraform [master●] % triton images name=~ubuntu-16.04 SHORTID NAME VERSION FLAGS OS TYPE PUBDATE 49b22aec ubuntu-16.04 20160427 P linux lx-dataset 2016-04-27 675834a0 ubuntu-16.04 20160505 P linux lx-dataset 2016-05-05 4edaa46a ubuntu-16.04 20160516 P linux lx-dataset 2016-05-16 05140a7e ubuntu-16.04 20160601 P linux lx-dataset 2016-06-01 e331b22a ubuntu-16.04 20161004 P linux lx-dataset 2016-10-04 8879c758 ubuntu-16.04 20161213 P linux lx-dataset 2016-12-13 7b5981c4 ubuntu-16.04 20170403 P linux lx-dataset 2017-04-03 <------- THIS IS THE LATEST UBUNTU IMAGE ```
51 lines
1.1 KiB
Go
51 lines
1.1 KiB
Go
package triton
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
func TestSourceMachineConfig_Prepare(t *testing.T) {
|
|
sc := testSourceMachineConfig(t)
|
|
errs := sc.Prepare(nil)
|
|
if errs != nil {
|
|
t.Fatalf("should not error: %#v", sc)
|
|
}
|
|
|
|
sc = testSourceMachineConfig(t)
|
|
sc.MachineName = ""
|
|
errs = sc.Prepare(nil)
|
|
if errs != nil {
|
|
t.Fatalf("should not error: %#v", sc)
|
|
}
|
|
|
|
sc = testSourceMachineConfig(t)
|
|
sc.MachinePackage = ""
|
|
errs = sc.Prepare(nil)
|
|
if errs == nil {
|
|
t.Fatalf("should error: %#v", sc)
|
|
}
|
|
}
|
|
|
|
func testSourceMachineConfig(t *testing.T) SourceMachineConfig {
|
|
return SourceMachineConfig{
|
|
MachineName: "test-machine",
|
|
MachinePackage: "test-package",
|
|
MachineImage: "test-image",
|
|
MachineNetworks: []string{
|
|
"test-network-1",
|
|
"test-network-2",
|
|
},
|
|
MachineMetadata: map[string]string{
|
|
"test-metadata-key1": "test-metadata-value1",
|
|
"test-metadata-key2": "test-metadata-value2",
|
|
"test-metadata-key3": "test-metadata-value3",
|
|
},
|
|
MachineTags: map[string]string{
|
|
"test-tags-key1": "test-tags-value1",
|
|
"test-tags-key2": "test-tags-value2",
|
|
"test-tags-key3": "test-tags-value3",
|
|
},
|
|
MachineFirewallEnabled: false,
|
|
}
|
|
}
|