From 4aaa119b6e857c4421ead24e7fd5284481e82a7b Mon Sep 17 00:00:00 2001 From: Jerel Miller Date: Mon, 26 Aug 2024 16:10:53 -0600 Subject: [PATCH] Ensure useFragment handles top-level null/undefined --- src/core/__tests__/masking.test.ts | 33 ++++++++++++++++++++++++++++++ src/core/masking.ts | 5 +++++ 2 files changed, 38 insertions(+) diff --git a/src/core/__tests__/masking.test.ts b/src/core/__tests__/masking.test.ts index 3c884ec4a3f..27063e7be1d 100644 --- a/src/core/__tests__/masking.test.ts +++ b/src/core/__tests__/masking.test.ts @@ -1821,6 +1821,39 @@ describe("maskOperation", () => { }); describe("maskFragment", () => { + test("returns null when data is null", () => { + const fragment = gql` + fragment Foo on Query { + foo + ...QueryFields + } + + fragment QueryFields on Query { + bar + } + `; + + const data = maskFragment(null, fragment, new InMemoryCache(), "Foo"); + + expect(data).toBe(null); + }); + + test("returns undefined when data is undefined", () => { + const fragment = gql` + fragment Foo on Query { + foo + ...QueryFields + } + + fragment QueryFields on Query { + bar + } + `; + + const data = maskFragment(undefined, fragment, new InMemoryCache(), "Foo"); + + expect(data).toBe(undefined); + }); test("masks named fragments in fragment documents", () => { const fragment = gql` fragment UserFields on User { diff --git a/src/core/masking.ts b/src/core/masking.ts index 19f552598c5..6dac331e968 100644 --- a/src/core/masking.ts +++ b/src/core/masking.ts @@ -105,6 +105,11 @@ export function maskFragment( fragmentName ); + if (data == null) { + // Maintain the original `null` or `undefined` value + return data; + } + const context: MaskingContext = { operationType: "fragment", operationName: fragment.name.value,