mirror of
https://github.com/sipeed/picoclaw.git
synced 2026-06-12 18:08:54 +00:00
9c31b0ca95
* fix: Fixed the bug where the bus was closed and consumers had unfinished messages. * fix: remove unnecessary blank line in Close method * fix: refactor message bus and channel handling for improved performance and reliability * fix: improve message handling and bus closure logic for better reliability * fix: reduce sleep duration in agent loop for improved responsiveness * fix the test case
53 lines
1.2 KiB
Go
53 lines
1.2 KiB
Go
package qq
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/tencent-connect/botgo/dto"
|
|
|
|
"github.com/sipeed/picoclaw/pkg/bus"
|
|
"github.com/sipeed/picoclaw/pkg/channels"
|
|
)
|
|
|
|
func TestHandleC2CMessage_IncludesAccountIDMetadata(t *testing.T) {
|
|
messageBus := bus.NewMessageBus()
|
|
ch := &QQChannel{
|
|
BaseChannel: channels.NewBaseChannel("qq", nil, messageBus, nil),
|
|
dedup: make(map[string]time.Time),
|
|
done: make(chan struct{}),
|
|
ctx: context.Background(),
|
|
}
|
|
|
|
err := ch.handleC2CMessage()(nil, &dto.WSC2CMessageData{
|
|
ID: "msg-1",
|
|
Content: "hello",
|
|
Author: &dto.User{
|
|
ID: "7750283E123456",
|
|
},
|
|
})
|
|
if err != nil {
|
|
t.Fatalf("handleC2CMessage() error = %v", err)
|
|
}
|
|
|
|
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
|
|
defer cancel()
|
|
|
|
for {
|
|
select {
|
|
case <-ctx.Done():
|
|
t.Fatal("timeout waiting for inbound message")
|
|
return
|
|
case inbound, ok := <-messageBus.InboundChan():
|
|
if !ok {
|
|
t.Fatal("expected inbound message")
|
|
}
|
|
if inbound.Metadata["account_id"] != "7750283E123456" {
|
|
t.Fatalf("account_id metadata = %q, want %q", inbound.Metadata["account_id"], "7750283E123456")
|
|
}
|
|
return
|
|
}
|
|
}
|
|
}
|