From 3cb76de16ef2acd8a0eb8cf5f15499ad2a58f52c Mon Sep 17 00:00:00 2001 From: Adrien FIGARD Date: Tue, 6 Aug 2024 11:31:43 +0200 Subject: [PATCH] :bug: Fix bug when types are not versioned --- patches/@graphql-tools+executor+1.2.1.patch | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/patches/@graphql-tools+executor+1.2.1.patch b/patches/@graphql-tools+executor+1.2.1.patch index 2f43831..ac833db 100644 --- a/patches/@graphql-tools+executor+1.2.1.patch +++ b/patches/@graphql-tools+executor+1.2.1.patch @@ -1,7 +1,7 @@ diff --git a/node_modules/@graphql-tools/executor/cjs/execution/execute.js b/node_modules/@graphql-tools/executor/cjs/execution/execute.js old mode 100644 new mode 100755 -index 791e3df..0333b51 +index 791e3df..1e8e7fb --- a/node_modules/@graphql-tools/executor/cjs/execution/execute.js +++ b/node_modules/@graphql-tools/executor/cjs/execution/execute.js @@ -628,8 +628,13 @@ function completeAbstractValue(exeContext, returnType, fieldNodes, info, path, r @@ -19,7 +19,7 @@ index 791e3df..0333b51 } // releases before 16.0.0 supported returning `GraphQLObjectType` from `resolveType` // TODO: remove in 17.0.0 release -@@ -640,6 +645,18 @@ function ensureValidRuntimeType(runtimeTypeName, exeContext, returnType, fieldNo +@@ -640,6 +645,25 @@ function ensureValidRuntimeType(runtimeTypeName, exeContext, returnType, fieldNo throw (0, utils_1.createGraphQLError)(`Abstract type "${returnType.name}" must resolve to an Object type at runtime for field "${info.parentType.name}.${info.fieldName}" with ` + `value ${(0, utils_1.inspect)(result)}, received "${(0, utils_1.inspect)(runtimeTypeName)}".`); } @@ -29,8 +29,15 @@ index 791e3df..0333b51 + .find(a => a.name.value === "mapping").value.value) + Object.keys(mappedTypes).forEach((type) => { + // For each key in the mapping object, check if the runtimeTypeName includes the key -+ const runtimeTypeNameWithoutVersion = runtimeTypeName.substring(0, runtimeTypeName.length-3) -+ if (runtimeTypeNameWithoutVersion === type) { ++ const splits = runtimeTypeName.split('_') ++ // Remove the version ++ splits.pop() ++ let joinedSplits = f.join('_') ++ // If the runtimeTypeName is not versioned ++ if (joinedSplits === "") { ++ joinedSplits = runtimeTypeName ++ } ++ if (joinedSplits === type) { + // Replace the key with its corresponding mapped type in the runtimeTypeName + runtimeTypeName = runtimeTypeName.replace(type, mappedTypes[type]) + }