From efdbbcfacd92adb78e002f2b8a61f2a6a1504c19 Mon Sep 17 00:00:00 2001 From: Ivan Goncharov Date: Thu, 13 Jan 2022 18:47:41 +0200 Subject: [PATCH] OverlappingFieldsCanBeMergedRule: simplify argument comparison --- .../rules/OverlappingFieldsCanBeMergedRule.ts | 42 +++++++------------ 1 file changed, 15 insertions(+), 27 deletions(-) diff --git a/src/validation/rules/OverlappingFieldsCanBeMergedRule.ts b/src/validation/rules/OverlappingFieldsCanBeMergedRule.ts index 83f6945703..a7d2b257b7 100644 --- a/src/validation/rules/OverlappingFieldsCanBeMergedRule.ts +++ b/src/validation/rules/OverlappingFieldsCanBeMergedRule.ts @@ -5,11 +5,10 @@ import type { ObjMap } from '../../jsutils/ObjMap'; import { GraphQLError } from '../../error/GraphQLError'; import type { - ArgumentNode, FieldNode, FragmentDefinitionNode, + ObjectValueNode, SelectionSetNode, - ValueNode, } from '../../language/ast'; import { Kind } from '../../language/kinds'; import { print } from '../../language/printer'; @@ -588,12 +587,8 @@ function findConflict( ]; } - // FIXME https://github.com/graphql/graphql-js/issues/2203 - const args1 = /* c8 ignore next */ node1.arguments ?? []; - const args2 = /* c8 ignore next */ node2.arguments ?? []; - // Two field calls must have the same arguments. - if (!sameArguments(args1, args2)) { + if (stringifyArguments(node1) !== stringifyArguments(node2)) { return [ [responseName, 'they have differing arguments'], [node1], @@ -639,26 +634,19 @@ function findConflict( } } -function sameArguments( - arguments1: ReadonlyArray, - arguments2: ReadonlyArray, -): boolean { - if (arguments1.length !== arguments2.length) { - return false; - } - return arguments1.every((argument1) => { - const argument2 = arguments2.find( - (argument) => argument.name.value === argument1.name.value, - ); - if (!argument2) { - return false; - } - return stringifyValue(argument1.value) === stringifyValue(argument2.value); - }); -} - -function stringifyValue(value: ValueNode): string { - return print(sortValueNode(value)); +function stringifyArguments(fieldNode: FieldNode): string { + // FIXME https://github.com/graphql/graphql-js/issues/2203 + const args = /* c8 ignore next */ fieldNode.arguments ?? []; + + const inputObjectWithArgs: ObjectValueNode = { + kind: Kind.OBJECT, + fields: args.map((argNode) => ({ + kind: Kind.OBJECT_FIELD, + name: argNode.name, + value: argNode.value, + })), + }; + return print(sortValueNode(inputObjectWithArgs)); } // Two types conflict if both types could not apply to a value simultaneously.