diff --git a/CHANGELOG.md b/CHANGELOG.md
index d1c7a799ffd..13812c17649 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -238,6 +238,9 @@
- Expand `ApolloError` typings to include `ServerError` and `ServerParseError`.
[@dmarkow](https://github.com/dmarkow) in [#6319](https://github.com/apollographql/apollo-client/pull/6319)
+- Fast responses received over the link chain will no longer conflict with `skip` settings.
+ [@hwillson](https://github.com/hwillson) in [#6587](https://github.com/apollographql/apollo-client/pull/6587)
+
## Apollo Client 2.6.8
### Apollo Client (2.6.8)
diff --git a/src/react/data/QueryData.ts b/src/react/data/QueryData.ts
index 86d132e2205..4d3ad689830 100644
--- a/src/react/data/QueryData.ts
+++ b/src/react/data/QueryData.ts
@@ -279,18 +279,6 @@ export class QueryData extends OperationData {
return;
}
- // If we skipped previously, `previousResult.data` is set to undefined.
- // When this subscription is run after skipping, Apollo Client sends
- // the last query result data alongside the `loading` true state. This
- // means the previous skipped `data` of undefined and the incoming
- // data won't match, which would normally mean we want to trigger a
- // render to show the new data. In this case however we're already
- // showing the loading state, and want to avoid triggering an
- // additional and unnecessary render showing the same loading state.
- if (this.previousOptions.skip) {
- return;
- }
-
onNewData();
},
error: error => {
diff --git a/src/react/hooks/__tests__/useQuery.test.tsx b/src/react/hooks/__tests__/useQuery.test.tsx
index b2755292f5f..9ec841088e5 100644
--- a/src/react/hooks/__tests__/useQuery.test.tsx
+++ b/src/react/hooks/__tests__/useQuery.test.tsx
@@ -2069,4 +2069,45 @@ describe('useQuery Hook', () => {
}).then(resolve, reject);
});
});
+
+ describe('Skipping', () => {
+ itAsync('should skip running a query when `skip` is `true`', (resolve, reject) => {
+ let renderCount = 0;
+
+ const Component = () => {
+ const [skip, setSkip] = useState(true);
+ const { loading, data } = useQuery(CAR_QUERY, { skip });
+
+ switch (++renderCount) {
+ case 1:
+ expect(loading).toBeFalsy();
+ expect(data).toBeUndefined();
+ setTimeout(() => setSkip(false));
+ break;
+ case 2:
+ expect(loading).toBeTruthy();
+ expect(data).toBeUndefined();
+ break;
+ case 3:
+ expect(loading).toBeFalsy();
+ expect(data).toEqual(CAR_RESULT_DATA);
+ break;
+ default:
+ reject("too many renders");
+ }
+
+ return null;
+ };
+
+ render(
+
+
+
+ );
+
+ return wait(() => {
+ expect(renderCount).toBe(3);
+ }).then(resolve, reject);
+ });
+ });
});