mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 08:50:15 +01:00
* fix(Google): allow presets to configure expected maxOutputTokens * refactor: standardize client-facing errors * refactor(checkUserKeyExpiry): pass endpoint instead of custom message * feat(UserService): JSDocs and getUserKeyValues * refactor: add NO_BASE_URL error type, make use of getUserKeyValues, throw user-specific errors * ci: update tests with recent changes
76 lines
2.6 KiB
JavaScript
76 lines
2.6 KiB
JavaScript
// file deepcode ignore HardcodedNonCryptoSecret: No hardcoded secrets
|
|
const { getUserKey } = require('~/server/services/UserService');
|
|
const initializeClient = require('./initializeClient');
|
|
const { GoogleClient } = require('~/app');
|
|
|
|
jest.mock('~/server/services/UserService', () => ({
|
|
checkUserKeyExpiry: jest.requireActual('~/server/services/UserService').checkUserKeyExpiry,
|
|
getUserKey: jest.fn().mockImplementation(() => ({})),
|
|
}));
|
|
|
|
describe('google/initializeClient', () => {
|
|
afterEach(() => {
|
|
jest.clearAllMocks();
|
|
});
|
|
|
|
test('should initialize GoogleClient with user-provided credentials', async () => {
|
|
process.env.GOOGLE_KEY = 'user_provided';
|
|
process.env.GOOGLE_REVERSE_PROXY = 'http://reverse.proxy';
|
|
process.env.PROXY = 'http://proxy';
|
|
|
|
const expiresAt = new Date(Date.now() + 60000).toISOString();
|
|
|
|
const req = {
|
|
body: { key: expiresAt },
|
|
user: { id: '123' },
|
|
};
|
|
const res = {};
|
|
const endpointOption = { modelOptions: { model: 'default-model' } };
|
|
|
|
const { client, credentials } = await initializeClient({ req, res, endpointOption });
|
|
|
|
expect(getUserKey).toHaveBeenCalledWith({ userId: '123', name: 'google' });
|
|
expect(client).toBeInstanceOf(GoogleClient);
|
|
expect(client.options.reverseProxyUrl).toBe('http://reverse.proxy');
|
|
expect(client.options.proxy).toBe('http://proxy');
|
|
expect(credentials).toEqual({});
|
|
});
|
|
|
|
test('should initialize GoogleClient with service key credentials', async () => {
|
|
process.env.GOOGLE_KEY = 'service_key';
|
|
process.env.GOOGLE_REVERSE_PROXY = 'http://reverse.proxy';
|
|
process.env.PROXY = 'http://proxy';
|
|
|
|
const req = {
|
|
body: { key: null },
|
|
user: { id: '123' },
|
|
};
|
|
const res = {};
|
|
const endpointOption = { modelOptions: { model: 'default-model' } };
|
|
|
|
const { client, credentials } = await initializeClient({ req, res, endpointOption });
|
|
|
|
expect(client).toBeInstanceOf(GoogleClient);
|
|
expect(client.options.reverseProxyUrl).toBe('http://reverse.proxy');
|
|
expect(client.options.proxy).toBe('http://proxy');
|
|
expect(credentials).toEqual({
|
|
GOOGLE_SERVICE_KEY: {},
|
|
GOOGLE_API_KEY: 'service_key',
|
|
});
|
|
});
|
|
|
|
test('should handle expired user-provided key', async () => {
|
|
process.env.GOOGLE_KEY = 'user_provided';
|
|
|
|
const expiresAt = new Date(Date.now() - 10000).toISOString(); // Expired
|
|
const req = {
|
|
body: { key: expiresAt },
|
|
user: { id: '123' },
|
|
};
|
|
const res = {};
|
|
const endpointOption = { modelOptions: { model: 'default-model' } };
|
|
await expect(initializeClient({ req, res, endpointOption })).rejects.toThrow(
|
|
/expired_user_key/,
|
|
);
|
|
});
|
|
});
|