mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 08:50:15 +01:00
* chore: linting for `loadCustomConfig` * refactor: decouple CDN init and variable/health checks from AppService * refactor: move AppService to packages/data-schemas * chore: update AppConfig import path to use data-schemas * chore: update JsonSchemaType import path to use data-schemas * refactor: update UserController to import webSearchKeys and redefine FunctionTool typedef * chore: remove AppService.js * refactor: update AppConfig interface to use Partial<TCustomConfig> and make paths and fileStrategies optional * refactor: update checkConfig function to accept Partial<TCustomConfig> * chore: fix types * refactor: move handleRateLimits to startup checks as is an effect * test: remove outdated rate limit tests from AppService.spec and add new handleRateLimits tests in checks.spec
137 lines
4.4 KiB
TypeScript
137 lines
4.4 KiB
TypeScript
import type { AppConfig } from '@librechat/data-schemas';
|
|
import {
|
|
createTempChatExpirationDate,
|
|
getTempChatRetentionHours,
|
|
DEFAULT_RETENTION_HOURS,
|
|
MIN_RETENTION_HOURS,
|
|
MAX_RETENTION_HOURS,
|
|
} from './tempChatRetention';
|
|
|
|
describe('tempChatRetention', () => {
|
|
const originalEnv = process.env;
|
|
|
|
beforeEach(() => {
|
|
jest.resetModules();
|
|
process.env = { ...originalEnv };
|
|
delete process.env.TEMP_CHAT_RETENTION_HOURS;
|
|
});
|
|
|
|
afterAll(() => {
|
|
process.env = originalEnv;
|
|
});
|
|
|
|
describe('getTempChatRetentionHours', () => {
|
|
it('should return default retention hours when no config or env var is set', () => {
|
|
const result = getTempChatRetentionHours();
|
|
expect(result).toBe(DEFAULT_RETENTION_HOURS);
|
|
});
|
|
|
|
it('should use environment variable when set', () => {
|
|
process.env.TEMP_CHAT_RETENTION_HOURS = '48';
|
|
const result = getTempChatRetentionHours();
|
|
expect(result).toBe(48);
|
|
});
|
|
|
|
it('should use config value when set', () => {
|
|
const config: Partial<AppConfig> = {
|
|
interfaceConfig: {
|
|
temporaryChatRetention: 12,
|
|
},
|
|
};
|
|
const result = getTempChatRetentionHours(config?.interfaceConfig);
|
|
expect(result).toBe(12);
|
|
});
|
|
|
|
it('should prioritize config over environment variable', () => {
|
|
process.env.TEMP_CHAT_RETENTION_HOURS = '48';
|
|
const config: Partial<AppConfig> = {
|
|
interfaceConfig: {
|
|
temporaryChatRetention: 12,
|
|
},
|
|
};
|
|
const result = getTempChatRetentionHours(config?.interfaceConfig);
|
|
expect(result).toBe(12);
|
|
});
|
|
|
|
it('should enforce minimum retention period', () => {
|
|
const config: Partial<AppConfig> = {
|
|
interfaceConfig: {
|
|
temporaryChatRetention: 0,
|
|
},
|
|
};
|
|
const result = getTempChatRetentionHours(config?.interfaceConfig);
|
|
expect(result).toBe(MIN_RETENTION_HOURS);
|
|
});
|
|
|
|
it('should enforce maximum retention period', () => {
|
|
const config: Partial<AppConfig> = {
|
|
interfaceConfig: {
|
|
temporaryChatRetention: 10000,
|
|
},
|
|
};
|
|
const result = getTempChatRetentionHours(config?.interfaceConfig);
|
|
expect(result).toBe(MAX_RETENTION_HOURS);
|
|
});
|
|
|
|
it('should handle invalid environment variable', () => {
|
|
process.env.TEMP_CHAT_RETENTION_HOURS = 'invalid';
|
|
const result = getTempChatRetentionHours();
|
|
expect(result).toBe(DEFAULT_RETENTION_HOURS);
|
|
});
|
|
|
|
it('should handle invalid config value', () => {
|
|
const config: Partial<AppConfig> = {
|
|
interfaceConfig: {
|
|
temporaryChatRetention: 'invalid' as unknown as number,
|
|
},
|
|
};
|
|
const result = getTempChatRetentionHours(config?.interfaceConfig);
|
|
expect(result).toBe(DEFAULT_RETENTION_HOURS);
|
|
});
|
|
});
|
|
|
|
describe('createTempChatExpirationDate', () => {
|
|
it('should create expiration date with default retention period', () => {
|
|
const beforeCall = Date.now();
|
|
const result = createTempChatExpirationDate();
|
|
const afterCall = Date.now();
|
|
|
|
const expectedMin = beforeCall + DEFAULT_RETENTION_HOURS * 60 * 60 * 1000;
|
|
const expectedMax = afterCall + DEFAULT_RETENTION_HOURS * 60 * 60 * 1000;
|
|
|
|
// Result should be between expectedMin and expectedMax
|
|
expect(result.getTime()).toBeGreaterThanOrEqual(expectedMin);
|
|
expect(result.getTime()).toBeLessThanOrEqual(expectedMax);
|
|
});
|
|
|
|
it('should create expiration date with custom retention period', () => {
|
|
const config: Partial<AppConfig> = {
|
|
interfaceConfig: {
|
|
temporaryChatRetention: 12,
|
|
},
|
|
};
|
|
|
|
const beforeCall = Date.now();
|
|
const result = createTempChatExpirationDate(config?.interfaceConfig);
|
|
const afterCall = Date.now();
|
|
|
|
const expectedMin = beforeCall + 12 * 60 * 60 * 1000;
|
|
const expectedMax = afterCall + 12 * 60 * 60 * 1000;
|
|
|
|
// Result should be between expectedMin and expectedMax
|
|
expect(result.getTime()).toBeGreaterThanOrEqual(expectedMin);
|
|
expect(result.getTime()).toBeLessThanOrEqual(expectedMax);
|
|
});
|
|
|
|
it('should return a Date object', () => {
|
|
const result = createTempChatExpirationDate();
|
|
expect(result).toBeInstanceOf(Date);
|
|
});
|
|
|
|
it('should return a future date', () => {
|
|
const now = new Date();
|
|
const result = createTempChatExpirationDate();
|
|
expect(result.getTime()).toBeGreaterThan(now.getTime());
|
|
});
|
|
});
|
|
});
|