Skip to content
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

Prisma Errors no longer throw in resolvers and instead are swallowed and returned as a GraphQL error object #9250

Open
AdamBerri opened this issue Aug 1, 2024 · 4 comments
Assignees

Comments

@AdamBerri
Copy link

Prisma errors (like PrismaClientKnownRequestError) are being caught and transformed into GraphQL errors.
These transformed errors are being returned as part of the query result rather than being thrown.

  1. Create a resolver
  2. Add a try/catch block
  3. In the try block use context.prisma.post.findUniqueOrThrow({where: { id: postId }}) or context.prisma.post.findFirstOrThrow({where: { id: postId }})
  4. Return the result in the error
  5. in the catch block, log the error
  6. import resolver into keystone.ts
  7. call the resolver with an ID that you know does not exist (in order to create the prisma error)

Note: This will also occur on context.prisma.post.update() if the ID being updated does not exist.

I expect the catch block to be invoked. Instead an error object is returned and the catch block is never reached.

image image

Resolver Incorporated into schema.ts this way:
return graphql.extend((base) => { return { query: { ...resolverForTesting(base) }, mutation: {} } })(merged)

Issue seems to be introduced by this commit: c0dacbf
If I understand correctly, the removal of runWithPrisma may have had an unintended consequence where errors no longer throw when caused by Prisma.

@dcousens dcousens self-assigned this Aug 2, 2024
@flippinjoe
Copy link

I can confirm this behavior as well. The main problem here is that now raw prisma operations can return either the expected result or this new hidden GraphQL error. Which isn’t reflected in typescript, thus unforeseen bugs. A simple workaround could be to extendPrismaSchema to do the type checking of the results and throw if a GraphQLError, but that seems like a workaround to the system itself

@dcousens
Copy link
Member

dcousens commented Aug 2, 2024

@AdamBerri @flippinjoe do you have a minimal reproduction that I can use to add tests for this?
I'm not following exactly what behaviour you had previously compared to now.

@flippinjoe
Copy link

@dcousens what kind of reproduction would be useful. The steps that @AdamBerri laid out are pretty thorough IMO. Happy to provide whatever you need. In my use case:

const result = await context.prisma.post.findFirstOrThrow({ where: { id: "some-id" })

^ Previously, this would throw GraphQLError. Now that behavior has changed, and result is actually being returned as a GraphQLError.

@davidmclark
Copy link

The systems I have built with Keystone rely heavily on GraphQL schema extensions and custom Prisma code. It is totally unexpected that Prisma exceptions are swallowed.

Error handling now requires checking the result after every Prisma call and doing string comparisions to determine the underlying Prisma error as the Prisma error code is not exposed. I now have duplicate error handling in my code as I have left the try/catch blocks intact in case this behaviour is fixed. This is obviously not an ideal situation.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants