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,59 @@
package(default_visibility = ["//visibility:public"])
load(
"@io_bazel_rules_go//go:def.bzl",
"go_test",
"go_library",
)
go_test(
name = "go_default_test",
srcs = [
"dao_test.go",
"manager_test.go",
"reason_test.go",
"up_test.go",
],
embed = [":go_default_library"],
rundir = ".",
tags = ["automanaged"],
deps = [
"//app/service/main/videoup/conf:go_default_library",
"//vendor/github.com/smartystreets/goconvey/convey:go_default_library",
],
)
go_library(
name = "go_default_library",
srcs = [
"dao.go",
"manager.go",
"reason.go",
"search.go",
"up.go",
],
importpath = "go-common/app/service/main/videoup/dao/manager",
tags = ["automanaged"],
visibility = ["//visibility:public"],
deps = [
"//app/service/main/videoup/conf:go_default_library",
"//app/service/main/videoup/model/archive:go_default_library",
"//library/database/sql:go_default_library",
"//library/log:go_default_library",
"//library/net/http/blademaster: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,48 @@
package manager
import (
"context"
"go-common/app/service/main/videoup/conf"
"go-common/library/database/sql"
bm "go-common/library/net/http/blademaster"
)
const (
_searchUpdateURL = "/x/admin/search/upsert"
)
// Dao is redis dao.
type Dao struct {
c *conf.Config
managerDB *sql.DB
// select stmt
upsStmt *sql.Stmt
httpW *bm.Client
searchUpdateURL string
}
// New fn
func New(c *conf.Config) (d *Dao) {
d = &Dao{
c: c,
managerDB: sql.NewMySQL(c.DB.Manager),
httpW: bm.NewClient(c.HTTPClient.Write),
searchUpdateURL: c.Host.Manager + _searchUpdateURL,
}
// select stmt
d.upsStmt = d.managerDB.Prepared(_upsSQL)
return d
}
// Close fn
func (d *Dao) Close() {
if d.managerDB != nil {
d.managerDB.Close()
}
}
// Ping ping cpdb
func (d *Dao) Ping(c context.Context) (err error) {
return d.managerDB.Ping(c)
}

View File

@@ -0,0 +1,33 @@
package manager
import (
"flag"
"os"
"testing"
"go-common/app/service/main/videoup/conf"
)
var (
d *Dao
)
func TestMain(m *testing.M) {
if os.Getenv("DEPLOY_ENV") != "" {
flag.Set("app_id", "main.archive.videoup-service")
flag.Set("conf_token", "4b62721602981eb3635dba3b0d866ac5")
flag.Set("tree_id", "2308")
flag.Set("conf_version", "docker-1")
flag.Set("deploy_env", "uat")
flag.Set("conf_host", "config.bilibili.co")
flag.Set("conf_path", "/tmp")
flag.Set("region", "sh")
flag.Set("zone", "sh001")
}
flag.Parse()
if err := conf.Init(); err != nil {
panic(err)
}
d = New(conf.Conf)
m.Run()
os.Exit(0)
}

View File

@@ -0,0 +1,38 @@
package manager
import (
"context"
"go-common/library/log"
)
const (
_upsSQL = "SELECT mid,type FROM ups"
)
// Uppers get uppers by type.
func (d *Dao) Uppers(c context.Context) (um map[int8]map[int64]struct{}, err error) {
rows, err := d.upsStmt.Query(c)
if err != nil {
log.Error("d.upsStmt.Query error(%v)", err)
return
}
defer rows.Close()
um = map[int8]map[int64]struct{}{}
for rows.Next() {
var (
mid int64
tp int8
)
if err = rows.Scan(&mid, &tp); err != nil {
log.Error("rows.Scan error(%v)", err)
return
}
if mm, ok := um[tp]; ok {
mm[mid] = struct{}{}
} else {
um[tp] = map[int64]struct{}{mid: struct{}{}}
}
}
return
}

View File

@@ -0,0 +1,20 @@
package manager
import (
"context"
"testing"
"github.com/smartystreets/goconvey/convey"
)
func TestManagerUppers(t *testing.T) {
var (
c = context.TODO()
)
convey.Convey("Uppers", t, func(ctx convey.C) {
_, err := d.Uppers(c)
ctx.Convey("Then err should be nil.um should not be nil.", func(ctx convey.C) {
ctx.So(err, convey.ShouldBeNil)
})
})
}

View File

@@ -0,0 +1,30 @@
package manager
import (
"context"
xsql "database/sql"
"go-common/library/log"
)
const (
_reasonSQL = "SELECT reason.tag_id as tag_id from reason_log left join reason on reason_log.reason_id=reason.id where reason_log.type=1 AND reason_log.oid=? order by reason_log.id desc limit 1;"
)
// ArcReason get a archive reason tag
func (d *Dao) ArcReason(c context.Context, aid int64) (tagID int64, err error) {
var (
row = d.managerDB.QueryRow(c, _reasonSQL, aid)
tagIDI xsql.NullInt64
)
if err := row.Scan(&tagIDI); err != nil {
if err == xsql.ErrNoRows {
err = nil
} else {
log.Error("ArcReason row.Scan error(%v)", err)
}
}
log.Info("ArcReason retrun(%v)", tagIDI)
tagID = tagIDI.Int64
return
}

View File

@@ -0,0 +1,21 @@
package manager
import (
"context"
"testing"
"github.com/smartystreets/goconvey/convey"
)
func TestManagerArcReason(t *testing.T) {
var (
c = context.TODO()
aid = int64(2333)
)
convey.Convey("ArcReason", t, func(ctx convey.C) {
_, err := d.ArcReason(c, aid)
ctx.Convey("Then err should be nil.tagID should not be nil.", func(ctx convey.C) {
ctx.So(err, convey.ShouldBeNil)
})
})
}

View File

@@ -0,0 +1,29 @@
package manager
import (
"context"
"go-common/library/log"
"net/url"
"strconv"
)
// searchUpdate .
func (d *Dao) SearchUpdate(c context.Context, business, data string, aid int64) (err error) {
params := url.Values{}
params.Set("business", business)
params.Set("data", data)
params.Set("aid", strconv.FormatInt(aid, 10))
var res struct {
Code int `json:"code"`
}
if err = d.httpW.Post(c, d.searchUpdateURL, "", params, &res); err != nil {
log.Error("searchUpdate d.httpW.Post(%s) error(%v)", d.searchUpdateURL+"?"+params.Encode(), err)
return
}
if res.Code != 0 {
log.Error("searchUpdate url(%s) code(%d)", d.searchUpdateURL+"?"+params.Encode(), res.Code)
}
log.Info("aid (%d) SearchUpdate url(%s) code(%d)", aid, d.searchUpdateURL+"?"+params.Encode(), res.Code)
return
}

View File

@@ -0,0 +1,34 @@
package manager
import (
"context"
"database/sql"
"go-common/app/service/main/videoup/model/archive"
"go-common/library/log"
)
const (
_upsWithGroup = "SELECT ups.id,mid,up_group.id as group_id ,up_group.short_tag as group_tag,up_group.name as group_name,ups.note,ups.ctime FROM ups INNER JOIN up_group on ups.type=up_group.id"
)
// UpSpecial load all ups with group info
func (d *Dao) UpSpecial(c context.Context) (ups []*archive.Up, err error) {
rows, err := d.managerDB.Query(c, _upsWithGroup)
if err != nil {
log.Error("d.tpsStmt.Query error(%v)", err)
return
}
defer rows.Close()
var note sql.NullString
for rows.Next() {
up := &archive.Up{}
if err = rows.Scan(&up.ID, &up.Mid, &up.GroupID, &up.GroupTag, &up.GroupName, &note, &up.CTime); err != nil {
log.Error("rows.Scan error(%v)", err)
return
}
up.Note = note.String
ups = append(ups, up)
}
return
}

View File

@@ -0,0 +1,20 @@
package manager
import (
"context"
"testing"
"github.com/smartystreets/goconvey/convey"
)
func TestManagerUpSpecial(t *testing.T) {
var (
c = context.TODO()
)
convey.Convey("UpSpecial", t, func(ctx convey.C) {
_, err := d.UpSpecial(c)
ctx.Convey("Then err should be nil.ups should not be nil.", func(ctx convey.C) {
ctx.So(err, convey.ShouldBeNil)
})
})
}