
% go test -race -v -short === RUN TestBuild ================== WARNING: DATA RACE Write at 0x00c4201379a0 by goroutine 9: os.(*file).close() /usr/local/go/src/os/file_unix.go:143 +0x10a os.(*File).Close() /usr/local/go/src/os/file_unix.go:132 +0x55 os/exec.(*Cmd).closeDescriptors() /usr/local/go/src/os/exec/exec.go:263 +0x67 os/exec.(*Cmd).Wait() /usr/local/go/src/os/exec/exec.go:448 +0x2b8 github.com/derekparker/delve/cmd/dlv.TestBuild.func1() /home/kbuilder/go/src/github.com/derekparker/delve/cmd/dlv/dlv_test.go:82 +0x8e github.com/derekparker/delve/cmd/dlv.TestBuild() /home/kbuilder/go/src/github.com/derekparker/delve/cmd/dlv/dlv_test.go:104 +0xb6a testing.tRunner() /usr/local/go/src/testing/testing.go:657 +0x107 Previous read at 0x00c4201379a0 by goroutine 12: os.(*File).Read() /usr/local/go/src/os/file.go:98 +0x70 bufio.(*Scanner).Scan() /usr/local/go/src/bufio/scan.go:207 +0x539 github.com/derekparker/delve/cmd/dlv.TestBuild.func2() /home/kbuilder/go/src/github.com/derekparker/delve/cmd/dlv/dlv_test.go:93 +0x38 Change-Id: I09d188dbf964fe4af0b33b6a8fcfe51396176b7e
108 lines
2.4 KiB
Go
108 lines
2.4 KiB
Go
package main
|
|
|
|
import (
|
|
"bufio"
|
|
"flag"
|
|
"os"
|
|
"os/exec"
|
|
"path/filepath"
|
|
"runtime"
|
|
"strings"
|
|
"testing"
|
|
|
|
protest "github.com/derekparker/delve/pkg/proc/test"
|
|
"github.com/derekparker/delve/service/rpc2"
|
|
)
|
|
|
|
var testBackend string
|
|
|
|
func TestMain(m *testing.M) {
|
|
flag.StringVar(&testBackend, "backend", "", "selects backend")
|
|
flag.Parse()
|
|
if testBackend == "" {
|
|
testBackend = os.Getenv("PROCTEST")
|
|
if testBackend == "" {
|
|
testBackend = "native"
|
|
}
|
|
}
|
|
os.Exit(m.Run())
|
|
}
|
|
|
|
func assertNoError(err error, t testing.TB, s string) {
|
|
if err != nil {
|
|
_, file, line, _ := runtime.Caller(1)
|
|
fname := filepath.Base(file)
|
|
t.Fatalf("failed assertion at %s:%d: %s - %s\n", fname, line, s, err)
|
|
}
|
|
}
|
|
|
|
func goEnv(name string) string {
|
|
if val := os.Getenv(name); val != "" {
|
|
return val
|
|
}
|
|
val, err := exec.Command("go", "env", name).Output()
|
|
if err != nil {
|
|
panic(err) // the Go tool was tested to work earlier
|
|
}
|
|
return strings.TrimSpace(string(val))
|
|
}
|
|
|
|
func TestBuild(t *testing.T) {
|
|
const listenAddr = "localhost:40573"
|
|
var err error
|
|
makedir := filepath.Join(goEnv("GOPATH"), "src", "github.com", "derekparker", "delve")
|
|
for _, makeProgram := range []string{"make", "mingw32-make"} {
|
|
var out []byte
|
|
cmd := exec.Command(makeProgram, "build")
|
|
cmd.Dir = makedir
|
|
out, err = cmd.CombinedOutput()
|
|
if err == nil {
|
|
break
|
|
} else {
|
|
t.Logf("makefile error %s (%s): %v", makeProgram, makedir, err)
|
|
t.Logf("output %s", string(out))
|
|
}
|
|
}
|
|
assertNoError(err, t, "make")
|
|
dlvbin := filepath.Join(makedir, "dlv")
|
|
defer os.Remove(dlvbin)
|
|
|
|
fixtures := protest.FindFixturesDir()
|
|
|
|
buildtestdir := filepath.Join(fixtures, "buildtest")
|
|
|
|
cmd := exec.Command(dlvbin, "debug", "--headless=true", "--listen="+listenAddr, "--api-version=2", "--backend="+testBackend)
|
|
cmd.Dir = buildtestdir
|
|
stdout, err := cmd.StdoutPipe()
|
|
assertNoError(err, t, "stdout pipe")
|
|
cmd.Start()
|
|
done := make(chan struct{})
|
|
defer func() {
|
|
if runtime.GOOS != "windows" {
|
|
cmd.Process.Signal(os.Interrupt)
|
|
} else {
|
|
// sending os.Interrupt on windows is not supported
|
|
cmd.Process.Kill()
|
|
}
|
|
<-done
|
|
cmd.Wait()
|
|
}()
|
|
|
|
scan := bufio.NewScanner(stdout)
|
|
// wait for the debugger to start
|
|
scan.Scan()
|
|
go func() {
|
|
for scan.Scan() {
|
|
// keep pipe empty
|
|
}
|
|
close(done)
|
|
}()
|
|
|
|
client := rpc2.NewClient(listenAddr)
|
|
state := <-client.Continue()
|
|
|
|
if !state.Exited {
|
|
t.Fatal("Program did not exit")
|
|
}
|
|
}
|