Skip to content

Commit

Permalink
Fix BasicPublish for <.NET Core 3.1
Browse files Browse the repository at this point in the history
  • Loading branch information
andrewlock committed Jan 8, 2025
1 parent 5c6fb07 commit af58ff9
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -41,11 +41,23 @@ internal static CallTargetState OnMethodBegin<TTarget, TExchange, TRoutingKey, T
return BasicPublishAsyncIntegration.OnMethodBegin(instance, exchangeString, routingKeyString, mandatory, basicProperties, body, default);
}

#if NETCOREAPP3_1_OR_GREATER
// We don't support ValueTask in < .NET Core 3.1, which means this doesn't work and is never called
internal static TReturn? OnAsyncMethodEnd<TTarget, TReturn>(TTarget instance, TReturn? returnValue, Exception? exception, in CallTargetState state)
{
state.Scope.DisposeWithException(exception);
return returnValue;
}
#else
// If the method executes synchronously, then this works fine, but if it executes asynchronously we could miss the exception
// This is because the exception is thrown after the method returns, and we can't catch it here
// If/when we support handling ValueTask correctly in < .NET Core 3.1, we should remove this method
internal static CallTargetReturn<TReturn?> OnMethodEnd<TTarget, TReturn>(TTarget instance, TReturn? returnValue, Exception? exception, in CallTargetState state)
{
state.Scope.DisposeWithException(exception);
return new CallTargetReturn<TReturn?>(returnValue);
}
#endif
}

/// <summary>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,9 +65,21 @@ internal static CallTargetState OnMethodBegin<TTarget, TBasicProperties, TBody>(
return new CallTargetState(scope);
}

#if NETCOREAPP3_1_OR_GREATER
// We don't support ValueTask in < .NET Core 3.1, which means this doesn't work and is never called
internal static TReturn? OnAsyncMethodEnd<TTarget, TReturn>(TTarget instance, TReturn? returnValue, Exception? exception, in CallTargetState state)
{
state.Scope.DisposeWithException(exception);
return returnValue;
}
#else
// If the method executes synchronously, then this works fine, but if it executes asynchronously we could miss the exception
// This is because the exception is thrown after the method returns, and we can't catch it here
// If/when we support handling ValueTask correctly in < .NET Core 3.1, we should remove this method
internal static CallTargetReturn<TReturn?> OnMethodEnd<TTarget, TReturn>(TTarget instance, TReturn? returnValue, Exception? exception, in CallTargetState state)
{
state.Scope.DisposeWithException(exception);
return new CallTargetReturn<TReturn?>(returnValue);
}
#endif
}

0 comments on commit af58ff9

Please sign in to comment.