Create & Init Project...

This commit is contained in:
2019-04-22 18:49:16 +08:00
commit fc4fa37393
25440 changed files with 4054998 additions and 0 deletions

View 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"],
)

View 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
}

View 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)
})
}