graphene icon indicating copy to clipboard operation
graphene copied to clipboard

In 3.1.0, `resolve_type` method on Interfaces and Unions no longer supports returning the GraphQL Type as a string

Open perlow opened this issue 1 year ago • 1 comments

  • What is the current behavior? As of 3.1.0, the resolve_type method on Interfaces and Unions no longer supports returning the GraphQL Type as a string as opposed to the actual Graphene Type. I think this might be an unintended regression from https://github.com/graphql-python/graphene/pull/1421.

  • What is the expected behavior? Our project heavily depends on resolve_type returning a string for the GraphQL Type as opposed to the Graphene Type that implements it.

  • What is the motivation / use case for changing the behavior? While it's possible to refactor most of our code to return the Graphene Type, there are some cases where it's very difficult to break circular imports. The reason for that is that some of our implementations of the resolve_type method delegates to returning a property of an Enum and the Enum definition can't reference the Graphene Type because the Graphene Type references the enum.

  • Please tell us about your environment:

    • Version: Trying to upgrade to 3.1.0.
    • Platform: Python 3.12.2 on Linux
  • Other information (e.g. detailed explanation, stacktraces, related issues, suggestions how to fix, links for us to have context, eg. stackoverflow) I created https://github.com/perlow/graphene/pull/1 in a fork. I don't have write permission the repo to request a merge. If this looks reasonable, I can add a unit test for the behavior.

perlow avatar Jun 21 '24 20:06 perlow

Hey, thanks for the report. Can you share a little more about your use case, maybe with a code example to understand your situation better? 😊

For public repositories you can always open a PR from your fork by clicking new PR on the main Repo and selecting your fork branch: https://github.com/graphql-python/graphene/compare

Or simply via github cli, running gh pr create.

erikwrede avatar Jun 22 '24 09:06 erikwrede