|
|
|
|
@@ -5,28 +5,16 @@ import (
|
|
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
"gorm.io/driver/sqlite"
|
|
|
|
|
"gorm.io/gorm"
|
|
|
|
|
|
|
|
|
|
"nex/backend/internal/config"
|
|
|
|
|
testHelpers "nex/backend/tests"
|
|
|
|
|
|
|
|
|
|
"nex/backend/internal/domain"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func setupTestDB(t *testing.T) *gorm.DB {
|
|
|
|
|
t.Helper()
|
|
|
|
|
dir := t.TempDir()
|
|
|
|
|
db, err := gorm.Open(sqlite.Open(dir+"/test.db"), &gorm.Config{})
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
err = db.AutoMigrate(&config.Provider{}, &config.Model{}, &config.UsageStats{})
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
// 关闭数据库连接以便 TempDir 清理
|
|
|
|
|
t.Cleanup(func() {
|
|
|
|
|
sqlDB, _ := db.DB()
|
|
|
|
|
if sqlDB != nil {
|
|
|
|
|
sqlDB.Close()
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
return db
|
|
|
|
|
return testHelpers.SetupTestDB(t)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ============ ProviderRepository 测试 ============
|
|
|
|
|
@@ -88,7 +76,7 @@ func TestProviderRepository_Update(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
repo := NewProviderRepository(db)
|
|
|
|
|
|
|
|
|
|
repo.Create(&domain.Provider{ID: "p1", Name: "Old", APIKey: "key", BaseURL: "https://old.com"})
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Provider{ID: "p1", Name: "Old", APIKey: "key", BaseURL: "https://old.com"}))
|
|
|
|
|
|
|
|
|
|
err := repo.Update("p1", map[string]interface{}{"name": "New"})
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
@@ -109,7 +97,7 @@ func TestProviderRepository_Delete(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
repo := NewProviderRepository(db)
|
|
|
|
|
|
|
|
|
|
repo.Create(&domain.Provider{ID: "p1", Name: "Test", APIKey: "key", BaseURL: "https://test.com"})
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Provider{ID: "p1", Name: "Test", APIKey: "key", BaseURL: "https://test.com"}))
|
|
|
|
|
err := repo.Delete("p1")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
@@ -129,17 +117,21 @@ func TestProviderRepository_Delete_NotFound(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
func TestModelRepository_Create(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
providerRepo := NewProviderRepository(db)
|
|
|
|
|
repo := NewModelRepository(db)
|
|
|
|
|
|
|
|
|
|
require.NoError(t, providerRepo.Create(&domain.Provider{ID: "p1", Name: "Test", APIKey: "key", BaseURL: "https://test.com"}))
|
|
|
|
|
err := repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4", Enabled: true})
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestModelRepository_GetByID(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
providerRepo := NewProviderRepository(db)
|
|
|
|
|
repo := NewModelRepository(db)
|
|
|
|
|
|
|
|
|
|
repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4", Enabled: true})
|
|
|
|
|
require.NoError(t, providerRepo.Create(&domain.Provider{ID: "p1", Name: "Test", APIKey: "key", BaseURL: "https://test.com"}))
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4", Enabled: true}))
|
|
|
|
|
|
|
|
|
|
result, err := repo.GetByID("m1")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
@@ -149,9 +141,11 @@ func TestModelRepository_GetByID(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
func TestModelRepository_FindByProviderAndModelName(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
providerRepo := NewProviderRepository(db)
|
|
|
|
|
repo := NewModelRepository(db)
|
|
|
|
|
|
|
|
|
|
repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4", Enabled: true})
|
|
|
|
|
require.NoError(t, providerRepo.Create(&domain.Provider{ID: "p1", Name: "Test", APIKey: "key", BaseURL: "https://test.com"}))
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4", Enabled: true}))
|
|
|
|
|
|
|
|
|
|
result, err := repo.FindByProviderAndModelName("p1", "gpt-4")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
@@ -162,9 +156,11 @@ func TestModelRepository_FindByProviderAndModelName(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
func TestModelRepository_FindByProviderAndModelName_NotFound(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
providerRepo := NewProviderRepository(db)
|
|
|
|
|
repo := NewModelRepository(db)
|
|
|
|
|
|
|
|
|
|
repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4", Enabled: true})
|
|
|
|
|
require.NoError(t, providerRepo.Create(&domain.Provider{ID: "p1", Name: "Test", APIKey: "key", BaseURL: "https://test.com"}))
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4", Enabled: true}))
|
|
|
|
|
|
|
|
|
|
// Wrong provider_id
|
|
|
|
|
_, err := repo.FindByProviderAndModelName("p2", "gpt-4")
|
|
|
|
|
@@ -181,11 +177,14 @@ func TestModelRepository_FindByProviderAndModelName_NotFound(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
func TestModelRepository_List(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
providerRepo := NewProviderRepository(db)
|
|
|
|
|
repo := NewModelRepository(db)
|
|
|
|
|
|
|
|
|
|
repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4"})
|
|
|
|
|
repo.Create(&domain.Model{ID: "m2", ProviderID: "p1", ModelName: "gpt-3.5"})
|
|
|
|
|
repo.Create(&domain.Model{ID: "m3", ProviderID: "p2", ModelName: "claude-3"})
|
|
|
|
|
require.NoError(t, providerRepo.Create(&domain.Provider{ID: "p1", Name: "Test", APIKey: "key", BaseURL: "https://test.com"}))
|
|
|
|
|
require.NoError(t, providerRepo.Create(&domain.Provider{ID: "p2", Name: "Test2", APIKey: "key", BaseURL: "https://test2.com"}))
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4"}))
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Model{ID: "m2", ProviderID: "p1", ModelName: "gpt-3.5"}))
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Model{ID: "m3", ProviderID: "p2", ModelName: "claude-3"}))
|
|
|
|
|
|
|
|
|
|
all, err := repo.List("")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
@@ -246,9 +245,11 @@ func TestModelRepository_ListEnabled(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
func TestModelRepository_Update(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
providerRepo := NewProviderRepository(db)
|
|
|
|
|
repo := NewModelRepository(db)
|
|
|
|
|
|
|
|
|
|
repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4", Enabled: true})
|
|
|
|
|
require.NoError(t, providerRepo.Create(&domain.Provider{ID: "p1", Name: "Test", APIKey: "key", BaseURL: "https://test.com"}))
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4", Enabled: true}))
|
|
|
|
|
|
|
|
|
|
err := repo.Update("m1", map[string]interface{}{"enabled": false})
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
@@ -259,9 +260,11 @@ func TestModelRepository_Update(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
func TestModelRepository_Delete(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
providerRepo := NewProviderRepository(db)
|
|
|
|
|
repo := NewModelRepository(db)
|
|
|
|
|
|
|
|
|
|
repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4"})
|
|
|
|
|
require.NoError(t, providerRepo.Create(&domain.Provider{ID: "p1", Name: "Test", APIKey: "key", BaseURL: "https://test.com"}))
|
|
|
|
|
require.NoError(t, repo.Create(&domain.Model{ID: "m1", ProviderID: "p1", ModelName: "gpt-4"}))
|
|
|
|
|
|
|
|
|
|
err := repo.Delete("m1")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
@@ -293,10 +296,32 @@ func TestStatsRepository_Query(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
repo := NewStatsRepository(db)
|
|
|
|
|
|
|
|
|
|
repo.Record("p1", "gpt-4")
|
|
|
|
|
require.NoError(t, repo.Record("p1", "gpt-4"))
|
|
|
|
|
// 注意:当前 schema 只有 date 字段有唯一约束
|
|
|
|
|
// 所以同一 provider + model 只能有一条记录
|
|
|
|
|
stats, err := repo.Query("p1", "", nil, nil)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.Len(t, stats, 1)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestModelRepository_List_EmptyResult(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
repo := NewModelRepository(db)
|
|
|
|
|
|
|
|
|
|
result, err := repo.List("")
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.NotNil(t, result)
|
|
|
|
|
assert.Empty(t, result)
|
|
|
|
|
assert.Len(t, result, 0)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestProviderRepository_List_EmptyResult(t *testing.T) {
|
|
|
|
|
db := setupTestDB(t)
|
|
|
|
|
repo := NewProviderRepository(db)
|
|
|
|
|
|
|
|
|
|
result, err := repo.List()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
assert.NotNil(t, result)
|
|
|
|
|
assert.Empty(t, result)
|
|
|
|
|
assert.Len(t, result, 0)
|
|
|
|
|
}
|
|
|
|
|
|