feat: add experimental support for parsing fragment arguments
This is a rebase of https://github.com/graphql/graphql-js/pull/3847
This implements execution of Fragment Arguments, and more specifically visiting, parsing and printing of fragment-spreads with arguments and fragment definitions with variables, as described by the spec changes in https://github.com/graphql/graphql-spec/pull/1081. There are a few amendments in terms of execution and keying the fragment-spreads, these are reflected in https://github.com/mjmahone/graphql-spec/pull/3
The purpose is to be able to independently review all the moving parts, the stacked PR's will contain mentions of open feedback that was present at the time.
CC @mjmahone the original author
Deploy Preview for compassionate-pike-271cb3 ready!
| Name | Link |
|---|---|
| Latest commit | 3918bb534d5f1cf5579664420103c2a58e5ae511 |
| Latest deploy log | https://app.netlify.com/sites/compassionate-pike-271cb3/deploys/66c4abd1f74a73000710da75 |
| Deploy Preview | https://deploy-preview-4015--compassionate-pike-271cb3.netlify.app |
| Preview on mobile | Toggle QR Code...Use your smartphone camera to open QR code link. |
To edit notification comments on pull requests, go to your Netlify site configuration.
Hi @JoviDeCroock, I'm @github-actions bot happy to help you with this PR π
Supported commands
Please post this commands in separate comments and only one per comment:
@github-actions run-benchmark- Run benchmark comparing base and merge commits for this PR@github-actions publish-pr-on-npm- Build package from this PR and publish it on NPM
@mjmahone worth bringing up that the PR is up, or should that be for the graphql-js wg? Not entirely sure π
CC @graphql/graphql-js-reviewers
The implementation in this branch passes tests but uses UNSET. However, there's an alternative here: https://github.com/JoviDeCroock/graphql-js/commit/1ee3f42d6101e9755a7103bca3316006ba6ec901, which has some updated tests.
Basically, the spec proposal uses CoerceArgumentValues (which itself is used in CoerceFieldArgumentValues, which isn't reflected in graphql-js since the spec conflates two different data structures), which is in turn used in ArgumentsFromSpread.
The spec then uses versions of spreadArgumentValues / argumentValues, i.e. a version of βvariablesβ only for the fragment variable definitions, and keeps the variableValues separate. Since CoerceArgumentValues is reused, we should raise an error in CollectFields (via the former) for invalid values (e.g. undefined on non-defaulting non-null fields), which is reflected in the linked commit.
worth bringing up that the PR is up, or should that be for the graphql-js wg?
I think it's worth adding a 5-10 minute dicussion item to the WG meeting this thursday https://github.com/graphql/graphql-wg/blob/main/agendas/2024/02-Feb/01-wg-primary.md
The implementation in this branch passes tests but uses UNSET. However, there's an alternative here: https://github.com/JoviDeCroock/graphql-js/commit/1ee3f42d6101e9755a7103bca3316006ba6ec901, which has some updated tests.
I don't think that is true anymore? I think @JoviDeCroock removed all the UNSET hacks from this PR (they might still exist in the executor changes). It also looks like graphql-js #4015 no longer uses the UNSET hack.
We should definitely ship the graphql-js changes that most closely match the changes to the spec itself, and the UNSET hack does not match the spec changes from Spec #1081 , but this looks like the parser changes are in a reasonably good state right now to my eyes!
@mjmahone yeah it doesn't use it it's just the parser. The execution PR also uses the new spec text
@graphql/graphql-js-reviewers is there anything missing to move this and the linked PR's forward?
So excited for this! Let me know if you want any help testing it in a real app.
Would this PR be better served being aimed at the 16.x.x branch? Not sure how the release schedule of this would work. If so how do we handle the existing option this._options.allowLegacyFragmentVariables