Commit 7a9499e1 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

builder/virtualbox: Attach the hard drive, not quite working yet

parent b9cd48bb
......@@ -19,6 +19,7 @@ func (s *stepCreateDisk) Run(state map[string]interface{}) multistep.StepAction
config := state["config"].(*config)
driver := state["driver"].(Driver)
ui := state["ui"].(packer.Ui)
vmName := state["vmName"].(string)
format := "VDI"
path := filepath.Join(config.OutputDir, fmt.Sprintf("%s.%s", config.VMName, strings.ToLower(format)))
......@@ -41,6 +42,28 @@ func (s *stepCreateDisk) Run(state map[string]interface{}) multistep.StepAction
// Set the path so that we can delete it later
s.diskPath = path
// Add the IDE controller so we can later attach the disk
controllerName := "IDE Controller"
err = driver.VBoxManage("storagectl", vmName, "--name", controllerName, "--add", "ide")
if err != nil {
ui.Error(fmt.Sprintf("Error creating disk controller: %s", err))
return multistep.ActionHalt
}
// Attach the disk to the controller
command = []string{
"storagectl", vmName,
"--storagectl", controllerName,
"--port", "0",
"--device", "0",
"--type", "hdd",
"--medium", path,
}
if err := driver.VBoxManage(command...); err != nil {
ui.Error(fmt.Sprintf("Error attaching hard drive: %s", err))
return multistep.ActionHalt
}
time.Sleep(15 * time.Second)
return multistep.ActionContinue
}
......
......@@ -7,6 +7,9 @@ import (
)
// This step creates the actual virtual machine.
//
// Produces:
// vmName string - The name of the VM
type stepCreateVM struct{
vmName string
}
......@@ -41,6 +44,9 @@ func (s *stepCreateVM) Run(state map[string]interface{}) multistep.StepAction {
}
}
// Set the final name in the state bag so others can use it
state["vmName"] = s.vmName
return multistep.ActionContinue
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment