| | |
| | |
| | |
| |
|
| | |
| |
|
| | package testing |
| |
|
| | import ( |
| | "fmt" |
| | "io" |
| | "os" |
| | "strings" |
| | "time" |
| | ) |
| |
|
| | |
| | |
| | func runExample(eg InternalExample) (ok bool) { |
| | if chatty.on { |
| | fmt.Printf("%s=== RUN %s\n", chatty.prefix(), eg.Name) |
| | } |
| |
|
| | |
| | |
| | stdout := os.Stdout |
| | f := createTempFile(eg.Name) |
| | os.Stdout = f |
| | finished := false |
| | start := time.Now() |
| |
|
| | |
| | defer func() { |
| | timeSpent := time.Since(start) |
| |
|
| | |
| | os.Stdout = stdout |
| | var buf strings.Builder |
| | _, seekErr := f.Seek(0, io.SeekStart) |
| | _, readErr := io.Copy(&buf, f) |
| | out := buf.String() |
| | f.Close() |
| | os.Remove(f.Name()) |
| | if seekErr != nil { |
| | fmt.Fprintf(os.Stderr, "testing: seek temp file: %v\n", seekErr) |
| | os.Exit(1) |
| | } |
| | if readErr != nil { |
| | fmt.Fprintf(os.Stderr, "testing: read temp file: %v\n", readErr) |
| | os.Exit(1) |
| | } |
| |
|
| | err := recover() |
| | ok = eg.processRunResult(out, timeSpent, finished, err) |
| | }() |
| |
|
| | |
| | eg.F() |
| | finished = true |
| | return |
| | } |
| |
|
| | func createTempFile(exampleName string) *os.File { |
| | for i := 0; ; i++ { |
| | name := fmt.Sprintf("%s/go-example-stdout-%s-%d.txt", os.TempDir(), exampleName, i) |
| | f, err := os.OpenFile(name, os.O_RDWR|os.O_CREATE|os.O_EXCL, 0600) |
| | if err != nil { |
| | if os.IsExist(err) { |
| | continue |
| | } |
| | fmt.Fprintf(os.Stderr, "testing: open temp file: %v\n", err) |
| | os.Exit(1) |
| | } |
| | return f |
| | } |
| | } |
| |
|