Merge pull request #9515 from jhawk28/vsphere_tools_fix

fix vsphere ToolsSyncTime and ToolsUpgradePolicy
This commit is contained in:
Megan Marsh 2020-07-02 14:19:41 -07:00 committed by GitHub
commit 6095fb2a62
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 26 additions and 17 deletions

View File

@ -7,6 +7,8 @@ import (
"context"
"fmt"
"github.com/vmware/govmomi/vim25/types"
"github.com/hashicorp/packer/builder/vsphere/driver"
"github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer"
@ -17,8 +19,7 @@ type ConfigParamsConfig struct {
// ConfigSpec: https://pubs.vmware.com/vi3/sdk/ReferenceGuide/vim.vm.ConfigSpec.html
ConfigParams map[string]string `mapstructure:"configuration_parameters"`
// Enables time synchronization with the host. If set to true will set `tools.syncTime` to `TRUE`.
// Defaults to FALSE.
// Enables time synchronization with the host. Defaults to false.
ToolsSyncTime bool `mapstructure:"tools_sync_time"`
// If sets to true, vSphere will automatically check and upgrade VMware Tools upon a system power cycle.
@ -39,17 +40,20 @@ func (s *StepConfigParams) Run(_ context.Context, state multistep.StateBag) mult
configParams = s.Config.ConfigParams
}
if s.Config.ToolsSyncTime {
configParams["tools.syncTime"] = "TRUE"
}
var info *types.ToolsConfigInfo
if s.Config.ToolsSyncTime || s.Config.ToolsUpgradePolicy {
info = &types.ToolsConfigInfo{}
if s.Config.ToolsUpgradePolicy {
configParams["tools.upgrade.policy"] = "upgradeAtPowerCycle"
}
if s.Config.ToolsSyncTime {
info.SyncTimeWithHost = &s.Config.ToolsSyncTime
}
if s.Config.ToolsUpgradePolicy {
info.ToolsUpgradePolicy = "UpgradeAtPowerCycle"
}
if len(configParams) > 0 {
ui.Say("Adding configuration parameters...")
if err := vm.AddConfigParams(configParams); err != nil {
if err := vm.AddConfigParams(configParams, info); err != nil {
state.Put("error", fmt.Errorf("error adding configuration parameters: %v", err))
return multistep.ActionHalt
}

View File

@ -800,7 +800,7 @@ func (vm *VirtualMachine) addDevice(device types.BaseVirtualDevice) error {
return err
}
func (vm *VirtualMachine) AddConfigParams(params map[string]string) error {
func (vm *VirtualMachine) AddConfigParams(params map[string]string, info *types.ToolsConfigInfo) error {
var confSpec types.VirtualMachineConfigSpec
var ov []types.BaseOptionValue
@ -813,13 +813,19 @@ func (vm *VirtualMachine) AddConfigParams(params map[string]string) error {
}
confSpec.ExtraConfig = ov
task, err := vm.vm.Reconfigure(vm.driver.ctx, confSpec)
if err != nil {
confSpec.Tools = info
if len(confSpec.ExtraConfig) > 0 || confSpec.Tools != nil {
task, err := vm.vm.Reconfigure(vm.driver.ctx, confSpec)
if err != nil {
return err
}
_, err = task.WaitForResult(vm.driver.ctx, nil)
return err
}
_, err = task.WaitForResult(vm.driver.ctx, nil)
return err
return nil
}
func (vm *VirtualMachine) Export() (*nfc.Lease, error) {

View File

@ -3,8 +3,7 @@
- `configuration_parameters` (map[string]string) - configuration_parameters is a direct passthrough to the VSphere API's
ConfigSpec: https://pubs.vmware.com/vi3/sdk/ReferenceGuide/vim.vm.ConfigSpec.html
- `tools_sync_time` (bool) - Enables time synchronization with the host. If set to true will set `tools.syncTime` to `TRUE`.
Defaults to FALSE.
- `tools_sync_time` (bool) - Enables time synchronization with the host. Defaults to false.
- `tools_upgrade_policy` (bool) - If sets to true, vSphere will automatically check and upgrade VMware Tools upon a system power cycle.
If not set, defaults to manual upgrade.