295 lines
8.2 KiB
Go
295 lines
8.2 KiB
Go
package service
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestAccount_IsOpenAIPassthroughEnabled(t *testing.T) {
|
|
t.Run("新字段开启", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeAPIKey,
|
|
Extra: map[string]any{
|
|
"openai_passthrough": true,
|
|
},
|
|
}
|
|
require.True(t, account.IsOpenAIPassthroughEnabled())
|
|
})
|
|
|
|
t.Run("兼容旧字段", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_oauth_passthrough": true,
|
|
},
|
|
}
|
|
require.True(t, account.IsOpenAIPassthroughEnabled())
|
|
})
|
|
|
|
t.Run("非OpenAI账号始终关闭", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformAnthropic,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_passthrough": true,
|
|
},
|
|
}
|
|
require.False(t, account.IsOpenAIPassthroughEnabled())
|
|
})
|
|
|
|
t.Run("空额外配置默认关闭", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
}
|
|
require.False(t, account.IsOpenAIPassthroughEnabled())
|
|
})
|
|
}
|
|
|
|
func TestAccount_IsOpenAIOAuthPassthroughEnabled(t *testing.T) {
|
|
t.Run("仅OAuth类型允许返回开启", func(t *testing.T) {
|
|
oauthAccount := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_passthrough": true,
|
|
},
|
|
}
|
|
require.True(t, oauthAccount.IsOpenAIOAuthPassthroughEnabled())
|
|
|
|
apiKeyAccount := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeAPIKey,
|
|
Extra: map[string]any{
|
|
"openai_passthrough": true,
|
|
},
|
|
}
|
|
require.False(t, apiKeyAccount.IsOpenAIOAuthPassthroughEnabled())
|
|
})
|
|
}
|
|
|
|
func TestAccount_IsCodexCLIOnlyEnabled(t *testing.T) {
|
|
t.Run("OpenAI OAuth 开启", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"codex_cli_only": true,
|
|
},
|
|
}
|
|
require.True(t, account.IsCodexCLIOnlyEnabled())
|
|
})
|
|
|
|
t.Run("OpenAI OAuth 关闭", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"codex_cli_only": false,
|
|
},
|
|
}
|
|
require.False(t, account.IsCodexCLIOnlyEnabled())
|
|
})
|
|
|
|
t.Run("字段缺失默认关闭", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{},
|
|
}
|
|
require.False(t, account.IsCodexCLIOnlyEnabled())
|
|
})
|
|
|
|
t.Run("类型非法默认关闭", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"codex_cli_only": "true",
|
|
},
|
|
}
|
|
require.False(t, account.IsCodexCLIOnlyEnabled())
|
|
})
|
|
|
|
t.Run("非 OAuth 账号始终关闭", func(t *testing.T) {
|
|
apiKeyAccount := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeAPIKey,
|
|
Extra: map[string]any{
|
|
"codex_cli_only": true,
|
|
},
|
|
}
|
|
require.False(t, apiKeyAccount.IsCodexCLIOnlyEnabled())
|
|
|
|
otherPlatform := &Account{
|
|
Platform: PlatformAnthropic,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"codex_cli_only": true,
|
|
},
|
|
}
|
|
require.False(t, otherPlatform.IsCodexCLIOnlyEnabled())
|
|
})
|
|
}
|
|
|
|
func TestAccount_IsOpenAIResponsesWebSocketV2Enabled(t *testing.T) {
|
|
t.Run("OAuth使用OAuth专用开关", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_oauth_responses_websockets_v2_enabled": true,
|
|
},
|
|
}
|
|
require.True(t, account.IsOpenAIResponsesWebSocketV2Enabled())
|
|
})
|
|
|
|
t.Run("API Key使用API Key专用开关", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeAPIKey,
|
|
Extra: map[string]any{
|
|
"openai_apikey_responses_websockets_v2_enabled": true,
|
|
},
|
|
}
|
|
require.True(t, account.IsOpenAIResponsesWebSocketV2Enabled())
|
|
})
|
|
|
|
t.Run("OAuth账号不会读取API Key专用开关", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_apikey_responses_websockets_v2_enabled": true,
|
|
},
|
|
}
|
|
require.False(t, account.IsOpenAIResponsesWebSocketV2Enabled())
|
|
})
|
|
|
|
t.Run("分类型新键优先于兼容键", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_oauth_responses_websockets_v2_enabled": false,
|
|
"responses_websockets_v2_enabled": true,
|
|
"openai_ws_enabled": true,
|
|
},
|
|
}
|
|
require.False(t, account.IsOpenAIResponsesWebSocketV2Enabled())
|
|
})
|
|
|
|
t.Run("分类型键缺失时回退兼容键", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeAPIKey,
|
|
Extra: map[string]any{
|
|
"responses_websockets_v2_enabled": true,
|
|
},
|
|
}
|
|
require.True(t, account.IsOpenAIResponsesWebSocketV2Enabled())
|
|
})
|
|
|
|
t.Run("非OpenAI账号默认关闭", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformAnthropic,
|
|
Type: AccountTypeAPIKey,
|
|
Extra: map[string]any{
|
|
"responses_websockets_v2_enabled": true,
|
|
},
|
|
}
|
|
require.False(t, account.IsOpenAIResponsesWebSocketV2Enabled())
|
|
})
|
|
}
|
|
|
|
func TestAccount_ResolveOpenAIResponsesWebSocketV2Mode(t *testing.T) {
|
|
t.Run("default fallback to shared", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{},
|
|
}
|
|
require.Equal(t, OpenAIWSIngressModeShared, account.ResolveOpenAIResponsesWebSocketV2Mode(""))
|
|
require.Equal(t, OpenAIWSIngressModeShared, account.ResolveOpenAIResponsesWebSocketV2Mode("invalid"))
|
|
})
|
|
|
|
t.Run("oauth mode field has highest priority", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_oauth_responses_websockets_v2_mode": OpenAIWSIngressModeDedicated,
|
|
"openai_oauth_responses_websockets_v2_enabled": false,
|
|
"responses_websockets_v2_enabled": false,
|
|
},
|
|
}
|
|
require.Equal(t, OpenAIWSIngressModeDedicated, account.ResolveOpenAIResponsesWebSocketV2Mode(OpenAIWSIngressModeShared))
|
|
})
|
|
|
|
t.Run("legacy enabled maps to shared", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeAPIKey,
|
|
Extra: map[string]any{
|
|
"responses_websockets_v2_enabled": true,
|
|
},
|
|
}
|
|
require.Equal(t, OpenAIWSIngressModeShared, account.ResolveOpenAIResponsesWebSocketV2Mode(OpenAIWSIngressModeOff))
|
|
})
|
|
|
|
t.Run("legacy disabled maps to off", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeAPIKey,
|
|
Extra: map[string]any{
|
|
"openai_apikey_responses_websockets_v2_enabled": false,
|
|
"responses_websockets_v2_enabled": true,
|
|
},
|
|
}
|
|
require.Equal(t, OpenAIWSIngressModeOff, account.ResolveOpenAIResponsesWebSocketV2Mode(OpenAIWSIngressModeShared))
|
|
})
|
|
|
|
t.Run("non openai always off", func(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformAnthropic,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_oauth_responses_websockets_v2_mode": OpenAIWSIngressModeDedicated,
|
|
},
|
|
}
|
|
require.Equal(t, OpenAIWSIngressModeOff, account.ResolveOpenAIResponsesWebSocketV2Mode(OpenAIWSIngressModeDedicated))
|
|
})
|
|
}
|
|
|
|
func TestAccount_OpenAIWSExtraFlags(t *testing.T) {
|
|
account := &Account{
|
|
Platform: PlatformOpenAI,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_ws_force_http": true,
|
|
"openai_ws_allow_store_recovery": true,
|
|
},
|
|
}
|
|
require.True(t, account.IsOpenAIWSForceHTTPEnabled())
|
|
require.True(t, account.IsOpenAIWSAllowStoreRecoveryEnabled())
|
|
|
|
off := &Account{Platform: PlatformOpenAI, Type: AccountTypeOAuth, Extra: map[string]any{}}
|
|
require.False(t, off.IsOpenAIWSForceHTTPEnabled())
|
|
require.False(t, off.IsOpenAIWSAllowStoreRecoveryEnabled())
|
|
|
|
var nilAccount *Account
|
|
require.False(t, nilAccount.IsOpenAIWSAllowStoreRecoveryEnabled())
|
|
|
|
nonOpenAI := &Account{
|
|
Platform: PlatformAnthropic,
|
|
Type: AccountTypeOAuth,
|
|
Extra: map[string]any{
|
|
"openai_ws_allow_store_recovery": true,
|
|
},
|
|
}
|
|
require.False(t, nonOpenAI.IsOpenAIWSAllowStoreRecoveryEnabled())
|
|
}
|