From fb749e8befb2dcdc266c2e8b7ef7c9001947143a Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Mon, 27 Nov 2023 19:40:40 +0100 Subject: test(services): add tests for posts fetchers --- .../graphql/fetchers/posts/fetch-post.test.ts | 23 ++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 src/services/graphql/fetchers/posts/fetch-post.test.ts (limited to 'src/services/graphql/fetchers/posts/fetch-post.test.ts') diff --git a/src/services/graphql/fetchers/posts/fetch-post.test.ts b/src/services/graphql/fetchers/posts/fetch-post.test.ts new file mode 100644 index 0000000..e19e4de --- /dev/null +++ b/src/services/graphql/fetchers/posts/fetch-post.test.ts @@ -0,0 +1,23 @@ +import { describe, expect, it } from '@jest/globals'; +import { wpPostsFixture } from '../../../../../tests/fixtures'; +import { fetchPost } from './fetch-post'; + +describe('fetch-post', () => { + it('returns a post by slug', async () => { + const result = await fetchPost(wpPostsFixture[2].slug); + + expect.assertions(1); + + expect(result).toStrictEqual(wpPostsFixture[2]); + }); + + it('rejects with an error when the slug does not exist', async () => { + const slug = '/inexistent-slug'; + + expect.assertions(1); + + await expect(async () => fetchPost(slug)).rejects.toEqual( + new Error(`No post found for the following slug ${slug}.`) + ); + }); +}); -- cgit v1.2.3