builder/qemu: log VM output

This commit is contained in:
Mitchell Hashimoto 2013-11-05 17:59:09 -08:00
parent 3e58ca4c98
commit 7370acf9e8
1 changed files with 28 additions and 4 deletions

View File

@ -1,15 +1,18 @@
package qemu
import (
"bufio"
"bytes"
"errors"
"fmt"
"github.com/mitchellh/multistep"
"io"
"log"
"os/exec"
"regexp"
"strings"
"time"
"unicode"
)
type DriverCancelCallback func(state multistep.StateBag) bool
@ -92,20 +95,24 @@ func (d *QemuDriver) Stop(name string) error {
}
func (d *QemuDriver) Qemu(vmName string, qemuArgs ...string) error {
var stdout, stderr bytes.Buffer
stdout_r, stdout_w := io.Pipe()
stderr_r, stderr_w := io.Pipe()
log.Printf("Executing %s: %#v", d.qemuPath, qemuArgs)
ds := d.getDriverState(vmName)
ds.cmd = exec.Command(d.qemuPath, qemuArgs...)
ds.cmd.Stdout = &stdout
ds.cmd.Stderr = &stderr
ds.cmd.Stdout = stdout_w
ds.cmd.Stderr = stderr_w
go logReader("Qemu stdout", stdout_r)
go logReader("Qemu stderr", stderr_r)
err := ds.cmd.Start()
if err != nil {
err = fmt.Errorf("Error starting VM: %s", err)
} else {
log.Printf("---- Started Qemu ------- PID = ", ds.cmd.Process.Pid)
log.Printf("---- Started Qemu ------- PID = %d", ds.cmd.Process.Pid)
ds.cancelChan = make(chan struct{})
@ -114,6 +121,8 @@ func (d *QemuDriver) Qemu(vmName string, qemuArgs ...string) error {
// start the virtual machine in the background
go func() {
defer stderr_w.Close()
defer stdout_w.Close()
ds.waitDone <- ds.cmd.Wait()
}()
}
@ -242,3 +251,18 @@ func (d *QemuDriver) Version() (string, error) {
log.Printf("Qemu version: %s", matches[0])
return matches[0], nil
}
func logReader(name string, r io.Reader) {
bufR := bufio.NewReader(r)
for {
line, err := bufR.ReadString('\n')
if line != "" {
line = strings.TrimRightFunc(line, unicode.IsSpace)
log.Printf("%s: %s", name, line)
}
if err == io.EOF {
break
}
}
}