123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- package mux
- import (
- "log"
- "net"
- "net/http"
- _ "net/http/pprof"
- "testing"
- "time"
- "github.com/astaxie/beego/logs"
- "github.com/cnlh/nps/lib/common"
- "github.com/cnlh/nps/lib/pool"
- )
- var conn1 net.Conn
- var conn2 net.Conn
- func TestNewMux(t *testing.T) {
- go func() {
- http.ListenAndServe("0.0.0.0:8889", nil)
- }()
- logs.EnableFuncCallDepth(true)
- logs.SetLogFuncCallDepth(3)
- server()
- client()
- time.Sleep(time.Second * 3)
- go func() {
- m2 := NewMux(conn2, "tcp")
- for {
- c, err := m2.Accept()
- if err != nil {
- log.Fatalln(err)
- }
- go func(c net.Conn) {
- c2, err := net.Dial("tcp", "127.0.0.1:8082")
- if err != nil {
- log.Fatalln(err)
- }
- go common.CopyBuffer(c2, c)
- common.CopyBuffer(c, c2)
- c.Close()
- c2.Close()
- }(c)
- }
- }()
- go func() {
- m1 := NewMux(conn1, "tcp")
- l, err := net.Listen("tcp", "127.0.0.1:7777")
- if err != nil {
- log.Fatalln(err)
- }
- for {
- conn, err := l.Accept()
- if err != nil {
- log.Fatalln(err)
- }
- go func(conn net.Conn) {
- tmpCpnn, err := m1.NewConn()
- if err != nil {
- log.Fatalln(err)
- }
- go common.CopyBuffer(tmpCpnn, conn)
- common.CopyBuffer(conn, tmpCpnn)
- conn.Close()
- tmpCpnn.Close()
- }(conn)
- }
- }()
- for {
- time.Sleep(time.Second * 5)
- }
- }
- func server() {
- var err error
- l, err := net.Listen("tcp", "127.0.0.1:9999")
- if err != nil {
- log.Fatalln(err)
- }
- go func() {
- conn1, err = l.Accept()
- if err != nil {
- log.Fatalln(err)
- }
- }()
- return
- }
- func client() {
- var err error
- conn2, err = net.Dial("tcp", "127.0.0.1:9999")
- if err != nil {
- log.Fatalln(err)
- }
- }
- func TestNewConn(t *testing.T) {
- buf := pool.GetBufPoolCopy()
- logs.Warn(len(buf), cap(buf))
- //b := pool.GetBufPoolCopy()
- //b[0] = 1
- //b[1] = 2
- //b[2] = 3
- b := []byte{1, 2, 3}
- logs.Warn(copy(buf[:3], b), len(buf), cap(buf))
- logs.Warn(len(buf), buf[0])
- }
|