diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/fixtures/index.ts | 1 | ||||
| -rw-r--r-- | tests/fixtures/wp-comments.fixture.ts | 104 | ||||
| -rw-r--r-- | tests/msw/handlers/comments/comments-list.handler.ts | 39 | ||||
| -rw-r--r-- | tests/msw/handlers/comments/index.ts | 3 | ||||
| -rw-r--r-- | tests/msw/handlers/index.ts | 3 | ||||
| -rw-r--r-- | tests/msw/schema/types/author.types.ts | 15 | ||||
| -rw-r--r-- | tests/msw/schema/types/comment.types.ts | 74 | ||||
| -rw-r--r-- | tests/msw/schema/types/common.types.ts | 13 | ||||
| -rw-r--r-- | tests/msw/schema/types/index.ts | 9 |
9 files changed, 246 insertions, 15 deletions
diff --git a/tests/fixtures/index.ts b/tests/fixtures/index.ts index c2e1c04..0c624c2 100644 --- a/tests/fixtures/index.ts +++ b/tests/fixtures/index.ts @@ -1 +1,2 @@ +export * from './wp-comments.fixture'; export * from './wp-posts.fixture'; diff --git a/tests/fixtures/wp-comments.fixture.ts b/tests/fixtures/wp-comments.fixture.ts new file mode 100644 index 0000000..3e0a1bb --- /dev/null +++ b/tests/fixtures/wp-comments.fixture.ts @@ -0,0 +1,104 @@ +import type { WPComment } from '../../src/types'; + +export const wpCommentsFixture: WPComment[] = [ + { + approved: true, + author: { + node: { + avatar: { + height: 96, + url: 'https://cloudflare-ipfs.com/ipfs/Qmd3W5DuhgHirLHGVixi6V76LhCkZUz6pnFt5AJBiyvHye/avatar/1225.jpg', + width: 96, + }, + name: 'London70', + url: null, + }, + }, + content: + 'Aliquid dolore molestiae eaque. Sint velit consectetur nesciunt est maxime. Ut qui harum ut quae iure. Voluptatem eius aut tempore repudiandae corrupti dignissimos.', + databaseId: 1, + date: '2022-04-21', + parentDatabaseId: 0, + status: 'APPROVE', + }, + { + approved: true, + author: { + node: { + avatar: { + height: 96, + url: 'https://cloudflare-ipfs.com/ipfs/Qmd3W5DuhgHirLHGVixi6V76LhCkZUz6pnFt5AJBiyvHye/avatar/168.jpg', + width: 96, + }, + name: 'Wilburn.Tillman5', + url: null, + }, + }, + content: + 'Sit labore quia excepturi repellat minus exercitationem. Nihil veniam sed voluptas a doloremque voluptatum. Quia accusantium totam accusamus quia qui dolorem autem ut. Et reprehenderit voluptates.', + databaseId: 2, + date: '2022-05-11', + parentDatabaseId: 0, + status: 'APPROVE', + }, + { + approved: true, + author: { + node: { + avatar: { + height: 96, + url: 'https://cloudflare-ipfs.com/ipfs/Qmd3W5DuhgHirLHGVixi6V76LhCkZUz6pnFt5AJBiyvHye/avatar/419.jpg', + width: 96, + }, + name: 'Addison27', + url: 'https://example.test', + }, + }, + content: + 'Cupiditate beatae ea vel dolore porro magnam in. Nostrum eum corrupti. Exercitationem cupiditate deserunt sunt quia quia ipsum placeat sit. Est maiores dolor qui. A tempora repellendus cumque voluptatem omnis beatae dolor nobis. Quis aut eos.', + databaseId: 3, + date: '2022-05-16', + parentDatabaseId: 1, + status: 'APPROVE', + }, + { + approved: true, + author: { + node: { + avatar: { + height: 96, + url: 'https://cloudflare-ipfs.com/ipfs/Qmd3W5DuhgHirLHGVixi6V76LhCkZUz6pnFt5AJBiyvHye/avatar/810.jpg', + width: 96, + }, + name: 'Mariana20', + url: null, + }, + }, + content: + 'Placeat iste unde. Et ad rem aut dolor placeat sunt aliquid aliquam. Dolor repellendus quis alias consequatur nihil.', + databaseId: 4, + date: '2022-05-17', + parentDatabaseId: 0, + status: 'APPROVE', + }, + { + approved: false, + author: { + node: { + avatar: { + height: 96, + url: 'https://cloudflare-ipfs.com/ipfs/Qmd3W5DuhgHirLHGVixi6V76LhCkZUz6pnFt5AJBiyvHye/avatar/1202.jpg', + width: 96, + }, + name: 'Willow8', + url: null, + }, + }, + content: + 'Debitis quia fuga itaque voluptatem consequatur dolores. Praesentium quibusdam non sequi. Inventore voluptatem qui ad. Aperiam labore maxime qui necessitatibus. Sed molestias veritatis et.', + databaseId: 4, + date: '2022-06-02', + parentDatabaseId: 2, + status: 'HOLD', + }, +]; diff --git a/tests/msw/handlers/comments/comments-list.handler.ts b/tests/msw/handlers/comments/comments-list.handler.ts new file mode 100644 index 0000000..e815a0e --- /dev/null +++ b/tests/msw/handlers/comments/comments-list.handler.ts @@ -0,0 +1,39 @@ +import { type ExecutionResult, graphql as executeGraphql } from 'graphql'; +import { HttpResponse, graphql } from 'msw'; +import type { + FetchCommentsListInput, + CommentsListResponse, +} from '../../../../src/services/graphql'; +import { wpCommentsFixture } from '../../../fixtures'; +import { schema } from '../../schema'; + +export const commentsListHandler = graphql.query< + CommentsListResponse, + FetchCommentsListInput +>('CommentsList', async ({ query, variables }) => { + const pageParams = new URLSearchParams(window.location.search); + const isError = pageParams.get('error') === 'true'; + + if (isError) return HttpResponse.json({ data: { comments: null } }); + + const { data, errors } = (await executeGraphql({ + schema, + source: query, + variableValues: variables, + rootValue: { + comments({ first, where }: typeof variables) { + const { status: commentStatus } = where ?? {}; + const filteredComments = commentStatus + ? wpCommentsFixture.filter( + (comment) => comment.status === commentStatus + ) + : wpCommentsFixture; + const comments = filteredComments.slice(0, first); + + return { nodes: comments }; + }, + }, + })) as ExecutionResult<CommentsListResponse>; + + return HttpResponse.json({ data, errors }); +}); diff --git a/tests/msw/handlers/comments/index.ts b/tests/msw/handlers/comments/index.ts new file mode 100644 index 0000000..349355b --- /dev/null +++ b/tests/msw/handlers/comments/index.ts @@ -0,0 +1,3 @@ +import { commentsListHandler } from './comments-list.handler'; + +export const commentsHandlers = [commentsListHandler]; diff --git a/tests/msw/handlers/index.ts b/tests/msw/handlers/index.ts index decbc9f..5f331e7 100644 --- a/tests/msw/handlers/index.ts +++ b/tests/msw/handlers/index.ts @@ -1,3 +1,4 @@ +import { commentsHandlers } from './comments'; import { postsHandlers } from './posts'; -export const handlers = [...postsHandlers]; +export const handlers = [...commentsHandlers, ...postsHandlers]; diff --git a/tests/msw/schema/types/author.types.ts b/tests/msw/schema/types/author.types.ts index bbb50a4..53c0bb7 100644 --- a/tests/msw/schema/types/author.types.ts +++ b/tests/msw/schema/types/author.types.ts @@ -1,17 +1,4 @@ -export const authorTypes = `enum AvatarRatingEnum { - G - PG - R - X -} - -type Avatar { - height: Int - url: String - width: Int -} - -type User { +export const authorTypes = `type User { avatar( forceDefault: Boolean rating: AvatarRatingEnum diff --git a/tests/msw/schema/types/comment.types.ts b/tests/msw/schema/types/comment.types.ts new file mode 100644 index 0000000..00cff77 --- /dev/null +++ b/tests/msw/schema/types/comment.types.ts @@ -0,0 +1,74 @@ +export const commentTypes = `enum CommentsConnectionOrderbyEnum { + COMMENT_AGENT + COMMENT_APPROVED + COMMENT_AUTHOR + COMMENT_AUTHOR_EMAIL + COMMENT_AUTHOR_IP + COMMENT_AUTHOR_URL + COMMENT_CONTENT + COMMENT_DATE + COMMENT_DATE_GMT + COMMENT_ID + COMMENT_IN + COMMENT_KARMA + COMMENT_PARENT + COMMENT_POST_ID + COMMENT_TYPE + USER_ID +} + +type Commenter { + avatar: Avatar + name: String + url: String +} + +type CommentToCommenterConnectionEdge { + cursor: String + node: Commenter! +} + +enum CommentStatusEnum { + APPROVE + HOLD + SPAM + TRASH +} + +type Comment { + approved: Boolean + author: CommentToCommenterConnectionEdge + content(format: PostObjectFieldFormatEnum): String + databaseId: Int! + date: String + parentDatabaseId: Int + status: CommentStatusEnum +} + +input RootQueryToCommentConnectionWhereArgs { + contentId: ID + contentName: String + order: OrderEnum + orderby: CommentsConnectionOrderbyEnum + parent: Int + status: String +} + +type RootQueryToCommentConnectionPageInfo { + endCursor: String + hasNextPage: Boolean! + hasPreviousPage: Boolean! + startCursor: String + total: Int +} + +type RootQueryToCommentConnectionEdge { + cursor: String + node: Comment! +} + +type RootQueryToCommentConnection { + edges: [RootQueryToCommentConnectionEdge!]! + nodes: [Comment!]! + pageInfo: RootQueryToCommentConnectionPageInfo! +}`; diff --git a/tests/msw/schema/types/common.types.ts b/tests/msw/schema/types/common.types.ts index 23baeb3..03e066c 100644 --- a/tests/msw/schema/types/common.types.ts +++ b/tests/msw/schema/types/common.types.ts @@ -21,6 +21,19 @@ enum PostObjectsConnectionOrderbyEnum { TITLE } +enum AvatarRatingEnum { + G + PG + R + X +} + +type Avatar { + height: Int + url: String + width: Int +} + type ContentPartsType { afterMore(format: PostObjectFieldFormatEnum): String beforeMore(format: PostObjectFieldFormatEnum): String diff --git a/tests/msw/schema/types/index.ts b/tests/msw/schema/types/index.ts index 163955b..c34cacd 100644 --- a/tests/msw/schema/types/index.ts +++ b/tests/msw/schema/types/index.ts @@ -1,4 +1,5 @@ import { authorTypes } from './author.types'; +import { commentTypes } from './comment.types'; import { commonTypes } from './common.types'; import { featuredImageTypes } from './featured-image.types'; import { postTypes } from './post.types'; @@ -6,6 +7,13 @@ import { thematicTypes } from './thematic.types'; import { topicTypes } from './topic.types'; const rootQueryType = `type Query { + comments( + after: String + before: String + first: Int + last: Int + where: RootQueryToCommentConnectionWhereArgs + ): RootQueryToCommentConnection post( asPreview: Boolean id: ID! @@ -22,6 +30,7 @@ const rootQueryType = `type Query { export const types = [ authorTypes, + commentTypes, commonTypes, featuredImageTypes, postTypes, |
