2017-01-23 08:58:39 -05:00
|
|
|
package common
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net"
|
|
|
|
"testing"
|
2017-02-23 14:55:51 -05:00
|
|
|
|
2020-12-01 18:30:31 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/communicator"
|
2020-11-17 19:31:03 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep"
|
2020-11-18 13:34:59 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/template/config"
|
2017-01-23 08:58:39 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestESX5Driver_implDriver(t *testing.T) {
|
|
|
|
var _ Driver = new(ESX5Driver)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestESX5Driver_UpdateVMX(t *testing.T) {
|
|
|
|
var driver ESX5Driver
|
|
|
|
data := make(map[string]string)
|
|
|
|
driver.UpdateVMX("0.0.0.0", "", 5900, data)
|
|
|
|
if _, ok := data["remotedisplay.vnc.ip"]; ok {
|
|
|
|
// Do not add the remotedisplay.vnc.ip on ESXi
|
|
|
|
t.Fatal("invalid VMX data key: remotedisplay.vnc.ip")
|
|
|
|
}
|
|
|
|
if enabled := data["remotedisplay.vnc.enabled"]; enabled != "TRUE" {
|
|
|
|
t.Errorf("bad VMX data for key remotedisplay.vnc.enabled: %v", enabled)
|
|
|
|
}
|
|
|
|
if port := data["remotedisplay.vnc.port"]; port != fmt.Sprint(port) {
|
|
|
|
t.Errorf("bad VMX data for key remotedisplay.vnc.port: %v", port)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestESX5Driver_implOutputDir(t *testing.T) {
|
|
|
|
var _ OutputDir = new(ESX5Driver)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestESX5Driver_implVNCAddressFinder(t *testing.T) {
|
|
|
|
var _ VNCAddressFinder = new(ESX5Driver)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestESX5Driver_implRemoteDriver(t *testing.T) {
|
|
|
|
var _ RemoteDriver = new(ESX5Driver)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestESX5Driver_HostIP(t *testing.T) {
|
|
|
|
expected_host := "127.0.0.1"
|
|
|
|
|
|
|
|
//create mock SSH server
|
|
|
|
listen, _ := net.Listen("tcp", fmt.Sprintf("%s:0", expected_host))
|
|
|
|
port := listen.Addr().(*net.TCPAddr).Port
|
|
|
|
defer listen.Close()
|
|
|
|
|
2019-03-19 09:47:21 -04:00
|
|
|
driver := ESX5Driver{Host: "localhost", Port: port}
|
2018-10-25 17:41:01 -04:00
|
|
|
state := new(multistep.BasicStateBag)
|
2017-01-23 08:58:39 -05:00
|
|
|
|
2018-10-25 17:41:01 -04:00
|
|
|
if host, _ := driver.HostIP(state); host != expected_host {
|
2017-01-23 08:58:39 -05:00
|
|
|
t.Error(fmt.Sprintf("Expected string, %s but got %s", expected_host, host))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestESX5Driver_CommHost(t *testing.T) {
|
|
|
|
const expected_host = "127.0.0.1"
|
|
|
|
|
2017-02-23 14:55:51 -05:00
|
|
|
conf := make(map[string]interface{})
|
|
|
|
conf["communicator"] = "winrm"
|
|
|
|
conf["winrm_username"] = "username"
|
|
|
|
conf["winrm_password"] = "password"
|
|
|
|
conf["winrm_host"] = expected_host
|
2017-01-23 08:58:39 -05:00
|
|
|
|
2017-02-23 14:55:51 -05:00
|
|
|
var commConfig communicator.Config
|
|
|
|
err := config.Decode(&commConfig, nil, conf)
|
2019-09-27 19:05:12 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("error decoding config: %v", err)
|
|
|
|
}
|
2017-02-23 14:55:51 -05:00
|
|
|
state := new(multistep.BasicStateBag)
|
|
|
|
sshConfig := SSHConfig{Comm: commConfig}
|
|
|
|
state.Put("sshConfig", &sshConfig)
|
2018-10-29 17:42:19 -04:00
|
|
|
driver := ESX5Driver{CommConfig: *(&sshConfig.Comm)}
|
2017-02-06 02:13:37 -05:00
|
|
|
|
2017-02-23 14:55:51 -05:00
|
|
|
host, err := driver.CommHost(state)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("should not have error: %s", err)
|
|
|
|
}
|
|
|
|
if host != expected_host {
|
|
|
|
t.Errorf("bad host name: %s", host)
|
|
|
|
}
|
|
|
|
address, ok := state.GetOk("vm_address")
|
|
|
|
if !ok {
|
|
|
|
t.Error("state not updated with vm_address")
|
|
|
|
}
|
|
|
|
if address.(string) != expected_host {
|
|
|
|
t.Errorf("bad vm_address: %s", address.(string))
|
|
|
|
}
|
2017-01-23 08:58:39 -05:00
|
|
|
}
|