package homeuserauthtest import ( "fmt" "fusenapi/server/home-user-auth/internal/types" fstests "fusenapi/utils/fstests" "testing" "github.com/474420502/requests" "github.com/tidwall/gjson" ) func TestCaseLogic(t *testing.T) { var err error var resp *requests.Response var result gjson.Result // 获取 session,并携带 JWT token ses := fstests.GetSessionWithUserToken(t, userserver, cnf.Host, cnf.Port) // 向服务器发送 GET 请求,获取用户类型信息 tp := ses.Post(fmt.Sprintf("http://%s:%d/api/user/order-delete", cnf.Host, cnf.Port)) reqO := types.RequestOrderId{ OrderId: 12, } tp.SetBodyJson(reqO) resp, err = tp.TestExecute(gserver) if err != nil { t.Error(err) } // 使用 gjson 解析返回的 json 数据 result = gjson.Parse(resp.ContentString()) // 检查返回值中的 code 字段是否存在,并且值是否为 200 code := result.Get("code").Int() if code != 200 { t.Errorf("Invalid code value: %d", code) } // 检查返回值中的 msg 字段是否存在,并且值是否为 "success" msg := result.Get("msg").String() if msg != "success" { t.Errorf(`Invalid msg value: "%s"`, msg) } // 检查返回值中的 data 字段是否存在,并且值是否为数组类型 dataArray := result.Get("data").Array() if len(dataArray) == 0 { t.Error("Empty data field") } // 遍历每个元素,检查其 key 和 name 字段是否存在,并且值是否符合预期 for i, item := range dataArray { key := item.Get("key").Int() name := item.Get("name").String() if key != int64(i+1) { t.Errorf("Unexpected key value at index %d: %d", i, key) } if len(name) == 0 { t.Errorf("Missing name value at index %d", i) } } }