|
|
package znet
import ( "fmt" "io" "net" "testing" "time"
"github.com/aceld/zinx/ziface" )
// run in terminal:
// go test -v ./znet -run=TestServer
/* 模拟客户端 */ func ClientTest(i uint32) {
fmt.Println("Client Test ... start") //3秒之后发起测试请求,给服务端开启服务的机会
time.Sleep(3 * time.Second)
conn, err := net.Dial("tcp", "127.0.0.1:8999") if err != nil { fmt.Println("client start err, exit!") return }
for { dp := NewDataPack() msg, _ := dp.Pack(NewMsgPackage(i, []byte("client test message"))) _, err := conn.Write(msg) if err != nil { fmt.Println("client write err: ", err) return }
//先读出流中的head部分
headData := make([]byte, dp.GetHeadLen()) _, err = io.ReadFull(conn, headData) if err != nil { fmt.Println("client read head err: ", err) return }
// 将headData字节流 拆包到msg中
msgHead, err := dp.Unpack(headData) if err != nil { fmt.Println("client unpack head err: ", err) return }
if msgHead.GetDataLen() > 0 { //msg 是有data数据的,需要再次读取data数据
msg := msgHead.(*Message) msg.Data = make([]byte, msg.GetDataLen())
//根据dataLen从io中读取字节流
_, err := io.ReadFull(conn, msg.Data) if err != nil { fmt.Println("client unpack data err") return }
fmt.Printf("==> Client receive Msg: ID = %d, len = %d , data = %s\n", msg.ID, msg.DataLen, msg.Data) }
time.Sleep(time.Second) } }
/* 模拟服务器端 */
//ping test 自定义路由
type PingRouter struct { BaseRouter }
//Test PreHandle
func (this *PingRouter) PreHandle(request ziface.IRequest) { fmt.Println("Call Router PreHandle") err := request.GetConnection().SendMsg(1, []byte("before ping ....\n")) if err != nil { fmt.Println("preHandle SendMsg err: ", err) } }
//Test Handle
func (this *PingRouter) Handle(request ziface.IRequest) { fmt.Println("Call PingRouter Handle") //先读取客户端的数据,再回写ping...ping...ping
fmt.Println("recv from client : msgID=", request.GetMsgID(), ", data=", string(request.GetData()))
err := request.GetConnection().SendMsg(1, []byte("ping...ping...ping\n")) if err != nil { fmt.Println("Handle SendMsg err: ", err) } }
//Test PostHandle
func (this *PingRouter) PostHandle(request ziface.IRequest) { fmt.Println("Call Router PostHandle") err := request.GetConnection().SendMsg(1, []byte("After ping .....\n")) if err != nil { fmt.Println("Post SendMsg err: ", err) } }
type HelloRouter struct { BaseRouter }
func (this *HelloRouter) Handle(request ziface.IRequest) { fmt.Println("call helloRouter Handle") fmt.Printf("receive from client msgID=%d, data=%s\n", request.GetMsgID(), string(request.GetData()))
err := request.GetConnection().SendMsg(2, []byte("hello zix hello Router")) if err != nil { fmt.Println(err) } }
func DoConnectionBegin(conn ziface.IConnection) { fmt.Println("DoConnectionBegin is Called ... ") err := conn.SendMsg(2, []byte("DoConnection BEGIN...")) if err != nil { fmt.Println(err) } }
//连接断开的时候执行
func DoConnectionLost(conn ziface.IConnection) { fmt.Println("DoConnectionLost is Called ... ") }
func TestServer(t *testing.T) { //创建一个server句柄
s := NewServer()
//注册链接hook回调函数
s.SetOnConnStart(DoConnectionBegin) s.SetOnConnStop(DoConnectionLost)
// 多路由
s.AddRouter(1, &PingRouter{}) s.AddRouter(2, &HelloRouter{})
// 客户端测试
go ClientTest(1) go ClientTest(2)
//2 开启服务
go s.Serve()
select { case <-time.After(time.Second * 10): return } }
|