mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-09-22 08:12:00 +02:00

* refactor: move model definitions and database-related methods to packages/data-schemas * ci: update tests due to new DB structure fix: disable mocking `librechat-data-provider` feat: Add schema exports to data-schemas package - Introduced a new schema module that exports various schemas including action, agent, and user schemas. - Updated index.ts to include the new schema exports for better modularity and organization. ci: fix appleStrategy tests fix: Agent.spec.js ci: refactor handleTools tests to use MongoMemoryServer for in-memory database fix: getLogStores imports ci: update banViolation tests to use MongoMemoryServer and improve session mocking test: refactor samlStrategy tests to improve mock configurations and user handling ci: fix crypto mock in handleText tests for improved accuracy ci: refactor spendTokens tests to improve model imports and setup ci: refactor Message model tests to use MongoMemoryServer and improve database interactions * refactor: streamline IMessage interface and move feedback properties to types/message.ts * refactor: use exported initializeRoles from `data-schemas`, remove api workspace version (this serves as an example of future migrations that still need to happen) * refactor: update model imports to use destructuring from `~/db/models` for consistency and clarity * refactor: remove unused mongoose imports from model files for cleaner code * refactor: remove unused mongoose imports from Share, Prompt, and Transaction model files for cleaner code * refactor: remove unused import in Transaction model for cleaner code * ci: update deploy workflow to reference new Docker Dev Branch Images Build and add new workflow for building Docker images on dev branch * chore: cleanup imports
103 lines
2.9 KiB
JavaScript
103 lines
2.9 KiB
JavaScript
const { isEnabled, sanitizeFilename } = require('./handleText');
|
|
|
|
describe('isEnabled', () => {
|
|
test('should return true when input is "true"', () => {
|
|
expect(isEnabled('true')).toBe(true);
|
|
});
|
|
|
|
test('should return true when input is "TRUE"', () => {
|
|
expect(isEnabled('TRUE')).toBe(true);
|
|
});
|
|
|
|
test('should return true when input is true', () => {
|
|
expect(isEnabled(true)).toBe(true);
|
|
});
|
|
|
|
test('should return false when input is "false"', () => {
|
|
expect(isEnabled('false')).toBe(false);
|
|
});
|
|
|
|
test('should return false when input is false', () => {
|
|
expect(isEnabled(false)).toBe(false);
|
|
});
|
|
|
|
test('should return false when input is null', () => {
|
|
expect(isEnabled(null)).toBe(false);
|
|
});
|
|
|
|
test('should return false when input is undefined', () => {
|
|
expect(isEnabled()).toBe(false);
|
|
});
|
|
|
|
test('should return false when input is an empty string', () => {
|
|
expect(isEnabled('')).toBe(false);
|
|
});
|
|
|
|
test('should return false when input is a whitespace string', () => {
|
|
expect(isEnabled(' ')).toBe(false);
|
|
});
|
|
|
|
test('should return false when input is a number', () => {
|
|
expect(isEnabled(123)).toBe(false);
|
|
});
|
|
|
|
test('should return false when input is an object', () => {
|
|
expect(isEnabled({})).toBe(false);
|
|
});
|
|
|
|
test('should return false when input is an array', () => {
|
|
expect(isEnabled([])).toBe(false);
|
|
});
|
|
});
|
|
|
|
jest.mock('crypto', () => {
|
|
const actualModule = jest.requireActual('crypto');
|
|
return {
|
|
...actualModule,
|
|
randomBytes: jest.fn().mockReturnValue(Buffer.from('abc123', 'hex')),
|
|
};
|
|
});
|
|
|
|
describe('sanitizeFilename', () => {
|
|
test('removes directory components (1/2)', () => {
|
|
expect(sanitizeFilename('/path/to/file.txt')).toBe('file.txt');
|
|
});
|
|
|
|
test('removes directory components (2/2)', () => {
|
|
expect(sanitizeFilename('../../../../file.txt')).toBe('file.txt');
|
|
});
|
|
|
|
test('replaces non-alphanumeric characters', () => {
|
|
expect(sanitizeFilename('file name@#$.txt')).toBe('file_name___.txt');
|
|
});
|
|
|
|
test('preserves dots and hyphens', () => {
|
|
expect(sanitizeFilename('file-name.with.dots.txt')).toBe('file-name.with.dots.txt');
|
|
});
|
|
|
|
test('prepends underscore to filenames starting with a dot', () => {
|
|
expect(sanitizeFilename('.hiddenfile')).toBe('_.hiddenfile');
|
|
});
|
|
|
|
test('truncates long filenames', () => {
|
|
const longName = 'a'.repeat(300) + '.txt';
|
|
const result = sanitizeFilename(longName);
|
|
expect(result.length).toBe(255);
|
|
expect(result).toMatch(/^a+-abc123\.txt$/);
|
|
});
|
|
|
|
test('handles filenames with no extension', () => {
|
|
const longName = 'a'.repeat(300);
|
|
const result = sanitizeFilename(longName);
|
|
expect(result.length).toBe(255);
|
|
expect(result).toMatch(/^a+-abc123$/);
|
|
});
|
|
|
|
test('handles empty input', () => {
|
|
expect(sanitizeFilename('')).toBe('_');
|
|
});
|
|
|
|
test('handles input with only special characters', () => {
|
|
expect(sanitizeFilename('@#$%^&*')).toBe('_______');
|
|
});
|
|
});
|