forked from kvz/logstreamer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogstreamer_test.go
83 lines (68 loc) · 2 KB
/
logstreamer_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package logstreamer
import (
"fmt"
"log"
"os"
"os/exec"
"testing"
)
func TestLogstreamerOk(t *testing.T) {
// Create a logger (your app probably already has one)
logger := log.New(os.Stdout, "--> ", log.Ldate|log.Ltime)
// Setup a streamer that we'll pipe cmd.Stdout to
logStreamerOut := NewLogstreamer(logger, "stdout", false)
// Setup a streamer that we'll pipe cmd.Stderr to.
// We want to record/buffer anything that's written to this (3rd argument true)
logStreamerErr := NewLogstreamer(logger, "stderr", true)
// Execute something that succeeds
cmd := exec.Command(
"ls",
"-al",
)
cmd.Stderr = logStreamerErr
cmd.Stdout = logStreamerOut
// Reset any error we recorded
logStreamerErr.FlushRecord()
// Execute command
err := cmd.Start()
// Failed to spawn?
if err != nil {
t.Fatal("ERROR could not spawn command.", err.Error())
}
// Failed to execute?
err = cmd.Wait()
if err != nil {
t.Fatal("ERROR command finished with error. ", err.Error(), logStreamerErr.FlushRecord())
}
}
func TestLogstreamerErr(t *testing.T) {
// Create a logger (your app probably already has one)
logger := log.New(os.Stdout, "--> ", log.Ldate|log.Ltime)
// Setup a streamer that we'll pipe cmd.Stdout to
logStreamerOut := NewLogstreamer(logger, "stdout", false)
// Setup a streamer that we'll pipe cmd.Stderr to.
// We want to record/buffer anything that's written to this (3rd argument true)
logStreamerErr := NewLogstreamer(logger, "stderr", true)
// Execute something that succeeds
cmd := exec.Command(
"ls",
"nonexisting",
)
cmd.Stderr = logStreamerErr
cmd.Stdout = logStreamerOut
// Reset any error we recorded
logStreamerErr.FlushRecord()
// Execute command
err := cmd.Start()
// Failed to spawn?
if err != nil {
logger.Print("ERROR could not spawn command. ")
}
// Failed to execute?
err = cmd.Wait()
if err != nil {
fmt.Printf("Good. command finished with %s. %s. \n", err.Error(), logStreamerErr.FlushRecord())
} else {
t.Fatal("This command should have failed")
}
}