Revert "Qemu builder disk size as a string"

This reverts commit 1ecfa032ba.
This commit is contained in:
Megan Marsh 2019-10-14 13:08:59 -07:00
parent 44f91c9afc
commit 9c782f4d04
6 changed files with 19 additions and 20 deletions

View File

@ -146,11 +146,9 @@ type Config struct {
// one of the other listed interfaces. Using the `scsi` interface under // one of the other listed interfaces. Using the `scsi` interface under
// these circumstances will cause the build to fail. // these circumstances will cause the build to fail.
DiskInterface string `mapstructure:"disk_interface" required:"false"` DiskInterface string `mapstructure:"disk_interface" required:"false"`
// The size in bytes, suffixes of the first letter of common byte types // The size, in megabytes, of the hard disk to create
// like "k" or "K", "M" for megabytes, G for gigabytes, T for terabytes. // for the VM. By default, this is 40960 (40 GB).
// Will create the of the hard disk of the VM. By default, this is DiskSize uint `mapstructure:"disk_size" required:"false"`
// `40960M` (40 GB).
DiskSize string `mapstructure:"disk_size" required:"false"`
// The cache mode to use for disk. Allowed values include any of // The cache mode to use for disk. Allowed values include any of
// `writethrough`, `writeback`, `none`, `unsafe` or `directsync`. By // `writethrough`, `writeback`, `none`, `unsafe` or `directsync`. By
// default, this is set to `writeback`. // default, this is set to `writeback`.
@ -318,6 +316,7 @@ type Config struct {
// "BUILDNAME" is the name of the build. Currently, no file extension will be // "BUILDNAME" is the name of the build. Currently, no file extension will be
// used unless it is specified in this option. // used unless it is specified in this option.
VMName string `mapstructure:"vm_name" required:"false"` VMName string `mapstructure:"vm_name" required:"false"`
// These are deprecated, but we keep them around for BC // These are deprecated, but we keep them around for BC
// TODO(@mitchellh): remove // TODO(@mitchellh): remove
SSHWaitTimeout time.Duration `mapstructure:"ssh_wait_timeout" required:"false"` SSHWaitTimeout time.Duration `mapstructure:"ssh_wait_timeout" required:"false"`
@ -345,10 +344,11 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
var errs *packer.MultiError var errs *packer.MultiError
warnings := make([]string, 0) warnings := make([]string, 0)
errs = packer.MultiErrorAppend(errs, b.config.ShutdownConfig.Prepare(&b.config.ctx)...) errs = packer.MultiErrorAppend(errs, b.config.ShutdownConfig.Prepare(&b.config.ctx)...)
if b.config.DiskSize == "" || b.config.DiskSize == "0" { if b.config.DiskSize == 0 {
b.config.DiskSize = "40960M" b.config.DiskSize = 40960
} }
if b.config.DiskCache == "" { if b.config.DiskCache == "" {
@ -700,7 +700,7 @@ func (b *Builder) Run(ctx context.Context, ui packer.Ui, hook packer.Hook) (pack
artifact.state["diskPaths"] = diskpaths artifact.state["diskPaths"] = diskpaths
} }
artifact.state["diskType"] = b.config.Format artifact.state["diskType"] = b.config.Format
artifact.state["diskSize"] = b.config.DiskSize artifact.state["diskSize"] = uint64(b.config.DiskSize)
artifact.state["domainType"] = b.config.Accelerator artifact.state["domainType"] = b.config.Accelerator
return artifact, nil return artifact, nil

View File

@ -169,11 +169,11 @@ func TestBuilderPrepare_DiskSize(t *testing.T) {
t.Fatalf("bad err: %s", err) t.Fatalf("bad err: %s", err)
} }
if b.config.DiskSize != "40960M" { if b.config.DiskSize != 40960 {
t.Fatalf("bad size: %s", b.config.DiskSize) t.Fatalf("bad size: %d", b.config.DiskSize)
} }
config["disk_size"] = "60000M" config["disk_size"] = 60000
b = Builder{} b = Builder{}
warns, err = b.Prepare(config) warns, err = b.Prepare(config)
if len(warns) > 0 { if len(warns) > 0 {
@ -183,8 +183,8 @@ func TestBuilderPrepare_DiskSize(t *testing.T) {
t.Fatalf("should not have error: %s", err) t.Fatalf("should not have error: %s", err)
} }
if b.config.DiskSize != "60000M" { if b.config.DiskSize != 60000 {
t.Fatalf("bad size: %s", b.config.DiskSize) t.Fatalf("bad size: %d", b.config.DiskSize)
} }
} }

View File

@ -29,7 +29,7 @@ func (s *stepCreateDisk) Run(ctx context.Context, state multistep.StateBag) mult
ui.Say("Creating required virtual machine disks") ui.Say("Creating required virtual machine disks")
// The 'main' or 'default' disk // The 'main' or 'default' disk
diskFullPaths = append(diskFullPaths, filepath.Join(config.OutputDir, name)) diskFullPaths = append(diskFullPaths, filepath.Join(config.OutputDir, name))
diskSizes = append(diskSizes, fmt.Sprintf("%s", config.DiskSize)) diskSizes = append(diskSizes, fmt.Sprintf("%dM", uint64(config.DiskSize)))
// Additional disks // Additional disks
if len(config.AdditionalDiskSize) > 0 { if len(config.AdditionalDiskSize) > 0 {
for i, diskSize := range config.AdditionalDiskSize { for i, diskSize := range config.AdditionalDiskSize {

View File

@ -23,8 +23,9 @@ func (s *stepResizeDisk) Run(ctx context.Context, state multistep.StateBag) mult
"resize", "resize",
"-f", config.Format, "-f", config.Format,
path, path,
fmt.Sprintf("%s", config.DiskSize), fmt.Sprintf("%vM", config.DiskSize),
} }
if config.DiskImage == false { if config.DiskImage == false {
return multistep.ActionContinue return multistep.ActionContinue
} }

View File

@ -37,7 +37,7 @@ to files, URLS for ISOs and checksums.
"iso_checksum_type": "md5", "iso_checksum_type": "md5",
"output_directory": "output_centos_tdhtest", "output_directory": "output_centos_tdhtest",
"shutdown_command": "echo 'packer' | sudo -S shutdown -P now", "shutdown_command": "echo 'packer' | sudo -S shutdown -P now",
"disk_size": "5000M", "disk_size": 5000,
"format": "qcow2", "format": "qcow2",
"accelerator": "kvm", "accelerator": "kvm",
"http_directory": "path/to/httpdir", "http_directory": "path/to/httpdir",

View File

@ -47,10 +47,8 @@
one of the other listed interfaces. Using the `scsi` interface under one of the other listed interfaces. Using the `scsi` interface under
these circumstances will cause the build to fail. these circumstances will cause the build to fail.
- `disk_size` (string) - The size in bytes, suffixes of the first letter of common byte types - `disk_size` (uint) - The size, in megabytes, of the hard disk to create
like "k" or "K", "M" for megabytes, G for gigabytes, T for terabytes. for the VM. By default, this is 40960 (40 GB).
Will create the of the hard disk of the VM. By default, this is
`40960M` (40 GB).
- `disk_cache` (string) - The cache mode to use for disk. Allowed values include any of - `disk_cache` (string) - The cache mode to use for disk. Allowed values include any of
`writethrough`, `writeback`, `none`, `unsafe` or `directsync`. By `writethrough`, `writeback`, `none`, `unsafe` or `directsync`. By