mirror of
https://github.com/memohai/Memoh.git
synced 2026-04-27 07:16:19 +09:00
85251a2905
- Remove user-level model settings (chat_model_id, memory_model_id, embedding_model_id, max_context_load_time, language) from users table - Merge migration 0002 into 0001, remove compatibility migrations - Delete dead conversation/resolver.go (1177 lines, only flow/resolver.go used) - Remove type aliases (Chat=Conversation, types_alias.go) - Fix SQL: remove AND false stub, fix UpdateChatTitle model_id, reset model IDs in DeleteSettings, add preauth expiry filter, add ListMessages limit, remove 10 dead queries - Extract shared handler helpers (RequireChannelIdentityID, AuthorizeBotAccess) - Rename internal/router to internal/channel/inbound - Fix identity confusion: remove UserID->ChannelIdentityID fallbacks - Fix all _ = var patterns with proper error logging - Fix error propagation: storeMessages, rescheduleJob, botContainerID - Fix naming: ModelId->ModelID, active->is_active, Duration semantic fix - Remove dead code: mcpService, ReplyTarget, callMCPServer, sshShellQuote, buildSessionMetadata, ChatRequest.Language, TriggerPayload.ChatID - Fix code quality: errors.Is(), remove goto, CreateHuman deprecated - Remove Enable model endpoint and user-level settings CLI commands - Regenerate sqlc, swagger, SDK
57 lines
1.3 KiB
Go
57 lines
1.3 KiB
Go
package flow
|
|
|
|
import (
|
|
"context"
|
|
"log/slog"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/memohai/memoh/internal/conversation"
|
|
"github.com/memohai/memoh/internal/memory"
|
|
)
|
|
|
|
func TestLoadMemoryContextMessage_NoMemoryService(t *testing.T) {
|
|
resolver := &Resolver{
|
|
memoryService: nil,
|
|
logger: slog.Default(),
|
|
}
|
|
msg := resolver.loadMemoryContextMessage(context.Background(), conversation.ChatRequest{
|
|
Query: "hello",
|
|
BotID: "bot-1",
|
|
ChatID: "chat-1",
|
|
})
|
|
if msg != nil {
|
|
t.Fatalf("expected nil message when memory service is nil")
|
|
}
|
|
}
|
|
|
|
func TestLoadMemoryContextMessage_SearchFailureFallback(t *testing.T) {
|
|
resolver := &Resolver{
|
|
memoryService: &memory.Service{},
|
|
logger: slog.Default(),
|
|
}
|
|
msg := resolver.loadMemoryContextMessage(context.Background(), conversation.ChatRequest{
|
|
Query: "hello",
|
|
BotID: "bot-1",
|
|
ChatID: "chat-1",
|
|
UserID: "user-1",
|
|
})
|
|
if msg != nil {
|
|
t.Fatalf("expected nil message when memory search cannot return results")
|
|
}
|
|
}
|
|
|
|
func TestTruncateMemorySnippet(t *testing.T) {
|
|
longText := strings.Repeat("a", 20) + " "
|
|
got := truncateMemorySnippet(longText, 10)
|
|
if got != strings.Repeat("a", 10)+"..." {
|
|
t.Fatalf("unexpected truncated value: %q", got)
|
|
}
|
|
|
|
shortText := " short "
|
|
got = truncateMemorySnippet(shortText, 10)
|
|
if got != "short" {
|
|
t.Fatalf("unexpected trimmed short value: %q", got)
|
|
}
|
|
}
|