mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 05:02:11 +08:00 
			
		
		
		
	fix: searchMessage method has potential NPE bug (#3287)
This commit is contained in:
		
							parent
							
								
									8e824c7e8e
								
							
						
					
					
						commit
						48d0433388
					
				| @ -321,7 +321,12 @@ func (m *MsgMgo) searchMessageIndex(ctx context.Context, filter any, nextID prim | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (m *MsgMgo) searchMessage(ctx context.Context, req *msg.SearchMessageReq) (int64, []searchMessageIndex, error) { | func (m *MsgMgo) searchMessage(ctx context.Context, req *msg.SearchMessageReq) (int64, []searchMessageIndex, error) { | ||||||
| 	filter := bson.M{} | 	filter := bson.M{ | ||||||
|  | 		"msgs.msg": bson.M{ | ||||||
|  | 			"$exists": true, | ||||||
|  | 			"$type":   "object", | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
| 	if req.RecvID != "" { | 	if req.RecvID != "" { | ||||||
| 		filter["$or"] = bson.A{ | 		filter["$or"] = bson.A{ | ||||||
| 			bson.M{"msgs.msg.recv_id": req.RecvID}, | 			bson.M{"msgs.msg.recv_id": req.RecvID}, | ||||||
|  | |||||||
| @ -9,6 +9,8 @@ import ( | |||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model" | ||||||
|  | 	"github.com/openimsdk/protocol/msg" | ||||||
|  | 	"github.com/openimsdk/protocol/sdkws" | ||||||
| 	"github.com/openimsdk/tools/db/mongoutil" | 	"github.com/openimsdk/tools/db/mongoutil" | ||||||
| 	"go.mongodb.org/mongo-driver/bson" | 	"go.mongodb.org/mongo-driver/bson" | ||||||
| 	"go.mongodb.org/mongo-driver/mongo" | 	"go.mongodb.org/mongo-driver/mongo" | ||||||
| @ -148,3 +150,29 @@ func TestName5(t *testing.T) { | |||||||
| //	} | //	} | ||||||
| //	t.Log(seq, sendTime) | //	t.Log(seq, sendTime) | ||||||
| //} | //} | ||||||
|  | 
 | ||||||
|  | func TestSearchMessage(t *testing.T) { | ||||||
|  | 	ctx, cancel := context.WithTimeout(context.Background(), time.Second*300) | ||||||
|  | 	defer cancel() | ||||||
|  | 	cli := Result(mongo.Connect(ctx, options.Client().ApplyURI("mongodb://openIM:openIM123@172.16.8.135:37017/openim_v3?maxPoolSize=100").SetConnectTimeout(5*time.Second))) | ||||||
|  | 
 | ||||||
|  | 	msgMongo, err := NewMsgMongo(cli.Database("openim_v3")) | ||||||
|  | 	if err != nil { | ||||||
|  | 		panic(err) | ||||||
|  | 	} | ||||||
|  | 	ts := time.Now().Add(-time.Hour * 24 * 5).UnixMilli() | ||||||
|  | 	t.Log(ts) | ||||||
|  | 	req := &msg.SearchMessageReq{ | ||||||
|  | 		//SendID: "yjz", | ||||||
|  | 		//RecvID: "aibot", | ||||||
|  | 		Pagination: &sdkws.RequestPagination{ | ||||||
|  | 			PageNumber: 1, | ||||||
|  | 			ShowNumber: 20, | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  | 	count, resp, err := msgMongo.SearchMessage(ctx, req) | ||||||
|  | 	if err != nil { | ||||||
|  | 		panic(err) | ||||||
|  | 	} | ||||||
|  | 	t.Log(resp, count) | ||||||
|  | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user