Commit c0f64f3a authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

builder/amazon/chroot: let go of flock earlier for parallelism

parent 750b7883
...@@ -127,6 +127,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe ...@@ -127,6 +127,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
&StepPrepareDevice{}, &StepPrepareDevice{},
&StepCreateVolume{}, &StepCreateVolume{},
&StepAttachVolume{}, &StepAttachVolume{},
&StepEarlyUnflock{},
&StepMountDevice{}, &StepMountDevice{},
&StepMountExtra{}, &StepMountExtra{},
&StepCopyFiles{}, &StepCopyFiles{},
......
package chroot
import (
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/packer/packer"
"log"
)
// StepEarlyUnflock unlocks the flock.
type StepEarlyUnflock struct{}
func (s *StepEarlyUnflock) Run(state map[string]interface{}) multistep.StepAction {
cleanup := state["flock_cleanup"].(Cleanup)
ui := state["ui"].(packer.Ui)
log.Println("Unlocking file lock...")
if err := cleanup.CleanupFunc(state); err != nil {
err := fmt.Errorf("Error unlocking file lock: %s", err)
state["error"] = err
ui.Error(err.Error())
return multistep.ActionHalt
}
return multistep.ActionContinue
}
func (s *StepEarlyUnflock) Cleanup(state map[string]interface{}) {}
...@@ -10,6 +10,9 @@ import ( ...@@ -10,6 +10,9 @@ import (
) )
// StepFlock provisions the instance within a chroot. // StepFlock provisions the instance within a chroot.
//
// Produces:
// flock_cleanup Cleanup - To perform early cleanup
type StepFlock struct { type StepFlock struct {
fh *os.File fh *os.File
} }
...@@ -46,14 +49,24 @@ func (s *StepFlock) Run(state map[string]interface{}) multistep.StepAction { ...@@ -46,14 +49,24 @@ func (s *StepFlock) Run(state map[string]interface{}) multistep.StepAction {
// the lock. // the lock.
s.fh = f s.fh = f
state["flock_cleanup"] = s
return multistep.ActionContinue return multistep.ActionContinue
} }
func (s *StepFlock) Cleanup(state map[string]interface{}) { func (s *StepFlock) Cleanup(state map[string]interface{}) {
s.CleanupFunc(state)
}
func (s *StepFlock) CleanupFunc(state map[string]interface{}) error {
if s.fh == nil { if s.fh == nil {
return return nil
} }
log.Printf("Unlocking: %s", s.fh.Name()) log.Printf("Unlocking: %s", s.fh.Name())
unlockFile(s.fh) if err := unlockFile(s.fh); err != nil {
return err
}
s.fh = nil
return nil
} }
package chroot
import "testing"
func TestFlockCleanupFunc_ImplementsCleanupFunc(t *testing.T) {
var raw interface{}
raw = new(StepFlock)
if _, ok := raw.(Cleanup); !ok {
t.Fatalf("cleanup func should be a CleanupFunc")
}
}
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