-
-
Notifications
You must be signed in to change notification settings - Fork 137
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Cancel resolver tasks if execution of an operation is terminated #217
Comments
Yes, that's something I also wanted to look into, but not sure when I will find the time. Meanwhile, if anybody has suggestions or ideas how to tackle this, please comment. |
Thanks so much for the quick response @Cito! Are there any thoughts / pointers you can share yourself? Don't want to make any promises, but I might be able to give fixing this a try. |
Specifically I would appreciate it if you could point me to the parts of the code which do the collection of results and skipping of execution when an incoercible error happens -- maybe I'll have some ideas how to embed task cancellation in there. |
Hi @kkom. One idea was to make use of task groups. I also wanted to explore the idea of using any.io/trio as suggested in #166. The parts that you need to look into are mostly inside the A good strategy would be to first create the most minimalist example you can think of where this problem occurs, and some way to cleanly test for the desired behavior in a unit test. Then you can make experiments, and check the code flow in a debugger. Please note the constraints in this project: It is meant to be a more or less 1:1 port of GraphQL.js to Python. There should not be any groundbreaking changes where the code deviates from how it works and is structured in GraphQL.js. Keeping the code base very close to GraphQL.js is the only way to continually port the current development there back to GraphQL-core. |
Thanks @Cito ! I have a few more questions:
|
Ah, I think this thing you said answers 3:
Still curious about your perspective on points 2 & 3, and if (to your knowledge) the same non-determinism in returned errors is present in GraphQL.js |
I think the short-circuit behavior is the one wanted by GraphQL.js. Yes, we should stay backward compatible, but I think it would be ok if certain features such as task cancellation work only in newer Python versions. |
TL;DR
Would it be possible to cancel outstanding resolver tasks
as soon asbefore execution of a GraphQL operation is terminated? Outstanding / unused tasks can happen as a result of an incoercible field resolver error.These outstanding tasks can run well after lifecycle hooks responsible for cleaning up their context have completed. As a result, they often fail and cause a lot of noisy errors for us.
More details
Hello!
I'm coming from the
strawberry-graphql
project. We're running into a problem with abandoned resolver tasks not being cancelled, and thus failing in unpredictable ways.Strawberry has an extensions framework which allows you to wrap the execution phase of your operation processing in hooks – running code before and after execution of resolvers. We use these hooks to manage (set up and tear down) some state needed by the resolvers.
However, when a resolver of a non-nullable field fails, it may lead to the results of some other resolvers being no longer necessary. It appears that
graphql-core
will then short-circuit returning a result, while the no-longer-necessary resolvers are still running. We see that they can continue running well after the HTTP response was returned.The problem is that Strawberry's lifecycle hooks (and I also imagine - the webserver's) would have completed by that time. As a result, we do things like terminate the DB session – making it very likely that these outstanding tasks will fail with various esoteric errors. This causes a lot of noise in our observability suite – which we'd love to avoid.
See strawberry-graphql/strawberry#3414 for more details, and strawberry-graphql/strawberry#3414 (comment) for the comment which recommends I report the issue here.
The text was updated successfully, but these errors were encountered: