Compare commits

...

2 Commits

Author SHA1 Message Date
Gitea Actions
ecec686347 ci: Bump version to 0.7.5 [skip ci] 2025-12-31 22:27:56 +05:00
86de680080 flyer processing fixes
All checks were successful
Deploy to Test Environment / deploy-to-test (push) Successful in 16m36s
2025-12-31 09:27:06 -08:00
3 changed files with 11 additions and 7 deletions

4
package-lock.json generated
View File

@@ -1,12 +1,12 @@
{
"name": "flyer-crawler",
"version": "0.7.4",
"version": "0.7.5",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"name": "flyer-crawler",
"version": "0.7.4",
"version": "0.7.5",
"dependencies": {
"@bull-board/api": "^6.14.2",
"@bull-board/express": "^6.14.2",

View File

@@ -1,7 +1,7 @@
{
"name": "flyer-crawler",
"private": true,
"version": "0.7.4",
"version": "0.7.5",
"type": "module",
"scripts": {
"dev": "concurrently \"npm:start:dev\" \"vite\"",

View File

@@ -63,7 +63,8 @@ describe('FlyerAiProcessor', () => {
};
vi.mocked(mockAiService.extractCoreDataFromFlyerImage).mockResolvedValue(mockAiResponse);
const result = await service.extractAndValidateData([], jobData, logger);
const imagePaths = [{ path: 'page1.jpg', mimetype: 'image/jpeg' }];
const result = await service.extractAndValidateData(imagePaths, jobData, logger);
expect(mockAiService.extractCoreDataFromFlyerImage).toHaveBeenCalledTimes(1);
expect(mockPersonalizationRepo.getAllMasterItems).toHaveBeenCalledTimes(1);
@@ -83,7 +84,8 @@ describe('FlyerAiProcessor', () => {
};
vi.mocked(mockAiService.extractCoreDataFromFlyerImage).mockResolvedValue(invalidResponse as any);
await expect(service.extractAndValidateData([], jobData, logger)).rejects.toThrow(
const imagePaths = [{ path: 'page1.jpg', mimetype: 'image/jpeg' }];
await expect(service.extractAndValidateData(imagePaths, jobData, logger)).rejects.toThrow(
AiDataValidationError,
);
});
@@ -101,7 +103,8 @@ describe('FlyerAiProcessor', () => {
vi.mocked(mockAiService.extractCoreDataFromFlyerImage).mockResolvedValue(mockAiResponse as any);
const { logger } = await import('./logger.server');
const result = await service.extractAndValidateData([], jobData, logger);
const imagePaths = [{ path: 'page1.jpg', mimetype: 'image/jpeg' }];
const result = await service.extractAndValidateData(imagePaths, jobData, logger);
// It should not throw, but return the data and log a warning.
expect(result.data).toEqual(mockAiResponse);
@@ -122,7 +125,8 @@ describe('FlyerAiProcessor', () => {
vi.mocked(mockAiService.extractCoreDataFromFlyerImage).mockResolvedValue(mockAiResponse);
const { logger } = await import('./logger.server');
const result = await service.extractAndValidateData([], jobData, logger);
const imagePaths = [{ path: 'page1.jpg', mimetype: 'image/jpeg' }];
const result = await service.extractAndValidateData(imagePaths, jobData, logger);
expect(result.data).toEqual(mockAiResponse);
expect(result.needsReview).toBe(true);
expect(logger.warn).toHaveBeenCalledWith(expect.any(Object), expect.stringContaining('contains no items. The flyer will be saved with an item_count of 0. Flagging for review.'));