Files
open-im-server/internal/crontask/clear_msg_test.go
T

105 lines
3.3 KiB
Go
Raw Normal View History

2022-11-01 16:54:23 +08:00
package cronTask
import (
"Open_IM/pkg/common/constant"
2023-01-16 20:14:26 +08:00
mongo2 "Open_IM/pkg/common/db/mongo"
2023-02-09 20:36:34 +08:00
sdkws "Open_IM/pkg/proto/sdkws"
2022-12-26 10:25:42 +08:00
"context"
"fmt"
"strconv"
"github.com/go-redis/redis/v8"
"github.com/golang/protobuf/proto"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
2022-11-01 16:54:23 +08:00
"testing"
2022-11-18 16:59:31 +08:00
"time"
2022-11-01 16:54:23 +08:00
)
2022-12-26 10:25:42 +08:00
var (
redisClient *redis.Client
mongoClient *mongo.Collection
)
2023-01-16 20:14:26 +08:00
func GenUserChat(startSeq, stopSeq, delSeq, index uint32, userID string) *mongo2.UserChat {
chat := &mongo2.UserChat{UID: userID + strconv.Itoa(int(index))}
2022-12-26 10:25:42 +08:00
for i := startSeq; i <= stopSeq; i++ {
2023-02-09 20:36:34 +08:00
msg := sdkws.MsgData{
2022-12-26 10:25:42 +08:00
SendID: "sendID1",
RecvID: "recvID1",
GroupID: "",
ClientMsgID: "xxx",
ServerMsgID: "xxx",
SenderPlatformID: 1,
SenderNickname: "testNickName",
SenderFaceURL: "testFaceURL",
SessionType: 1,
MsgFrom: 100,
ContentType: 101,
Content: []byte("testFaceURL"),
Seq: uint32(i),
SendTime: time.Now().Unix(),
CreateTime: time.Now().Unix(),
Status: 1,
}
bytes, _ := proto.Marshal(&msg)
sendTime := 0
2023-01-16 20:14:26 +08:00
chat.Msg = append(chat.Msg, mongo2.MsgInfo{SendTime: int64(sendTime), Msg: bytes})
2022-11-18 16:59:31 +08:00
}
2022-12-26 10:25:42 +08:00
return chat
2022-11-18 16:59:31 +08:00
}
2022-12-26 10:25:42 +08:00
func SetUserMaxSeq(userID string, seq int) error {
return redisClient.Set(context.Background(), "REDIS_USER_INCR_SEQ"+userID, seq, 0).Err()
}
2023-01-16 20:14:26 +08:00
func CreateChat(userChat *mongo2.UserChat) error {
2022-12-26 10:25:42 +08:00
_, err := mongoClient.InsertOne(context.Background(), userChat)
return err
}
2022-11-18 18:09:43 +08:00
2022-12-26 10:25:42 +08:00
func TestDeleteMongoMsgAndResetRedisSeq(t *testing.T) {
2022-11-01 16:54:23 +08:00
operationID := getCronTaskOperationID()
2022-12-26 10:25:42 +08:00
redisClient = redis.NewClient(&redis.Options{
Addr: "127.0.0.1:16379",
Password: "openIM123", // no password set
DB: 13, // use default DB
})
mongoUri := fmt.Sprintf("mongodb://%s:%s@%s/%s?maxPoolSize=%d&authSource=admin",
"root", "openIM123", "127.0.0.1:37017",
"openIM", 100)
client, err := mongo.Connect(context.TODO(), options.Client().ApplyURI(mongoUri))
mongoClient = client.Database("openIM").Collection("msg")
2022-11-18 16:59:31 +08:00
testUID1 := "test_del_id1"
//testUID2 := "test_del_id2"
//testUID3 := "test_del_id3"
//testUID4 := "test_del_id4"
//testUID5 := "test_del_id5"
//testUID6 := "test_del_id6"
2022-12-26 10:25:42 +08:00
err = SetUserMaxSeq(testUID1, 600)
userChat := GenUserChat(1, 500, 200, 0, testUID1)
err = CreateChat(userChat)
2022-11-18 16:59:31 +08:00
2022-12-26 10:25:42 +08:00
if err := DeleteMongoMsgAndResetRedisSeq(operationID, testUID1); err != nil {
t.Error("checkMaxSeqWithMongo failed", testUID1)
2022-11-18 18:16:44 +08:00
}
2022-12-26 10:25:42 +08:00
if err := checkMaxSeqWithMongo(operationID, testUID1, constant.WriteDiffusion); err != nil {
t.Error("checkMaxSeqWithMongo failed", testUID1)
2022-11-01 16:54:23 +08:00
}
2022-12-26 10:25:42 +08:00
if err != nil {
t.Error("err is not nil", testUID1, err.Error())
2022-11-01 16:54:23 +08:00
}
2022-12-26 10:25:42 +08:00
// testWorkingGroupIDList := []string{"test_del_id1", "test_del_id2", "test_del_id3", "test_del_id4", "test_del_id5"}
// for _, groupID := range testWorkingGroupIDList {
// operationID = groupID + "-" + operationID
// log.NewDebug(operationID, utils.GetSelfFuncName(), "groupID:", groupID, "userIDList:", testUserIDList)
// if err := ResetUserGroupMinSeq(operationID, groupID, testUserIDList); err != nil {
// t.Error("checkMaxSeqWithMongo failed", groupID)
// }
// if err := checkMaxSeqWithMongo(operationID, groupID, constant.ReadDiffusion); err != nil {
// t.Error("checkMaxSeqWithMongo failed", groupID)
// }
// }
2022-11-01 16:54:23 +08:00
}