| // run |
| |
| // +build !nacl,!js,!gccgo |
| |
| // Copyright 2019 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| // |
| // Ensure that deadlock detection can still |
| // run even with an import of "_ os/signal". |
| |
| package main |
| |
| import ( |
| "bytes" |
| "context" |
| "io/ioutil" |
| "log" |
| "os" |
| "os/exec" |
| "path/filepath" |
| "time" |
| ) |
| |
| const prog = ` |
| package main |
| |
| import _ "os/signal" |
| |
| func main() { |
| c := make(chan int) |
| c <- 1 |
| } |
| ` |
| |
| func main() { |
| dir, err := ioutil.TempDir("", "21576") |
| if err != nil { |
| log.Fatal(err) |
| } |
| defer os.RemoveAll(dir) |
| |
| file := filepath.Join(dir, "main.go") |
| if err := ioutil.WriteFile(file, []byte(prog), 0655); err != nil { |
| log.Fatalf("Write error %v", err) |
| } |
| |
| // Using a timeout of 1 minute in case other factors might slow |
| // down the start of "go run". See https://golang.org/issue/34836. |
| ctx, cancel := context.WithTimeout(context.Background(), time.Minute) |
| defer cancel() |
| |
| cmd := exec.CommandContext(ctx, "go", "run", file) |
| output, err := cmd.CombinedOutput() |
| if err == nil { |
| log.Fatalf("Passed, expected an error") |
| } |
| |
| want := []byte("fatal error: all goroutines are asleep - deadlock!") |
| if !bytes.Contains(output, want) { |
| log.Fatalf("Unmatched error message %q:\nin\n%s\nError: %v", want, output, err) |
| } |
| } |