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
62 lines
1.4 KiB
Go
62 lines
1.4 KiB
Go
//go:build whatsapp_native
|
|
|
|
package whatsapp
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
"time"
|
|
|
|
"go.mau.fi/whatsmeow/proto/waE2E"
|
|
"go.mau.fi/whatsmeow/types"
|
|
"go.mau.fi/whatsmeow/types/events"
|
|
"google.golang.org/protobuf/proto"
|
|
|
|
"github.com/sipeed/picoclaw/pkg/bus"
|
|
"github.com/sipeed/picoclaw/pkg/channels"
|
|
"github.com/sipeed/picoclaw/pkg/config"
|
|
)
|
|
|
|
func TestHandleIncoming_DoesNotConsumeGenericCommandsLocally(t *testing.T) {
|
|
messageBus := bus.NewMessageBus()
|
|
ch := &WhatsAppNativeChannel{
|
|
BaseChannel: channels.NewBaseChannel("whatsapp_native", config.WhatsAppConfig{}, messageBus, nil),
|
|
runCtx: context.Background(),
|
|
}
|
|
|
|
evt := &events.Message{
|
|
Info: types.MessageInfo{
|
|
MessageSource: types.MessageSource{
|
|
Sender: types.NewJID("1001", types.DefaultUserServer),
|
|
Chat: types.NewJID("1001", types.DefaultUserServer),
|
|
},
|
|
ID: "mid1",
|
|
PushName: "Alice",
|
|
},
|
|
Message: &waE2E.Message{
|
|
Conversation: proto.String("/new"),
|
|
},
|
|
}
|
|
|
|
ch.handleIncoming(evt)
|
|
|
|
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
|
|
defer cancel()
|
|
|
|
select {
|
|
case <-ctx.Done():
|
|
t.Fatal("timeout waiting for message to be forwarded")
|
|
return
|
|
case inbound, ok := <-messageBus.InboundChan():
|
|
if !ok {
|
|
t.Fatal("expected inbound message to be forwarded")
|
|
}
|
|
if inbound.Channel != "whatsapp_native" {
|
|
t.Fatalf("channel=%q", inbound.Channel)
|
|
}
|
|
if inbound.Content != "/new" {
|
|
t.Fatalf("content=%q", inbound.Content)
|
|
}
|
|
}
|
|
}
|