test existing and new items in batches
This commit is contained in:
		@@ -190,5 +190,42 @@ describe('ScrapingService', () => {
 | 
			
		||||
      await expect(scrapingService.processFeedBatch(feedItems)).rejects.toThrow('Database connection failed');
 | 
			
		||||
      expect(mockFeedRepository.findByUrl).toHaveBeenCalledWith(feedItems[0].url);
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    test('should handle mixed results in batch processing', async () => {
 | 
			
		||||
      const feedItems = [
 | 
			
		||||
        {
 | 
			
		||||
          title: 'New News',
 | 
			
		||||
          description: 'New description',
 | 
			
		||||
          url: 'https://example.com/new-news',
 | 
			
		||||
          source: 'El País' as any,
 | 
			
		||||
          publishedAt: new Date(),
 | 
			
		||||
          isManual: false
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          title: 'Existing News',
 | 
			
		||||
          description: 'Existing description',
 | 
			
		||||
          url: 'https://example.com/existing-news',
 | 
			
		||||
          source: 'El País' as any,
 | 
			
		||||
          publishedAt: new Date(),
 | 
			
		||||
          isManual: false
 | 
			
		||||
        }
 | 
			
		||||
      ];
 | 
			
		||||
      
 | 
			
		||||
      const savedFeed = { _id: '1', ...feedItems[0] };
 | 
			
		||||
      const existingFeed = { _id: '2', ...feedItems[1] };
 | 
			
		||||
      
 | 
			
		||||
      mockFeedRepository.findByUrl
 | 
			
		||||
        .mockResolvedValueOnce(null)
 | 
			
		||||
        .mockResolvedValueOnce(existingFeed);
 | 
			
		||||
      mockFeedRepository.create.mockResolvedValue(savedFeed);
 | 
			
		||||
      
 | 
			
		||||
      const results = await scrapingService.processFeedBatch(feedItems);
 | 
			
		||||
      
 | 
			
		||||
      expect(mockFeedRepository.findByUrl).toHaveBeenCalledTimes(2);
 | 
			
		||||
      expect(mockFeedRepository.create).toHaveBeenCalledTimes(1);
 | 
			
		||||
      expect(results).toHaveLength(2);
 | 
			
		||||
      expect(results[0]).toEqual(savedFeed);
 | 
			
		||||
      expect(results[1]).toBeNull();
 | 
			
		||||
    });
 | 
			
		||||
  });
 | 
			
		||||
});
 | 
			
		||||
		Reference in New Issue
	
	Block a user