mirror of
https://github.com/Syngnat/GoNavi.git
synced 2026-05-31 23:39:36 +08:00
- 运行时校验可选 driver-agent revision,避免旧代理继续被复用 - OceanBase agent revision 纳入 oracle_impl.go 指纹并重新生成 - OceanBase Oracle 保留 URI 中的 Oracle 连接参数 - Oracle DSN 默认写入连接和读取超时,并输出脱敏诊断摘要 - 补充 revision、Oracle DSN、OceanBase Oracle 参数提升测试
129 lines
3.6 KiB
Go
129 lines
3.6 KiB
Go
package db
|
|
|
|
import (
|
|
"errors"
|
|
"net/url"
|
|
"strings"
|
|
"testing"
|
|
|
|
"GoNavi-Wails/internal/connection"
|
|
)
|
|
|
|
func TestOracleGetDSNIncludesQueryPerformanceOptions(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
dsn := (&OracleDB{}).getDSN(connection.ConnectionConfig{
|
|
Host: "db.example.com",
|
|
Port: 1521,
|
|
User: "scott",
|
|
Password: "tiger",
|
|
Database: "ORCLPDB1",
|
|
})
|
|
|
|
parsed, err := url.Parse(dsn)
|
|
if err != nil {
|
|
t.Fatalf("解析 Oracle DSN 失败: %v", err)
|
|
}
|
|
query := parsed.Query()
|
|
if got := query.Get("PREFETCH_ROWS"); got != "10000" {
|
|
t.Fatalf("PREFETCH_ROWS = %q, want 10000", got)
|
|
}
|
|
if got := query.Get("LOB FETCH"); got != "POST" {
|
|
t.Fatalf("LOB FETCH = %q, want POST", got)
|
|
}
|
|
}
|
|
|
|
func TestOracleGetDSNIncludesTimeoutDefaults(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
dsn := (&OracleDB{}).getDSN(connection.ConnectionConfig{
|
|
Host: "db.example.com",
|
|
Port: 1521,
|
|
User: "scott",
|
|
Password: "tiger",
|
|
Database: "ORCLPDB1",
|
|
Timeout: 12,
|
|
})
|
|
|
|
parsed, err := url.Parse(dsn)
|
|
if err != nil {
|
|
t.Fatalf("解析 Oracle DSN 失败: %v", err)
|
|
}
|
|
query := parsed.Query()
|
|
if got := query.Get("CONNECT TIMEOUT"); got != "12" {
|
|
t.Fatalf("CONNECT TIMEOUT = %q, want 12", got)
|
|
}
|
|
if got := query.Get("READ TIMEOUT"); got != "12" {
|
|
t.Fatalf("READ TIMEOUT = %q, want 12", got)
|
|
}
|
|
}
|
|
|
|
func TestOracleGetDSNMergesConnectionParams(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
dsn := (&OracleDB{}).getDSN(connection.ConnectionConfig{
|
|
Host: "db.example.com",
|
|
Port: 1521,
|
|
User: "scott",
|
|
Password: "tiger",
|
|
Database: "ORCLPDB1",
|
|
ConnectionParams: "PREFETCH_ROWS=5000&TRACE FILE=/tmp/go-ora.trc&connect_timeout=10&read_timeout=7&FAILOVER=3&unknown=bad",
|
|
})
|
|
|
|
parsed, err := url.Parse(dsn)
|
|
if err != nil {
|
|
t.Fatalf("解析 Oracle DSN 失败: %v", err)
|
|
}
|
|
query := parsed.Query()
|
|
if got := query.Get("PREFETCH_ROWS"); got != "5000" {
|
|
t.Fatalf("PREFETCH_ROWS = %q, want 5000", got)
|
|
}
|
|
if got := query.Get("TRACE FILE"); got != "/tmp/go-ora.trc" {
|
|
t.Fatalf("TRACE FILE = %q, want /tmp/go-ora.trc", got)
|
|
}
|
|
if got := query.Get("CONNECT TIMEOUT"); got != "10" {
|
|
t.Fatalf("CONNECT TIMEOUT = %q, want 10", got)
|
|
}
|
|
if got := query.Get("READ TIMEOUT"); got != "7" {
|
|
t.Fatalf("READ TIMEOUT = %q, want 7", got)
|
|
}
|
|
if got := query.Get("FAILOVER"); got != "" {
|
|
t.Fatalf("FAILOVER should be filtered because go-ora no longer supports it, got %q", got)
|
|
}
|
|
if got := query.Get("unknown"); got != "" {
|
|
t.Fatalf("unknown should be filtered, got %q", got)
|
|
}
|
|
}
|
|
|
|
func TestOracleDSNLogSummaryDoesNotExposePassword(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
dsn := (&OracleDB{}).getDSN(connection.ConnectionConfig{
|
|
Host: "db.example.com",
|
|
Port: 1521,
|
|
User: "sys@tenant",
|
|
Password: "top-secret",
|
|
Database: "ORCLPDB1",
|
|
ConnectionParams: "DBA_PRIVILEGE=SYSDBA&AUTH_TYPE=NORMAL",
|
|
})
|
|
|
|
got := oracleDSNLogSummary(connection.ConnectionConfig{Database: "ORCLPDB1"}, dsn)
|
|
if strings.Contains(got, "top-secret") || strings.Contains(got, "sys@tenant") {
|
|
t.Fatalf("summary should not expose credentials, got %q", got)
|
|
}
|
|
for _, want := range []string{"服务名=ORCLPDB1", "DBA_PRIVILEGE=SYSDBA", "AUTH_TYPE=NORMAL"} {
|
|
if !strings.Contains(got, want) {
|
|
t.Fatalf("expected summary to contain %q, got %q", want, got)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestAnnotateOracleValidationErrorAddsClosedConnectionHint(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
err := annotateOracleValidationError(errors.New("read tcp 127.0.0.1:1->127.0.0.1:2: use of closed network connection"))
|
|
if err == nil || !strings.Contains(err.Error(), "Service Name") {
|
|
t.Fatalf("expected closed connection hint, got %v", err)
|
|
}
|
|
}
|