Don Box
Don Box

Reputation: 3336

How to catch async void method exception?

I have an implementation like this:

Task<IEnumerable<Item1>> GetItems1() 
{
    return RunRequest(async () => ParseItemsFromResponse(await(httpClient.Get(..))));
}

Task<IEnumerable<Item2>> GetItems2() 
{
    return RunRequest(async () => ParseItemsFromResponse(await httpClient.Get(..)));
}


TResult RunRequest<TResult>(Func<TResult> req)
{
    try
    {
        return req();
    }
    catch (Exception ex)
    {
        // Parse exception here and throw custom exceptions
    }
}

The issue is the void anonymous method async () => ParseItemsFromResponse(..).

Since it returns void and not a Task, if there's an exception thrown within the anonymous method, it's actually not going to be caught by the try and catch within the RunRequest.

Any suggestions how to refactor this?

Upvotes: 2

Views: 1256

Answers (1)

Stephen Cleary
Stephen Cleary

Reputation: 456507

RunRequest should take a Func<Task<TResult>>, as such:

async Task<TResult> RunRequestAsync<TResult>(Func<Task<TResult>> req)
{
  try
  {
    return await req().ConfigureAwait(false);
  }
  catch (Exception ex)
  {
    // Parse exception here and throw custom exceptions
  }
}

Then your async lambdas are converted to async Task<T> methods instead of async void.

I have more information on sync/async delegates on my blog.

Upvotes: 3

Related Questions