packer/plugin: flush os.Stderr whenever a plugin ends
This commit is contained in:
parent
ce0322662d
commit
8c341b0c78
|
@ -244,9 +244,18 @@ func (c *Client) Start() (address string, err error) {
|
||||||
|
|
||||||
// Start goroutine to wait for process to exit
|
// Start goroutine to wait for process to exit
|
||||||
go func() {
|
go func() {
|
||||||
|
// Make sure we close the write end of our stderr listener so
|
||||||
|
// that the log goroutine ends properly.
|
||||||
defer stderr_w.Close()
|
defer stderr_w.Close()
|
||||||
|
|
||||||
|
// Wait for the command to end.
|
||||||
cmd.Wait()
|
cmd.Wait()
|
||||||
|
|
||||||
|
// Log and make sure to flush the logs write away
|
||||||
log.Printf("%s: plugin process exited\n", cmd.Path)
|
log.Printf("%s: plugin process exited\n", cmd.Path)
|
||||||
|
os.Stderr.Sync()
|
||||||
|
|
||||||
|
// Mark that we exited
|
||||||
c.exited = true
|
c.exited = true
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue