Bird
Raised Fist0
GraphQLquery~5 mins

Error handling on client in GraphQL

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Introduction

Error handling on the client helps you catch and manage problems when fetching or sending data. It keeps your app working smoothly and shows helpful messages to users.

When a query fails because the server is down.
When the user sends wrong or incomplete data in a mutation.
When the network connection is lost during a request.
When the server returns an error message for a query.
When you want to show loading and error states in your app.
Syntax
GraphQL
try {
  const result = await client.query({ query: YOUR_QUERY });
  // use result.data
} catch (error) {
  // handle error here
}
Use try...catch to catch errors from async GraphQL calls.
Errors can come from network issues or server responses.
Examples
This example tries to get users and logs them. If it fails, it logs an error message.
GraphQL
try {
  const result = await client.query({ query: GET_USERS });
  console.log(result.data.users);
} catch (error) {
  console.error('Error fetching users:', error.message);
}
This uses promises with then and catch to handle success and errors.
GraphQL
client.query({ query: GET_POSTS })
  .then(result => console.log(result.data.posts))
  .catch(error => console.error('Failed to load posts:', error.message));
Sample Program

This program tries to get a list of books from a GraphQL server. If it works, it prints the books. If there is an error, it prints an error message.

GraphQL
import { ApolloClient, InMemoryCache, gql } from '@apollo/client';

const client = new ApolloClient({
  uri: 'https://example.com/graphql',
  cache: new InMemoryCache()
});

const GET_BOOKS = gql`
  query {
    books {
      title
      author
    }
  }
`;

async function fetchBooks() {
  try {
    const result = await client.query({ query: GET_BOOKS });
    console.log('Books:', result.data.books);
  } catch (error) {
    console.error('Error fetching books:', error.message);
  }
}

fetchBooks();
OutputSuccess
Important Notes

Always handle errors to avoid your app crashing unexpectedly.

Show friendly messages to users when errors happen.

Network errors and GraphQL errors are different; handle both.

Summary

Error handling keeps your app stable and user-friendly.

Use try...catch or catch on promises to catch errors.

Show clear messages so users know what went wrong.

Practice

(1/5)
1. What is the main purpose of error handling on the client side in GraphQL applications?
easy
A. To speed up the server response time
B. To keep the app stable and show clear messages to users
C. To change the GraphQL schema dynamically
D. To store data permanently on the client

Solution

  1. Step 1: Understand client-side error handling

    Error handling on the client is about managing problems that happen when fetching or processing data, so the app doesn't crash.
  2. Step 2: Identify the main goal

    The goal is to keep the app stable and inform users clearly about what went wrong.
  3. Final Answer:

    To keep the app stable and show clear messages to users -> Option B
  4. Quick Check:

    Error handling = stability + clear messages [OK]
Hint: Error handling means stability and clear user messages [OK]
Common Mistakes:
  • Thinking error handling speeds up server
  • Confusing error handling with schema changes
  • Assuming error handling stores data
2. Which of the following is the correct way to catch errors from a GraphQL query using promises on the client?
easy
A. client.query(...).then(...).catch(error => handleError(error))
B. client.query(...).catch(...).then(error => handleError(error))
C. client.query(...).try(error => handleError(error))
D. client.query(...).error(error => handleError(error))

Solution

  1. Step 1: Recall promise error handling syntax

    Promises use .then() for success and .catch() for errors.
  2. Step 2: Match correct chaining

    The correct order is .then(...).catch(...). client.query(...).then(...).catch(error => handleError(error)) matches this.
  3. Final Answer:

    client.query(...).then(...).catch(error => handleError(error)) -> Option A
  4. Quick Check:

    Promise catch method = .catch() [OK]
Hint: Use .then() before .catch() to handle errors [OK]
Common Mistakes:
  • Placing .catch() before .then()
  • Using non-existent .try() or .error() methods
  • Ignoring promise chaining order
3. Given the following code snippet, what will be logged if the GraphQL query fails?
client.query({ query: GET_USER })
  .then(response => console.log('User:', response.data.user))
  .catch(error => console.log('Error:', error.message))
medium
A. User: undefined
B. No output
C. User: null
D. Error: [error message from server]

Solution

  1. Step 1: Understand promise flow on failure

    If the query fails, the .catch() block runs, logging the error message.
  2. Step 2: Identify logged output

    The console logs 'Error:' followed by the error message from the server.
  3. Final Answer:

    Error: [error message from server] -> Option D
  4. Quick Check:

    Failed query triggers .catch() logging error [OK]
Hint: Failed queries run .catch() logging error message [OK]
Common Mistakes:
  • Assuming .then() runs on failure
  • Expecting 'User: undefined' instead of error
  • Thinking no output appears on error
4. Identify the error in this client-side GraphQL error handling code:
try {
  const response = await client.query({ query: GET_POSTS });
  console.log(response.data.posts);
} catch {
  console.log('Failed to fetch posts');
}
medium
A. client.query does not return a promise
B. Using await inside try block is invalid
C. Missing error parameter in catch block
D. console.log cannot be used inside catch

Solution

  1. Step 1: Review try-catch syntax

    The catch block should include an error parameter to access error details.
  2. Step 2: Identify missing error parameter

    The code uses catch { ... } without (error), preventing access to the error details.
  3. Final Answer:

    Missing error parameter in catch block -> Option C
  4. Quick Check:

    catch needs (error) parameter [OK]
Hint: Always include error parameter in catch block [OK]
Common Mistakes:
  • Omitting error parameter in catch
  • Thinking await is invalid in try
  • Believing client.query is not a promise
5. You want to show a friendly message to users when a GraphQL mutation fails due to network issues. Which approach correctly handles this on the client?
async function submitData() {
  try {
    const result = await client.mutate({ mutation: ADD_ITEM, variables: { name: 'Book' } });
    console.log('Item added:', result.data.addItem.id);
  } catch (error) {
    if (error.networkError) {
      alert('Network problem, please try again later.');
    } else {
      alert('An error occurred.');
    }
  }
}
hard
A. This code correctly distinguishes network errors and shows messages
B. The catch block should not check error properties
C. Using alert is not allowed in error handling
D. await cannot be used with client.mutate

Solution

  1. Step 1: Analyze error handling logic

    The catch block checks if the error is a network error and shows a specific message.
  2. Step 2: Confirm correct usage of await and alerts

    Using await with client.mutate is valid, and alerts are acceptable for user messages.
  3. Final Answer:

    This code correctly distinguishes network errors and shows messages -> Option A
  4. Quick Check:

    Check error.networkError to show friendly messages [OK]
Hint: Check error.networkError to show specific messages [OK]
Common Mistakes:
  • Ignoring networkError property in catch
  • Thinking alerts are disallowed
  • Misunderstanding await usage with mutate