加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
core_test.go 3.72 KB
一键复制 编辑 原始数据 按行查看 历史
Endless 提交于 2019-07-15 22:31 . 完善对雀魂三麻的支持
package main
import (
"testing"
"io/ioutil"
"strings"
"fmt"
"encoding/json"
"github.com/EndlessCheng/mahjong-helper/util/debug"
"github.com/stretchr/testify/assert"
)
func Test_majsoul_analysis(t *testing.T) {
debugMode = true
logFile := "log/gamedata-x.log"
logData, err := ioutil.ReadFile(logFile)
if err != nil {
t.Fatal(err)
}
s := struct {
Level string `json:"level"`
Message string `json:"message"`
}{}
// config
startLo := -1
endLo := -1
majsoulRoundData := &majsoulRoundData{}
majsoulRoundData.roundData = newGame(majsoulRoundData)
lines := strings.Split(string(logData), "\n")
if startLo == -1 {
// 取最近游戏的日志
for i := len(lines) - 1; i >= 0; i-- {
if strings.Contains(lines[i], "==============") {
startLo = i + 3
break
}
}
}
if endLo == -1 {
endLo = len(lines)
}
for lo, line := range lines[startLo-1 : endLo] {
debug.Lo = lo + 1
fmt.Println(debug.Lo)
if line == "" {
continue
}
if err := json.Unmarshal([]byte(line), &s); err != nil {
fmt.Println(err)
continue
}
if s.Level != "INFO" {
fmt.Println(s.Level, s.Message)
continue
}
msg := s.Message
d := majsoulMessage{}
if err := json.Unmarshal([]byte(msg), &d); err != nil {
fmt.Println(err)
continue
}
majsoulRoundData.msg = &d
majsoulRoundData.originJSON = msg
if err := majsoulRoundData.analysis(); err != nil {
fmt.Println("错误:", err)
}
}
}
func Test_tenhou_analysis(t *testing.T) {
debugMode = true
logFile := "log/gamedata-20190715-201349.log"
logData, err := ioutil.ReadFile(logFile)
if err != nil {
t.Fatal(err)
}
s := struct {
Level string `json:"level"`
Message string `json:"message"`
}{}
// config
startLo := -1
endLo := -1
tenhouRoundData := &tenhouRoundData{isRoundEnd: true}
tenhouRoundData.roundData = newGame(tenhouRoundData)
lines := strings.Split(string(logData), "\n")
if startLo == -1 {
// 取最近游戏的日志
for i := len(lines) - 1; i >= 0; i-- {
if strings.Contains(lines[i], "==============") {
startLo = i + 3
break
}
}
}
if endLo == -1 {
endLo = len(lines)
}
for lo, line := range lines[startLo-1 : endLo] {
debug.Lo = lo + 1
fmt.Println(debug.Lo)
if line == "" {
continue
}
if err := json.Unmarshal([]byte(line), &s); err != nil {
fmt.Println(err)
continue
}
if s.Level != "INFO" {
fmt.Println(s.Message)
continue
}
msg := s.Message
d := tenhouMessage{}
if err := json.Unmarshal([]byte(msg), &d); err != nil {
fmt.Println(err)
continue
}
tenhouRoundData.msg = &d
tenhouRoundData.originJSON = msg
if err := tenhouRoundData.analysis(); err != nil {
fmt.Println("错误:", err)
}
}
}
func Test_modifySanninPlayerInfoList(t *testing.T) {
assert := assert.New(t)
roundNumber := 0
dealer := 2
rd := newRoundData(nil, roundNumber, 0, dealer)
newPlayers := modifySanninPlayerInfoList(rd.players, roundNumber)
assert.Equal(newPlayers[0].selfWindTile, 29)
assert.Equal(newPlayers[1].selfWindTile, 30)
assert.Equal(newPlayers[2].selfWindTile, 27)
assert.Equal(newPlayers[3].selfWindTile, 28)
roundNumber = 1
dealer = 3
rd = newRoundData(nil, roundNumber, 0, dealer)
newPlayers = modifySanninPlayerInfoList(rd.players, roundNumber)
assert.Equal(newPlayers[0].selfWindTile, 28)
assert.Equal(newPlayers[1].selfWindTile, 30)
assert.Equal(newPlayers[2].selfWindTile, 29)
assert.Equal(newPlayers[3].selfWindTile, 27)
roundNumber = 2
dealer = 0
rd = newRoundData(nil, roundNumber, 0, dealer)
newPlayers = modifySanninPlayerInfoList(rd.players, roundNumber)
assert.Equal(newPlayers[0].selfWindTile, 27)
assert.Equal(newPlayers[1].selfWindTile, 30)
assert.Equal(newPlayers[2].selfWindTile, 28)
assert.Equal(newPlayers[3].selfWindTile, 29)
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化