mirror of
https://github.com/danny-avila/LibreChat.git
synced 2026-03-15 12:16:33 +01:00
* fix: add file size limits to conversation import multer instance * fix: address review findings for conversation import file size limits * fix: use local jest.mock for data-schemas instead of global moduleNameMapper The global @librechat/data-schemas mock in jest.config.js only provided logger, breaking all tests that depend on createModels from the same package. Replace with a virtual jest.mock scoped to the import spec file. * fix: move import to top of file, pre-compute upload middleware, assert logger.warn in tests * refactor: move resolveImportMaxFileSize to packages/api New backend logic belongs in packages/api as TypeScript. Delete the api/server/utils/import/limits.js wrapper and import directly from @librechat/api in convos.js and importConversations.js. Resolver unit tests move to packages/api; the api/ spec retains only multer behavior tests. * chore: rename importLimits to import * fix: stale type reference and mock isolation in import tests Update typeof import path from '../importLimits' to '../import' after the rename. Clear mockLogger.warn in beforeEach to prevent cross-test accumulation. * fix: add resolveImportMaxFileSize to @librechat/api mock in convos.spec.js * fix: resolve jest.mock hoisting issue in import tests jest.mock factories are hoisted above const declarations, so the mockLogger reference was undefined at factory evaluation time. Use a direct import of the mocked logger module instead. * fix: remove virtual flag from data-schemas mock for CI compatibility virtual: true prevents the mock from intercepting the real module in CI where @librechat/data-schemas is built, causing import.ts to use the real logger while the test asserts against the mock.
93 lines
2.1 KiB
JavaScript
93 lines
2.1 KiB
JavaScript
module.exports = {
|
|
agents: () => ({ sleep: jest.fn() }),
|
|
|
|
api: (overrides = {}) => ({
|
|
isEnabled: jest.fn(),
|
|
resolveImportMaxFileSize: jest.fn(() => 262144000),
|
|
createAxiosInstance: jest.fn(() => ({
|
|
get: jest.fn(),
|
|
post: jest.fn(),
|
|
put: jest.fn(),
|
|
delete: jest.fn(),
|
|
})),
|
|
logAxiosError: jest.fn(),
|
|
...overrides,
|
|
}),
|
|
|
|
dataSchemas: () => ({
|
|
logger: {
|
|
debug: jest.fn(),
|
|
info: jest.fn(),
|
|
warn: jest.fn(),
|
|
error: jest.fn(),
|
|
},
|
|
createModels: jest.fn(() => ({
|
|
User: {},
|
|
Conversation: {},
|
|
Message: {},
|
|
SharedLink: {},
|
|
})),
|
|
}),
|
|
|
|
dataProvider: (overrides = {}) => ({
|
|
CacheKeys: { GEN_TITLE: 'GEN_TITLE' },
|
|
EModelEndpoint: {
|
|
azureAssistants: 'azureAssistants',
|
|
assistants: 'assistants',
|
|
},
|
|
...overrides,
|
|
}),
|
|
|
|
conversationModel: () => ({
|
|
getConvosByCursor: jest.fn(),
|
|
getConvo: jest.fn(),
|
|
deleteConvos: jest.fn(),
|
|
saveConvo: jest.fn(),
|
|
}),
|
|
|
|
toolCallModel: () => ({ deleteToolCalls: jest.fn() }),
|
|
|
|
sharedModels: () => ({
|
|
deleteAllSharedLinks: jest.fn(),
|
|
deleteConvoSharedLink: jest.fn(),
|
|
}),
|
|
|
|
requireJwtAuth: () => (req, res, next) => next(),
|
|
|
|
middlewarePassthrough: () => ({
|
|
createImportLimiters: jest.fn(() => ({
|
|
importIpLimiter: (req, res, next) => next(),
|
|
importUserLimiter: (req, res, next) => next(),
|
|
})),
|
|
createForkLimiters: jest.fn(() => ({
|
|
forkIpLimiter: (req, res, next) => next(),
|
|
forkUserLimiter: (req, res, next) => next(),
|
|
})),
|
|
configMiddleware: (req, res, next) => next(),
|
|
validateConvoAccess: (req, res, next) => next(),
|
|
}),
|
|
|
|
forkUtils: () => ({
|
|
forkConversation: jest.fn(),
|
|
duplicateConversation: jest.fn(),
|
|
}),
|
|
|
|
importUtils: () => ({ importConversations: jest.fn() }),
|
|
|
|
logStores: () => jest.fn(),
|
|
|
|
multerSetup: () => ({
|
|
storage: {},
|
|
importFileFilter: jest.fn(),
|
|
}),
|
|
|
|
multerLib: () =>
|
|
jest.fn(() => ({
|
|
single: jest.fn(() => (req, res, next) => {
|
|
req.file = { path: '/tmp/test-file.json' };
|
|
next();
|
|
}),
|
|
})),
|
|
|
|
assistantEndpoint: () => ({ initializeClient: jest.fn() }),
|
|
};
|