mirror of
https://github.com/Syngnat/GoNavi.git
synced 2026-05-11 21:59:48 +08:00
- 测试连接统一走 RPC 配置构造,确保 OceanBase Oracle 协议生效 - 保存连接时同步写入 oceanBaseProtocol 与 protocol 参数 - 编辑回显支持从显式字段、连接参数和 URI 恢复协议 - 双击连接时清理旧树缓存,避免复用 MySQL 协议子节点 - 补充 OceanBase 协议解析与缓存 key 隔离测试
214 lines
5.3 KiB
Go
214 lines
5.3 KiB
Go
package app
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"GoNavi-Wails/internal/connection"
|
|
)
|
|
|
|
func TestGetCacheKey_IgnoreTimeout(t *testing.T) {
|
|
base := connection.ConnectionConfig{
|
|
Type: "duckdb",
|
|
Host: `C:\data\songs.duckdb`,
|
|
Timeout: 30,
|
|
UseProxy: false,
|
|
UseSSH: false,
|
|
}
|
|
modified := base
|
|
modified.Timeout = 120
|
|
|
|
left := getCacheKey(base)
|
|
right := getCacheKey(modified)
|
|
if left != right {
|
|
t.Fatalf("expected same cache key when only timeout differs, got %s vs %s", left, right)
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_IgnoreConnectionID(t *testing.T) {
|
|
base := connection.ConnectionConfig{
|
|
ID: "conn-1",
|
|
Type: "mysql",
|
|
Host: "127.0.0.1",
|
|
Port: 3306,
|
|
User: "root",
|
|
Password: "root",
|
|
}
|
|
modified := base
|
|
modified.ID = "conn-2"
|
|
|
|
left := getCacheKey(base)
|
|
right := getCacheKey(modified)
|
|
if left != right {
|
|
t.Fatalf("expected same cache key when only connection id differs, got %s vs %s", left, right)
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_DuckDBHostAndDatabaseEquivalent(t *testing.T) {
|
|
withHost := connection.ConnectionConfig{
|
|
Type: "duckdb",
|
|
Host: `D:\music\songs.duckdb`,
|
|
}
|
|
withDatabase := connection.ConnectionConfig{
|
|
Type: "duckdb",
|
|
Database: `D:\music\songs.duckdb`,
|
|
}
|
|
|
|
left := getCacheKey(withHost)
|
|
right := getCacheKey(withDatabase)
|
|
if left != right {
|
|
t.Fatalf("expected same cache key for duckdb host/database path, got %s vs %s", left, right)
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_KeepDatabaseIsolation(t *testing.T) {
|
|
a := connection.ConnectionConfig{
|
|
Type: "mysql",
|
|
Host: "127.0.0.1",
|
|
Port: 3306,
|
|
User: "root",
|
|
Password: "root",
|
|
Database: "db_a",
|
|
Timeout: 30,
|
|
}
|
|
b := a
|
|
b.Database = "db_b"
|
|
b.Timeout = 5
|
|
|
|
left := getCacheKey(a)
|
|
right := getCacheKey(b)
|
|
if left == right {
|
|
t.Fatalf("expected different cache key for different database targets")
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_KeepConnectionParamsIsolation(t *testing.T) {
|
|
base := connection.ConnectionConfig{
|
|
Type: "mysql",
|
|
Host: "127.0.0.1",
|
|
Port: 3306,
|
|
User: "root",
|
|
Password: "root",
|
|
Database: "app",
|
|
ConnectionParams: "charset=utf8",
|
|
}
|
|
modified := base
|
|
modified.ConnectionParams = "charset=utf8mb4"
|
|
|
|
left := getCacheKey(base)
|
|
right := getCacheKey(modified)
|
|
if left == right {
|
|
t.Fatalf("expected different cache key for different connection params")
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_KeepClickHouseProtocolIsolation(t *testing.T) {
|
|
base := connection.ConnectionConfig{
|
|
Type: "clickhouse",
|
|
Host: "clickhouse.local",
|
|
Port: 8125,
|
|
User: "default",
|
|
Database: "default",
|
|
ClickHouseProtocol: "native",
|
|
}
|
|
modified := base
|
|
modified.ClickHouseProtocol = "http"
|
|
|
|
left := getCacheKey(base)
|
|
right := getCacheKey(modified)
|
|
if left == right {
|
|
t.Fatalf("expected different cache key for different ClickHouse protocols")
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_KeepOceanBaseProtocolIsolation(t *testing.T) {
|
|
base := connection.ConnectionConfig{
|
|
Type: "oceanbase",
|
|
Host: "ob.local",
|
|
Port: 2881,
|
|
User: "sys@oracle001",
|
|
Database: "ORCL",
|
|
ConnectionParams: "protocol=mysql",
|
|
}
|
|
modified := base
|
|
modified.ConnectionParams = "protocol=oracle"
|
|
|
|
left := getCacheKey(base)
|
|
right := getCacheKey(modified)
|
|
if left == right {
|
|
t.Fatalf("expected different cache key for different OceanBase protocols")
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_KeepOceanBaseExplicitProtocolIsolation(t *testing.T) {
|
|
base := connection.ConnectionConfig{
|
|
Type: "oceanbase",
|
|
Host: "ob.local",
|
|
Port: 2881,
|
|
User: "sys@oracle001",
|
|
Database: "ORCL",
|
|
}
|
|
modified := base
|
|
modified.OceanBaseProtocol = "oracle"
|
|
|
|
left := getCacheKey(base)
|
|
right := getCacheKey(modified)
|
|
if left == right {
|
|
t.Fatalf("expected different cache key for explicit OceanBase Oracle protocol")
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_KeepOceanBaseDefaultProtocolEquivalentToMySQL(t *testing.T) {
|
|
base := connection.ConnectionConfig{
|
|
Type: "oceanbase",
|
|
Host: "ob.local",
|
|
Port: 2881,
|
|
User: "root@test",
|
|
Database: "app",
|
|
}
|
|
modified := base
|
|
modified.ConnectionParams = "protocol=mysql"
|
|
|
|
left := getCacheKey(base)
|
|
right := getCacheKey(modified)
|
|
if left != right {
|
|
t.Fatalf("expected default OceanBase protocol to equal mysql, got %s vs %s", left, right)
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_KeepOceanBaseDefaultProtocolEquivalentToExplicitMySQL(t *testing.T) {
|
|
base := connection.ConnectionConfig{
|
|
Type: "oceanbase",
|
|
Host: "ob.local",
|
|
Port: 2881,
|
|
User: "root@test",
|
|
Database: "app",
|
|
}
|
|
modified := base
|
|
modified.OceanBaseProtocol = "mysql"
|
|
|
|
left := getCacheKey(base)
|
|
right := getCacheKey(modified)
|
|
if left != right {
|
|
t.Fatalf("expected default OceanBase protocol to equal explicit mysql, got %s vs %s", left, right)
|
|
}
|
|
}
|
|
|
|
func TestGetCacheKey_OceanBaseProtocolParamWinsOverAliases(t *testing.T) {
|
|
base := connection.ConnectionConfig{
|
|
Type: "oceanbase",
|
|
Host: "ob.local",
|
|
Port: 2881,
|
|
User: "root@test",
|
|
Database: "app",
|
|
ConnectionParams: "protocol=mysql",
|
|
}
|
|
modified := base
|
|
modified.ConnectionParams = "protocol=mysql&tenantMode=oracle"
|
|
|
|
left := getCacheKey(base)
|
|
right := getCacheKey(modified)
|
|
if left != right {
|
|
t.Fatalf("expected explicit protocol=mysql to win over alias, got %s vs %s", left, right)
|
|
}
|
|
}
|