Create & Init Project...
This commit is contained in:
49
app/service/main/dynamic/rpc/server/BUILD
Normal file
49
app/service/main/dynamic/rpc/server/BUILD
Normal file
@ -0,0 +1,49 @@
|
||||
package(default_visibility = ["//visibility:public"])
|
||||
|
||||
load(
|
||||
"@io_bazel_rules_go//go:def.bzl",
|
||||
"go_test",
|
||||
"go_library",
|
||||
)
|
||||
|
||||
go_test(
|
||||
name = "go_default_test",
|
||||
srcs = ["rpc_test.go"],
|
||||
embed = [":go_default_library"],
|
||||
rundir = ".",
|
||||
tags = ["automanaged"],
|
||||
deps = [
|
||||
"//app/service/main/archive/api:go_default_library",
|
||||
"//app/service/main/dynamic/model:go_default_library",
|
||||
"//vendor/github.com/smartystreets/goconvey/convey:go_default_library",
|
||||
],
|
||||
)
|
||||
|
||||
go_library(
|
||||
name = "go_default_library",
|
||||
srcs = ["rpc.go"],
|
||||
importpath = "go-common/app/service/main/dynamic/rpc/server",
|
||||
tags = ["automanaged"],
|
||||
deps = [
|
||||
"//app/service/main/archive/api:go_default_library",
|
||||
"//app/service/main/dynamic/conf:go_default_library",
|
||||
"//app/service/main/dynamic/model:go_default_library",
|
||||
"//app/service/main/dynamic/service:go_default_library",
|
||||
"//library/net/rpc:go_default_library",
|
||||
"//library/net/rpc/context:go_default_library",
|
||||
],
|
||||
)
|
||||
|
||||
filegroup(
|
||||
name = "package-srcs",
|
||||
srcs = glob(["**"]),
|
||||
tags = ["automanaged"],
|
||||
visibility = ["//visibility:private"],
|
||||
)
|
||||
|
||||
filegroup(
|
||||
name = "all-srcs",
|
||||
srcs = [":package-srcs"],
|
||||
tags = ["automanaged"],
|
||||
visibility = ["//visibility:public"],
|
||||
)
|
68
app/service/main/dynamic/rpc/server/rpc.go
Normal file
68
app/service/main/dynamic/rpc/server/rpc.go
Normal file
@ -0,0 +1,68 @@
|
||||
package server
|
||||
|
||||
import (
|
||||
"go-common/app/service/main/archive/api"
|
||||
"go-common/app/service/main/dynamic/conf"
|
||||
"go-common/app/service/main/dynamic/model"
|
||||
"go-common/app/service/main/dynamic/service"
|
||||
"go-common/library/net/rpc"
|
||||
"go-common/library/net/rpc/context"
|
||||
)
|
||||
|
||||
// RPC struct info.
|
||||
type RPC struct {
|
||||
s *service.Service
|
||||
}
|
||||
|
||||
// New new rpc server.
|
||||
func New(c *conf.Config, s *service.Service) (svr *rpc.Server) {
|
||||
r := &RPC{s: s}
|
||||
svr = rpc.NewServer(c.RPCServer)
|
||||
if err := svr.Register(r); err != nil {
|
||||
panic(err)
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// Ping check connection success.
|
||||
func (r *RPC) Ping(c context.Context, arg *struct{}, res *struct{}) (err error) {
|
||||
return
|
||||
}
|
||||
|
||||
//RegionTotal return dynamic region total.
|
||||
func (r *RPC) RegionTotal(c context.Context, a *model.ArgRegionTotal, res *map[string]int) (err error) {
|
||||
*res = r.s.RegionTotal(c)
|
||||
return
|
||||
}
|
||||
|
||||
// RegionArcs3 receive aid, then init archive3 info.
|
||||
func (r *RPC) RegionArcs3(c context.Context, a *model.ArgRegion3, res *model.DynamicArcs3) (err error) {
|
||||
var (
|
||||
count int
|
||||
arcs []*api.Arc
|
||||
)
|
||||
if arcs, count, err = r.s.RegionArcs3(c, a.RegionID, a.Pn, a.Ps); err == nil {
|
||||
res.Page = &model.Page{Num: a.Pn, Size: a.Ps, Count: count}
|
||||
res.Archives = arcs
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// RegionTagArcs3 receive aid, then init archive info.
|
||||
func (r *RPC) RegionTagArcs3(c context.Context, a *model.ArgRegionTag3, res *model.DynamicArcs3) (err error) {
|
||||
var (
|
||||
count int
|
||||
arcs []*api.Arc
|
||||
)
|
||||
if arcs, count, err = r.s.RegionTagArcs3(c, a.RegionID, a.TagID, a.Pn, a.Ps); err == nil {
|
||||
res.Page = &model.Page{Num: a.Pn, Size: a.Ps, Count: count}
|
||||
res.Archives = arcs
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// RegionsArcs3 receive rids and return dynamic archives3.
|
||||
func (r *RPC) RegionsArcs3(c context.Context, a *model.ArgRegions3, res *map[int32][]*api.Arc) (err error) {
|
||||
*res, err = r.s.RegionsArcs3(c, a.RegionIDs, a.Count)
|
||||
return
|
||||
}
|
94
app/service/main/dynamic/rpc/server/rpc_test.go
Normal file
94
app/service/main/dynamic/rpc/server/rpc_test.go
Normal file
@ -0,0 +1,94 @@
|
||||
package server
|
||||
|
||||
import (
|
||||
"net/rpc"
|
||||
"testing"
|
||||
|
||||
"go-common/app/service/main/archive/api"
|
||||
"go-common/app/service/main/dynamic/model"
|
||||
|
||||
. "github.com/smartystreets/goconvey/convey"
|
||||
)
|
||||
|
||||
const (
|
||||
_addr = "127.0.0.1:6235"
|
||||
_regionArcs3 = "RPC.RegionArcs3"
|
||||
_regionTagArcs3 = "RPC.RegionTagArcs3"
|
||||
_regionsArcs3 = "RPC.RegionsArcs3"
|
||||
_regionTotal = "RPC.RegionTotal"
|
||||
)
|
||||
|
||||
func Test_RPC(t *testing.T) {
|
||||
Convey("RPC Region Archives", t, func() {
|
||||
client, err := rpc.Dial("tcp", _addr)
|
||||
So(err, ShouldBeNil)
|
||||
defer client.Close()
|
||||
|
||||
testRPCRegionArcs(t, client)
|
||||
testRPCRegionTagArcs(t, client)
|
||||
testRPCRegionsArcs(t, client)
|
||||
testRPCRegionTotal(t, client)
|
||||
})
|
||||
}
|
||||
|
||||
func testRPCRegionArcs(t *testing.T, client *rpc.Client) {
|
||||
var (
|
||||
rid int32 = 168
|
||||
pn, ps int = 1, 10
|
||||
ip = "127.0.0.1"
|
||||
res *model.DynamicArcs3
|
||||
)
|
||||
Convey("RPC Region Archives", func() {
|
||||
arg := &model.ArgRegion3{RegionID: rid, Pn: pn, Ps: ps, RealIP: ip}
|
||||
res = new(model.DynamicArcs3)
|
||||
err := client.Call(_regionArcs3, arg, &res)
|
||||
So(err, ShouldBeNil)
|
||||
So(res, ShouldNotBeEmpty)
|
||||
})
|
||||
}
|
||||
|
||||
func testRPCRegionTagArcs(t *testing.T, client *rpc.Client) {
|
||||
var (
|
||||
rid int32 = 168
|
||||
tid int64 = 123456
|
||||
pn, ps int = 1, 10
|
||||
ip = "127.0.0.1"
|
||||
res *model.DynamicArcs3
|
||||
)
|
||||
Convey("RPC Region Tag Archives", func() {
|
||||
arg := &model.ArgRegionTag3{TagID: tid, RegionID: rid, Pn: pn, Ps: ps, RealIP: ip}
|
||||
res = new(model.DynamicArcs3)
|
||||
err := client.Call(_regionTagArcs3, arg, &res)
|
||||
So(err, ShouldBeNil)
|
||||
So(res, ShouldNotBeEmpty)
|
||||
})
|
||||
}
|
||||
|
||||
func testRPCRegionsArcs(t *testing.T, client *rpc.Client) {
|
||||
var (
|
||||
rids = []int32{1, 3, 4, 5, 13, 36, 129, 119, 23, 11, 155, 160, 165, 168}
|
||||
count = 10
|
||||
ip = "127.0.0.1"
|
||||
res *map[int32][]*api.Arc
|
||||
)
|
||||
Convey("RPC Regions Archives", func() {
|
||||
arg := &model.ArgRegions3{RegionIDs: rids, Count: count, RealIP: ip}
|
||||
err := client.Call(_regionsArcs3, arg, &res)
|
||||
So(err, ShouldBeNil)
|
||||
So(res, ShouldNotBeEmpty)
|
||||
})
|
||||
|
||||
}
|
||||
|
||||
func testRPCRegionTotal(t *testing.T, client *rpc.Client) {
|
||||
var (
|
||||
ip = "127.0.0.1"
|
||||
res map[string]int
|
||||
)
|
||||
Convey("RPC Region Total", func() {
|
||||
arg := &model.ArgRegionTotal{RealIP: ip}
|
||||
err := client.Call(_regionTotal, arg, &res)
|
||||
So(err, ShouldBeNil)
|
||||
So(res, ShouldNotBeEmpty)
|
||||
})
|
||||
}
|
Reference in New Issue
Block a user