Skip to content

Commit

Permalink
Add documentation tests
Browse files Browse the repository at this point in the history
  • Loading branch information
gzm0 committed Oct 16, 2023
1 parent c585e90 commit 8fe4798
Showing 1 changed file with 65 additions and 1 deletion.
66 changes: 65 additions & 1 deletion src/testing/react/__tests__/MockedProvider.test.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import React from "react";
import { DocumentNode } from "graphql";
import { render, waitFor } from "@testing-library/react";
import { render, screen, waitFor } from "@testing-library/react";
import gql from "graphql-tag";

import { itAsync, MockedResponse, MockLink } from "../../core";
Expand Down Expand Up @@ -708,6 +708,70 @@ describe("General use", () => {
}).then(resolve, reject);
}
);

it("should support loading state testing with delay", async () => {
function Component({ username }: Variables) {
const { loading, data } = useQuery<Data, Variables>(query, { variables });

if (loading || data === undefined) return <p>Loading the user ID...</p>;

return <p>The user ID is '{data.user.id}'</p>;
}

const mocks: ReadonlyArray<MockedResponse> = [
{
delay: 30, // prevent React from batching the loading state away
request: {
query,
variables,
},
result: { data: { user } },
},
];

render(
<MockedProvider mocks={mocks}>
<Component {...variables} />
</MockedProvider>
);

expect(
await screen.findByText("Loading the user ID...")
).toBeInTheDocument();
expect(
await screen.findByText("The user ID is 'user_id'")
).toBeInTheDocument();
});

it("should support loading state testing with infinite delay", async () => {
function Component({ username }: Variables) {
const { loading, data } = useQuery<Data, Variables>(query, { variables });

if (loading || data === undefined) return <p>Loading the user ID...</p>;

return <p>The user ID is '{data.user.id}'</p>;
}

const mocks: ReadonlyArray<MockedResponse> = [
{
delay: Infinity, // keep loading forever.
request: {
query,
variables,
},
},
];

render(
<MockedProvider mocks={mocks}>
<Component {...variables} />
</MockedProvider>
);

expect(
await screen.findByText("Loading the user ID...")
).toBeInTheDocument();
});
});

describe("@client testing", () => {
Expand Down

0 comments on commit 8fe4798

Please sign in to comment.