main.go 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302
  1. package main
  2. import (
  3. "fmt"
  4. jsoniter "github.com/json-iterator/go"
  5. mhayaHttp "github.com/mhaya/extend/http"
  6. mhayaTime "github.com/mhaya/extend/time"
  7. "github.com/mhaya/game/game_cluster/internal/code"
  8. "github.com/mhaya/game/game_cluster/internal/param"
  9. mhayaLogger "github.com/mhaya/logger"
  10. pomeloClient "github.com/mhaya/net/parser/pomelo/client"
  11. "math/rand"
  12. "strconv"
  13. "time"
  14. )
  15. var (
  16. maxRobotNum = 1000 // 运行x个机器人
  17. url = "http://127.0.0.1:20000"
  18. url2 = "http://127.0.0.1:20001" // web node
  19. addr = "127.0.0.1:10011" // 网关地址(正式环境通过区服列表获取)
  20. serverId int32 = 10001 // 测试的游戏服id
  21. pid = "2126001" // 测试的sdk包id
  22. printLog = false // 是否输出详细日志
  23. )
  24. func main() {
  25. accounts := make(map[string]*param.LoginReq)
  26. for i := 1; i <= maxRobotNum; i++ {
  27. str := strconv.Itoa(i)
  28. accounts[str] = &param.LoginReq{
  29. Pid: 2,
  30. OpenID: str,
  31. Platform: "ios",
  32. Channel: "tg",
  33. }
  34. }
  35. var Url = ""
  36. for _, val := range accounts {
  37. k := rand.Intn(2)
  38. if k == 1 {
  39. Url = url2
  40. } else {
  41. Url = url
  42. }
  43. fmt.Println(Url)
  44. time.Sleep(200 * time.Millisecond)
  45. go RunRobot(Url, val)
  46. }
  47. }
  48. //func main() {
  49. //
  50. // //accounts := make(map[string]*param.LoginReq)
  51. // //for i := 1; i <= maxRobotNum; i++ {
  52. // // str := strconv.Itoa(i)
  53. // // accounts[str] = &param.LoginReq{
  54. // // Pid: 2,
  55. // // OpenID: str,
  56. // // Platform: "ios",
  57. // // Channel: "tg",
  58. // // }
  59. // //}
  60. // //var Url = ""
  61. // //for _, val := range accounts {
  62. // // k := rand.Intn(2)
  63. // // if k == 1 {
  64. // // Url = url2
  65. // // } else {
  66. // // Url = url
  67. // // }
  68. // // fmt.Println(Url)
  69. // // time.Sleep(200 * time.Millisecond)
  70. // // go RunRobot(Url, val)
  71. // //}
  72. //
  73. // var wg sync.WaitGroup
  74. // // 邀请排行榜机器人
  75. // accounts := BuildAccount(100)
  76. // for _, account := range accounts {
  77. // wg.Add(1)
  78. // InviteRankRobot(account, &wg)
  79. // }
  80. // wg.Wait()
  81. //}
  82. var Player = []string{"28q1PjXEh3M", "28q1PjY2LSm", "28q1PjYpgFW", "28q1PjYLLvw", "28qeTc4cwBj", "28q1RgBeGYq", "28q1PjYLLvx", "28qfgUzvh67", "28qeLPTxn79", "28qfBVzrRqm", "28qf5VTadno", "28qfdrK9yVN", "28qg8W7Lbmh"}
  83. func RunRobot(url string, val *param.LoginReq) {
  84. token := RegisterDevAccount(url, val)
  85. if token == "" {
  86. return
  87. }
  88. params := map[string]interface{}{
  89. "nickName": "guest" + val.OpenID,
  90. }
  91. Login(url, params, token)
  92. time.Sleep(time.Duration(rand.Int31n(2)) * time.Millisecond)
  93. num1 := rand.Intn(12)
  94. params = map[string]interface{}{
  95. "parentName": Player[num1],
  96. }
  97. time.Sleep(time.Duration(rand.Int31n(10)) * time.Millisecond)
  98. //Invite(url, params, token)
  99. timer := time.NewTimer(time.Duration(rand.Int31n(2)) * time.Second)
  100. go func(url string, token string) {
  101. select {
  102. case <-timer.C:
  103. num := rand.Intn(20) + 1
  104. params = map[string]interface{}{
  105. "multi": num,
  106. }
  107. Roll(url, params, token)
  108. num = rand.Intn(2) + 1
  109. params = map[string]interface{}{
  110. "tp": num,
  111. }
  112. Lottery(url, params, token)
  113. }
  114. }(url, token)
  115. }
  116. func RegisterDevAccount(url string, val *param.LoginReq) string {
  117. requestURL := fmt.Sprintf("%s/auth", url)
  118. params := map[string]interface{}{
  119. "pid": val.Pid,
  120. "openid": val.OpenID,
  121. "platform": val.Platform,
  122. "channel": val.Channel,
  123. }
  124. jsonBytes, _, err := mhayaHttp.PostJSON(requestURL, params)
  125. if err != nil {
  126. mhayaLogger.Warn(err)
  127. return ""
  128. }
  129. rsp := &code.Result{}
  130. err = jsoniter.Unmarshal(jsonBytes, rsp)
  131. if err != nil {
  132. mhayaLogger.Warn(err)
  133. return ""
  134. }
  135. if rsp.Code == 0 {
  136. mhayaLogger.Debugf("register account = %v, result = %v", val.OpenID, rsp)
  137. return rsp.Data.(string)
  138. }
  139. return ""
  140. }
  141. func Login(url string, params map[string]interface{}, token string) {
  142. requestURL := fmt.Sprintf("%s/login", url)
  143. jsonBytes, err := mhayaHttp.PostJSONWithHeader(requestURL, params, token)
  144. if err != nil {
  145. mhayaLogger.Warn(err)
  146. return
  147. }
  148. rsp := &code.Result{}
  149. err = jsoniter.Unmarshal(jsonBytes, rsp)
  150. if err != nil {
  151. mhayaLogger.Warn(err)
  152. return
  153. }
  154. mhayaLogger.Debugf("Login OK")
  155. }
  156. func Roll(url string, params map[string]interface{}, token string) {
  157. requestURL := fmt.Sprintf("%s/roll", url)
  158. jsonBytes, err := mhayaHttp.PostJSONWithHeader(requestURL, params, token)
  159. if err != nil {
  160. mhayaLogger.Warn(err)
  161. return
  162. }
  163. rsp := &code.Result{}
  164. err = jsoniter.Unmarshal(jsonBytes, rsp)
  165. if err != nil {
  166. mhayaLogger.Warn(err)
  167. return
  168. }
  169. mhayaLogger.Debugf("roll parms =%v", params)
  170. }
  171. func Lottery(url string, params map[string]interface{}, token string) {
  172. requestURL := fmt.Sprintf("%s/lottery", url)
  173. jsonBytes, err := mhayaHttp.PostJSONWithHeader(requestURL, params, token)
  174. if err != nil {
  175. mhayaLogger.Warn(err)
  176. return
  177. }
  178. rsp := &code.Result{}
  179. err = jsoniter.Unmarshal(jsonBytes, rsp)
  180. if err != nil {
  181. mhayaLogger.Warn(err)
  182. return
  183. }
  184. mhayaLogger.Debugf("Lottery %v", params)
  185. }
  186. func Invite(url string, params map[string]interface{}, token string) {
  187. requestURL := fmt.Sprintf("%s/invite", url)
  188. jsonBytes, err := mhayaHttp.PostJSONWithHeader(requestURL, params, token)
  189. if err != nil {
  190. mhayaLogger.Warn(err)
  191. return
  192. }
  193. rsp := &code.Result{}
  194. err = jsoniter.Unmarshal(jsonBytes, rsp)
  195. if err != nil {
  196. mhayaLogger.Warn(err)
  197. return
  198. }
  199. mhayaLogger.Debugf("Invite %v", params)
  200. }
  201. func RunRobot1(url, pid, userName, password, addr string, serverId int32, printLog bool) *Robot {
  202. // 创建客户端
  203. cli := New(
  204. pomeloClient.New(
  205. pomeloClient.WithRequestTimeout(10*time.Second),
  206. pomeloClient.WithErrorBreak(true),
  207. ),
  208. )
  209. cli.PrintLog = printLog
  210. // 登录获取token
  211. if err := cli.GetToken(url, pid, userName, password); err != nil {
  212. mhayaLogger.Error(err)
  213. return nil
  214. }
  215. // 根据地址连接网关
  216. if err := cli.ConnectToTCP(addr); err != nil {
  217. mhayaLogger.Error(err)
  218. return nil
  219. }
  220. if cli.PrintLog {
  221. mhayaLogger.Infof("tcp connect %s is ok", addr)
  222. }
  223. // 随机休眠
  224. cli.RandSleep()
  225. // 用户登录到游戏节点
  226. err := cli.UserLogin(serverId)
  227. if err != nil {
  228. mhayaLogger.Warn(err)
  229. return nil
  230. }
  231. if cli.PrintLog {
  232. mhayaLogger.Infof("user login is ok. [user = %s, serverId = %d]", userName, serverId)
  233. }
  234. //cli.RandSleep()
  235. // 查看是否有角色
  236. err = cli.PlayerSelect()
  237. if err != nil {
  238. mhayaLogger.Warn(err)
  239. return nil
  240. }
  241. //cli.RandSleep()
  242. // 创建角色
  243. err = cli.ActorCreate()
  244. if err != nil {
  245. mhayaLogger.Warn(err)
  246. return nil
  247. }
  248. //cli.RandSleep()
  249. // 角色进入游戏
  250. err = cli.ActorEnter()
  251. if err != nil {
  252. mhayaLogger.Warn(err)
  253. return nil
  254. }
  255. elapsedTime := cli.StartTime.DiffInMillisecond(mhayaTime.Now())
  256. mhayaLogger.Debugf("[%s] is enter to game. elapsed time:%dms", cli.TagName, elapsedTime)
  257. //cli.Disconnect()
  258. return cli
  259. }