-
Notifications
You must be signed in to change notification settings - Fork 0
/
getNews.spec.ts
65 lines (53 loc) · 1.49 KB
/
getNews.spec.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import { contentfulDeliveryClient } from './contentful';
import getNews from './getNews';
jest.mock('./flattenAssetFields', () => ({
flattenImageAssetFields: jest.fn((item) => item),
}));
jest.mock('./contentful', () => ({
contentfulDeliveryClient: {
getEntries: jest.fn(),
},
}));
const mockedEntries = {
title: 'test title',
slug: 'test-slug',
date: 'test date',
category: 'test category',
keywords: ['test-keyword-1', 'test-keyword-2'],
content: 'test content',
description: 'test description',
image: 'test image',
};
beforeEach(() => {
(contentfulDeliveryClient.getEntries as jest.Mock)
.mockImplementation(() => ({ items: [{ fields: mockedEntries }] }));
});
afterEach(() => {
jest.clearAllMocks();
});
it('Queries news articles', async () => {
const result = await getNews({ limit: 12 });
expect(contentfulDeliveryClient.getEntries).toHaveBeenCalledTimes(1);
expect(contentfulDeliveryClient.getEntries).toHaveBeenNthCalledWith(1, {
content_type: 'newsArticle',
order: ['-fields.date'],
limit: 12,
});
expect(result).toStrictEqual([mockedEntries]);
});
it('Queries new articles with no keywords', async () => {
(contentfulDeliveryClient.getEntries as jest.Mock)
.mockImplementation(() => ({
items: [{
fields: {
...mockedEntries,
keywords: undefined,
},
}],
}));
const result = await getNews({ limit: 100 });
expect(result).toStrictEqual([{
...mockedEntries,
keywords: [],
}]);
});