fusenapi/server/home-user-auth/test/basic.go

87 lines
2.0 KiB
Go
Raw Normal View History

2023-06-16 02:58:43 +00:00
package logic
2023-06-12 11:52:11 +00:00
import (
"fmt"
"fusenapi/server/home-user-auth/internal/config"
"fusenapi/server/home-user-auth/internal/handler"
"fusenapi/server/home-user-auth/internal/svc"
2023-06-19 02:33:51 +00:00
"log"
2023-06-12 11:52:11 +00:00
"testing"
"github.com/474420502/requests"
"github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest"
)
2023-06-15 09:51:06 +00:00
var testConfigFile = "../etc/home-user-auth.yaml"
2023-06-12 11:52:11 +00:00
var cnf config.Config
var gserver *rest.Server
func init() {
2023-06-19 02:33:51 +00:00
log.SetFlags(log.Llongfile)
2023-06-12 11:52:11 +00:00
gserver = GetTestServer()
}
func GetTestServer() *rest.Server {
2023-06-15 09:51:06 +00:00
conf.MustLoad(testConfigFile, &cnf)
2023-06-12 11:52:11 +00:00
server := rest.MustNewServer(cnf.RestConf)
defer server.Stop()
ctx := svc.NewServiceContext(cnf)
handler.RegisterHandlers(server, ctx)
fmt.Printf("Starting server at %s:%d...\n", cnf.Host, cnf.Port)
return server
}
2023-06-16 02:58:43 +00:00
func GetSesssion(t *testing.T, server requests.ITestServer) *requests.Session {
ses := requests.NewSession()
return ses
}
2023-06-16 10:52:24 +00:00
func GetSesssionWithUserToken(t *testing.T, server requests.ITestServer) *requests.Session {
2023-06-12 11:52:11 +00:00
ses := requests.NewSession()
tp := ses.Post(fmt.Sprintf("http://%s:%d/user/login", cnf.Host, cnf.Port))
tp.SetBodyJson(map[string]interface{}{
"name": "devenv@sina.cn",
"pwd": "$2y$13$6UFDMZQMEfqFYiNLpiUCi.B3fpvGEamPAjIgzUqv/u7jT05nB3pOC",
})
2023-06-16 10:52:24 +00:00
resp, err := tp.TestInServer(server)
if err != nil {
t.Error(err)
}
result := resp.Json()
code := result.Get("code").Int()
if code != 200 {
t.Error("code is not 200")
}
token := result.Get("data.token")
if !token.Exists() {
t.Error("data.token is not exists")
}
ses.Header.Add("Authorization", token.String())
return ses
}
func GetSesssionWithGuestToken(t *testing.T, server requests.ITestServer) *requests.Session {
ses := requests.NewSession()
tp := ses.Post(fmt.Sprintf("http://%s:%d/accept/cookie", cnf.Host, cnf.Port))
2023-06-12 11:52:11 +00:00
resp, err := tp.TestInServer(server)
if err != nil {
t.Error(err)
}
result := resp.Json()
token := result.Get("data.token")
if !token.Exists() {
t.Error("data.token is not exists")
}
ses.Header.Add("Authorization", token.String())
return ses
}