fix: parse error message when running command

This commit is contained in:
Jan De Dobbeleer 2020-12-30 20:01:22 +01:00 committed by Jan De Dobbeleer
parent 23eb73cd69
commit e0a4482d4b

View file

@ -4,7 +4,9 @@ import (
"bufio" "bufio"
"bytes" "bytes"
"context" "context"
"errors"
"fmt" "fmt"
"io"
"io/ioutil" "io/ioutil"
"log" "log"
"net/http" "net/http"
@ -153,21 +155,10 @@ func (env *environment) getPlatform() string {
} }
func (env *environment) runCommand(command string, args ...string) (string, error) { func (env *environment) runCommand(command string, args ...string) (string, error) {
cmd := exec.Command(command, args...) getOutputString := func(io io.ReadCloser) string {
stdout, err := cmd.StdoutPipe()
if err != nil {
log.Fatal(err)
}
err = cmd.Start()
if err != nil {
return "", err
}
defer func() {
_ = cmd.Process.Kill()
}()
output := new(bytes.Buffer) output := new(bytes.Buffer)
defer output.Reset() defer output.Reset()
buf := bufio.NewReader(stdout) buf := bufio.NewReader(io)
multiline := false multiline := false
for { for {
line, _, _ := buf.ReadLine() line, _, _ := buf.ReadLine()
@ -180,7 +171,30 @@ func (env *environment) runCommand(command string, args ...string) (string, erro
output.Write(line) output.Write(line)
multiline = true multiline = true
} }
return output.String(), nil return output.String()
}
cmd := exec.Command(command, args...)
stdout, err := cmd.StdoutPipe()
if err != nil {
log.Fatal(err)
}
stderr, err := cmd.StderrPipe()
if err != nil {
log.Fatal(err)
}
err = cmd.Start()
if err != nil {
return "", err
}
defer func() {
_ = cmd.Process.Kill()
}()
stdoutString := getOutputString(stdout)
stderrString := getOutputString(stderr)
if stderrString != "" {
return "", errors.New(stderrString)
}
return stdoutString, nil
} }
func (env *environment) runShellCommand(shell, command string) string { func (env *environment) runShellCommand(shell, command string) string {