support wait_snapshot_ready_timeout for much bigger disk
This commit is contained in:
parent
3c2c13a021
commit
3c1395eb04
|
@ -172,12 +172,15 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
|
||||||
})
|
})
|
||||||
|
|
||||||
if b.config.AlicloudImageIgnoreDataDisks {
|
if b.config.AlicloudImageIgnoreDataDisks {
|
||||||
steps = append(steps, &stepCreateAlicloudSnapshot{})
|
steps = append(steps, &stepCreateAlicloudSnapshot{
|
||||||
|
WaitSnapshotReadyTimeout: b.getSnapshotReadyTimeout(),
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
steps = append(steps,
|
steps = append(steps,
|
||||||
&stepCreateAlicloudImage{
|
&stepCreateAlicloudImage{
|
||||||
AlicloudImageIgnoreDataDisks: b.config.AlicloudImageIgnoreDataDisks,
|
AlicloudImageIgnoreDataDisks: b.config.AlicloudImageIgnoreDataDisks,
|
||||||
|
WaitSnapshotReadyTimeout: b.getSnapshotReadyTimeout(),
|
||||||
},
|
},
|
||||||
&stepCreateTags{
|
&stepCreateTags{
|
||||||
Tags: b.config.AlicloudImageTags,
|
Tags: b.config.AlicloudImageTags,
|
||||||
|
@ -253,3 +256,11 @@ func (b *Builder) isUserDataNeeded() bool {
|
||||||
func (b *Builder) isKeyPairNeeded() bool {
|
func (b *Builder) isKeyPairNeeded() bool {
|
||||||
return b.config.Comm.SSHKeyPairName != "" || b.config.Comm.SSHTemporaryKeyPairName != ""
|
return b.config.Comm.SSHKeyPairName != "" || b.config.Comm.SSHTemporaryKeyPairName != ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (b *Builder) getSnapshotReadyTimeout() int {
|
||||||
|
if b.config.WaitSnapshotReadyTimeout > 0 {
|
||||||
|
return b.config.WaitSnapshotReadyTimeout
|
||||||
|
}
|
||||||
|
|
||||||
|
return ALICLOUD_DEFAULT_LONG_TIMEOUT
|
||||||
|
}
|
||||||
|
|
|
@ -195,3 +195,40 @@ func TestBuilderPrepare_IgnoreDataDisks(t *testing.T) {
|
||||||
t.Fatalf("image_ignore_data_disks is not set properly, expect: %t, actual: %t", true, b.config.AlicloudImageIgnoreDataDisks)
|
t.Fatalf("image_ignore_data_disks is not set properly, expect: %t, actual: %t", true, b.config.AlicloudImageIgnoreDataDisks)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestBuilderPrepare_WaitSnapshotReadyTimeout(t *testing.T) {
|
||||||
|
var b Builder
|
||||||
|
config := testBuilderConfig()
|
||||||
|
|
||||||
|
warnings, err := b.Prepare(config)
|
||||||
|
if len(warnings) > 0 {
|
||||||
|
t.Fatalf("bad: %#v", warnings)
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("should not have error: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if b.config.WaitSnapshotReadyTimeout != 0 {
|
||||||
|
t.Fatalf("wait_snapshot_ready_timeout is not set properly, expect: %d, actual: %d", 0, b.config.WaitSnapshotReadyTimeout)
|
||||||
|
}
|
||||||
|
if b.getSnapshotReadyTimeout() != ALICLOUD_DEFAULT_LONG_TIMEOUT {
|
||||||
|
t.Fatalf("default timeout is not set properly, expect: %d, actual: %d", ALICLOUD_DEFAULT_LONG_TIMEOUT, b.getSnapshotReadyTimeout())
|
||||||
|
}
|
||||||
|
|
||||||
|
config["wait_snapshot_ready_timeout"] = ALICLOUD_DEFAULT_TIMEOUT
|
||||||
|
warnings, err = b.Prepare(config)
|
||||||
|
if len(warnings) > 0 {
|
||||||
|
t.Fatalf("bad: %#v", warnings)
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("should not have error: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if b.config.WaitSnapshotReadyTimeout != ALICLOUD_DEFAULT_TIMEOUT {
|
||||||
|
t.Fatalf("wait_snapshot_ready_timeout is not set properly, expect: %d, actual: %d", ALICLOUD_DEFAULT_TIMEOUT, b.config.WaitSnapshotReadyTimeout)
|
||||||
|
}
|
||||||
|
|
||||||
|
if b.getSnapshotReadyTimeout() != ALICLOUD_DEFAULT_TIMEOUT {
|
||||||
|
t.Fatalf("default timeout is not set properly, expect: %d, actual: %d", ALICLOUD_DEFAULT_TIMEOUT, b.getSnapshotReadyTimeout())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -32,6 +32,7 @@ type RunConfig struct {
|
||||||
InstanceName string `mapstructure:"instance_name"`
|
InstanceName string `mapstructure:"instance_name"`
|
||||||
InternetChargeType string `mapstructure:"internet_charge_type"`
|
InternetChargeType string `mapstructure:"internet_charge_type"`
|
||||||
InternetMaxBandwidthOut int `mapstructure:"internet_max_bandwidth_out"`
|
InternetMaxBandwidthOut int `mapstructure:"internet_max_bandwidth_out"`
|
||||||
|
WaitSnapshotReadyTimeout int `mapstructure:"wait_snapshot_ready_timeout"`
|
||||||
|
|
||||||
// Communicator settings
|
// Communicator settings
|
||||||
Comm communicator.Config `mapstructure:",squash"`
|
Comm communicator.Config `mapstructure:",squash"`
|
||||||
|
|
|
@ -12,6 +12,7 @@ import (
|
||||||
|
|
||||||
type stepCreateAlicloudImage struct {
|
type stepCreateAlicloudImage struct {
|
||||||
AlicloudImageIgnoreDataDisks bool
|
AlicloudImageIgnoreDataDisks bool
|
||||||
|
WaitSnapshotReadyTimeout int
|
||||||
image *ecs.ImageType
|
image *ecs.ImageType
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,8 +50,7 @@ func (s *stepCreateAlicloudImage) Run(_ context.Context, state multistep.StateBa
|
||||||
ui.Error(err.Error())
|
ui.Error(err.Error())
|
||||||
return multistep.ActionHalt
|
return multistep.ActionHalt
|
||||||
}
|
}
|
||||||
err = client.WaitForImageReady(common.Region(config.AlicloudRegion),
|
err = client.WaitForImageReady(common.Region(config.AlicloudRegion), imageId, s.WaitSnapshotReadyTimeout)
|
||||||
imageId, ALICLOUD_DEFAULT_LONG_TIMEOUT)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
err := fmt.Errorf("Timeout waiting for image to be created: %s", err)
|
err := fmt.Errorf("Timeout waiting for image to be created: %s", err)
|
||||||
state.Put("error", err)
|
state.Put("error", err)
|
||||||
|
|
|
@ -11,7 +11,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type stepCreateAlicloudSnapshot struct {
|
type stepCreateAlicloudSnapshot struct {
|
||||||
snapshot *ecs.SnapshotType
|
snapshot *ecs.SnapshotType
|
||||||
|
WaitSnapshotReadyTimeout int
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *stepCreateAlicloudSnapshot) Run(_ context.Context, state multistep.StateBag) multistep.StepAction {
|
func (s *stepCreateAlicloudSnapshot) Run(_ context.Context, state multistep.StateBag) multistep.StepAction {
|
||||||
|
@ -44,8 +45,7 @@ func (s *stepCreateAlicloudSnapshot) Run(_ context.Context, state multistep.Stat
|
||||||
return halt(state, err, "Error creating snapshot")
|
return halt(state, err, "Error creating snapshot")
|
||||||
}
|
}
|
||||||
|
|
||||||
err = client.WaitForSnapShotReady(common.Region(config.AlicloudRegion),
|
err = client.WaitForSnapShotReady(common.Region(config.AlicloudRegion), snapshotId, s.WaitSnapshotReadyTimeout)
|
||||||
snapshotId, ALICLOUD_DEFAULT_LONG_TIMEOUT)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return halt(state, err, "Timeout waiting for snapshot to be created")
|
return halt(state, err, "Timeout waiting for snapshot to be created")
|
||||||
}
|
}
|
||||||
|
|
|
@ -153,6 +153,10 @@ builder.
|
||||||
any circumstance that default data disks with instance types are not concerned.
|
any circumstance that default data disks with instance types are not concerned.
|
||||||
The default value is false.
|
The default value is false.
|
||||||
|
|
||||||
|
- `wait_snapshot_ready_timeout`(number) - Timeout of creating snapshot(s). The
|
||||||
|
default timeout is 3600 seconds if this option is not set or is set to 0. For
|
||||||
|
those disks containing lots of data, it may require a higher timeout value.
|
||||||
|
|
||||||
- `image_force_delete` (boolean) - If this value is true, when the target
|
- `image_force_delete` (boolean) - If this value is true, when the target
|
||||||
image name is duplicated with an existing image, it will delete the
|
image name is duplicated with an existing image, it will delete the
|
||||||
existing image and then create the target image, otherwise, the creation
|
existing image and then create the target image, otherwise, the creation
|
||||||
|
|
Loading…
Reference in New Issue