forked from nats-rpc/nrpc
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathhelloworld_test.go
71 lines (65 loc) · 2.22 KB
/
helloworld_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
package nrpc
import (
"bytes"
"os"
"os/exec"
"testing"
"time"
natsserver "github.com/nats-io/nats-server/v2/test"
)
func TestHelloWorldExample(t *testing.T) {
s := natsserver.RunRandClientPortServer()
defer s.Shutdown()
// make sure protoc-gen-nrpc is up to date
installGenRPC := exec.Command("go", "install", "./protoc-gen-nrpc")
if out, err := installGenRPC.CombinedOutput(); err != nil {
t.Fatal("Install protoc-gen-nrpc failed", err, ":\n", string(out))
}
// generate the sources
generate := exec.Command("go", "generate", "./examples/helloworld/helloworld")
if out, err := generate.CombinedOutput(); err != nil {
t.Fatal("Generate failed", err, ":\n", string(out))
}
// build
buildServer := exec.Command("go", "build",
"-o", "./examples/helloworld/greeter_server/greeter_server",
"./examples/helloworld/greeter_server")
if out, err := buildServer.CombinedOutput(); err != nil {
t.Fatal("Buid server failed", err, string(out))
}
buildClient := exec.Command("go", "build",
"-o", "./examples/helloworld/greeter_client/greeter_client",
"./examples/helloworld/greeter_client")
if out, err := buildClient.CombinedOutput(); err != nil {
t.Fatal("Buid client failed", err, string(out))
}
// run the server
server := exec.Command("./examples/helloworld/greeter_server/greeter_server", s.ClientURL())
var serverStdout bytes.Buffer
server.Stdout = &serverStdout
server.Start()
defer func() {
if server.Process != nil {
server.Process.Signal(os.Interrupt)
}
if err := server.Wait(); err != nil {
t.Error("Server run failed:", err)
t.Error("Server output:", serverStdout.String())
}
}()
// Give the server a little time to be ready to handle requests
time.Sleep(250 * time.Millisecond)
// run the client and check its output
client := exec.Command("./examples/helloworld/greeter_client/greeter_client", s.ClientURL())
timeout := time.AfterFunc(time.Second, func() { client.Process.Kill() })
out, err := client.CombinedOutput()
timeout.Stop()
if err != nil {
t.Fatal("Run client failed with:", err, ", output was:\n", string(out))
}
expectedOuput := "Greeting: Hello world\n"
if string(out) != expectedOuput {
t.Errorf("Wrong client output. Expected '%s', got '%s'",
expectedOuput, string(out))
}
}