forked from kandoo/beehive
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample_reply_test.go
64 lines (57 loc) · 1.96 KB
/
example_reply_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
package beehive_test
import (
"fmt"
"github.com/kandoo/beehive"
"github.com/kandoo/beehive/Godeps/_workspace/src/github.com/golang/glog"
"github.com/kandoo/beehive/Godeps/_workspace/src/golang.org/x/net/context"
)
// HelloReply represents a message in our hello world example.
type HelloReply struct {
Name string // Name is the name of the person saying hello.
}
// RcvfReply receives the message and the context.
func RcvfReply(msg beehive.Msg, ctx beehive.RcvContext) error {
// msg is an envelope around the Hello message.
// You can retrieve the Hello, using msg.Data() and then
// you need to assert that its a Hello.
hello := msg.Data().(HelloReply)
// Using ctx.Dict you can get (or create) a dictionary.
dict := ctx.Dict("hello_dict")
// Using Get(), you can get the value associated with
// a key in the dictionary. Keys are always string
// and values are generic interface{}'s.
v, err := dict.Get(hello.Name)
// If there is an error, the entry is not in the
// dictionary. Otherwise, we set cnt based on
// the value we already have in the dictionary
// for that name.
cnt := 0
if err == nil {
cnt = v.(int)
}
// Now we increment the count.
cnt++
// Reply to the message with the count of hellos.
ctx.Reply(msg, cnt)
// Finally we update the count stored in the dictionary.
return dict.Put(hello.Name, cnt)
}
func Example_reply() {
// Create the hello world application and make sure .
app := beehive.NewApp("hello-world", beehive.Persistent(1))
// Register the handler for Hello messages.
app.HandleFunc(HelloReply{}, beehive.RuntimeMap(RcvfReply), RcvfReply)
// Start the default hive.
go beehive.Start()
defer beehive.Stop()
name := "your name"
for i := 0; i < 2; i++ {
// Sync sends the Hello message and waits until it receives the reply.
res, err := beehive.Sync(context.TODO(), HelloReply{Name: name})
if err != nil {
glog.Fatalf("error in sending Hello: %v", err)
}
cnt := res.(int)
fmt.Printf("hello %s (%d)!\n", name, cnt)
}
}