Files
MyGoNavi/internal/db/sqlserver_impl_test.go
tianqijiuyun-latiao d13c153f5e feat(i18n): 收口数据库驱动多语言代码
- 提交 internal/db 多驱动用户可见错误与状态文案多语言化

- 补齐数据库驱动多语言测试与六语言 catalog

- 修复 frontend i18n catalog 的 4 个失效 guard
2026-06-22 10:09:45 +08:00

147 lines
3.7 KiB
Go

//go:build gonavi_full_drivers || gonavi_sqlserver_driver
package db
import (
"errors"
"os"
"strings"
"testing"
"GoNavi-Wails/shared/i18n"
)
var rawSQLServerTableNameRequiredText = string([]rune{0x8868, 0x540d, 0x4e0d, 0x80fd, 0x4e3a, 0x7a7a})
type fakeSQLServerExecResult struct {
affected int64
rowErr error
}
func (r fakeSQLServerExecResult) LastInsertId() (int64, error) {
return 0, errors.New("not implemented")
}
func (r fakeSQLServerExecResult) RowsAffected() (int64, error) {
if r.rowErr != nil {
return 0, r.rowErr
}
return r.affected, nil
}
func TestSQLServerRowsAffectedIgnoresTransactionControlErrors(t *testing.T) {
rowErr := errors.New("不支持的方法")
for _, query := range []string{
"BEGIN TRANSACTION",
"COMMIT TRANSACTION",
"ROLLBACK TRANSACTION",
"SAVE TRANSACTION before_update",
"BEGIN TRY\nSELECT 1\nEND TRY",
} {
affected, err := sqlServerRowsAffected(query, fakeSQLServerExecResult{rowErr: rowErr})
if err != nil {
t.Fatalf("sqlServerRowsAffected(%q) returned unexpected error: %v", query, err)
}
if affected != 0 {
t.Fatalf("sqlServerRowsAffected(%q) = %d, want 0", query, affected)
}
}
}
func TestSQLServerRowsAffectedPreservesDMLCount(t *testing.T) {
affected, err := sqlServerRowsAffected(
"UPDATE dbo.users SET name = 'neo' WHERE id = 1",
fakeSQLServerExecResult{affected: 3},
)
if err != nil {
t.Fatalf("sqlServerRowsAffected returned unexpected error: %v", err)
}
if affected != 3 {
t.Fatalf("sqlServerRowsAffected = %d, want 3", affected)
}
}
func TestSQLServerRowsAffectedDoesNotHideDMLRowsAffectedErrors(t *testing.T) {
rowErr := errors.New("rows affected unsupported")
_, err := sqlServerRowsAffected(
"UPDATE dbo.users SET name = 'neo' WHERE id = 1",
fakeSQLServerExecResult{rowErr: rowErr},
)
if !errors.Is(err, rowErr) {
t.Fatalf("expected rows affected error to propagate for DML, got %v", err)
}
}
func TestSQLServerMetadataErrorsUseCurrentLanguage(t *testing.T) {
SetBackendLanguage(i18n.LanguageEnUS)
t.Cleanup(func() {
SetBackendLanguage(i18n.LanguageZhCN)
})
sqlServer := &SqlServerDB{}
tests := []struct {
name string
call func() error
}{
{
name: "columns table name required",
call: func() error {
_, err := sqlServer.GetColumns("", " ")
return err
},
},
{
name: "indexes table name required",
call: func() error {
_, err := sqlServer.GetIndexes("", " ")
return err
},
},
{
name: "foreign keys table name required",
call: func() error {
_, err := sqlServer.GetForeignKeys("", " ")
return err
},
},
{
name: "triggers table name required",
call: func() error {
_, err := sqlServer.GetTriggers("", " ")
return err
},
},
}
for _, tc := range tests {
t.Run(tc.name, func(t *testing.T) {
err := tc.call()
if err == nil {
t.Fatal("expected SQL Server metadata call to fail")
}
if err.Error() != "Table name is required" {
t.Fatalf("expected English table-name-required error, got %q", err.Error())
}
if strings.Contains(err.Error(), rawSQLServerTableNameRequiredText) {
t.Fatalf("expected no raw Chinese SQL Server metadata text, got %q", err.Error())
}
})
}
}
func TestSQLServerMetadataErrorSourcesUseI18nKeys(t *testing.T) {
sourceBytes, err := os.ReadFile("sqlserver_impl.go")
if err != nil {
t.Fatalf("read sqlserver_impl.go: %v", err)
}
source := string(sourceBytes)
rawMessage := `fmt.Errorf("` + rawSQLServerTableNameRequiredText + `")`
if strings.Contains(source, rawMessage) {
t.Fatalf("sqlserver_impl.go still contains raw SQL Server metadata text %q", rawMessage)
}
if !strings.Contains(source, "db.backend.error.table_name_required") {
t.Fatal("sqlserver_impl.go does not reference db.backend.error.table_name_required")
}
}