Skip to content

Commit

Permalink
Refactor HttpWebRequestActivitySource (#5055)
Browse files Browse the repository at this point in the history
  • Loading branch information
vishweshbankwar authored Nov 17, 2023
1 parent d346196 commit 2a228f9
Showing 1 changed file with 33 additions and 42 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -204,8 +204,6 @@ private static void AddResponseTags(HttpWebResponse response, Activity activity)
activity.SetTag(SemanticConventions.AttributeHttpResponseStatusCode, TelemetryHelper.GetBoxedStatusCode(response.StatusCode));
}

activity.SetStatus(SpanHelper.ResolveSpanStatusForHttpStatusCode(activity.Kind, (int)response.StatusCode));

try
{
TracingOptions.EnrichWithHttpWebResponse?.Invoke(activity, response);
Expand Down Expand Up @@ -243,45 +241,15 @@ private static string GetErrorType(Exception exception)
}

[MethodImpl(MethodImplOptions.AggressiveInlining)]
private static void AddExceptionTags(Exception exception, Activity activity, out HttpStatusCode? statusCode, out Version protocolVersion)
private static void AddExceptionEvent(Exception exception, Activity activity)
{
Debug.Assert(activity != null, "Activity must not be null");

statusCode = null;
protocolVersion = null;

if (!activity.IsAllDataRequested)
{
return;
}

ActivityStatusCode status;

if (exception is WebException wexc && wexc.Response is HttpWebResponse response)
{
statusCode = response.StatusCode;
protocolVersion = response.ProtocolVersion;

if (tracingEmitOldAttributes)
{
activity.SetTag(SemanticConventions.AttributeHttpStatusCode, (int)statusCode);
}

if (tracingEmitNewAttributes)
{
activity.SetTag(SemanticConventions.AttributeNetworkProtocolVersion, HttpTagHelper.GetProtocolVersionString(protocolVersion));
activity.SetTag(SemanticConventions.AttributeHttpResponseStatusCode, (int)statusCode);
}

status = SpanHelper.ResolveSpanStatusForHttpStatusCode(activity.Kind, (int)statusCode);
}
else
{
status = ActivityStatusCode.Error;
}

activity.SetStatus(status);

if (TracingOptions.RecordException)
{
activity.RecordException(exception);
Expand Down Expand Up @@ -401,6 +369,7 @@ private static void ProcessResult(IAsyncResult asyncResult, AsyncCallback asyncC
HttpStatusCode? httpStatusCode = null;
string errorType = null;
Version protocolVersion = null;
ActivityStatusCode activityStatus = ActivityStatusCode.Unset;

// Activity may be null if we are not tracing in these cases:
// 1. No listeners
Expand All @@ -417,14 +386,30 @@ private static void ProcessResult(IAsyncResult asyncResult, AsyncCallback asyncC
if (result is Exception ex)
{
errorType = GetErrorType(ex);
if (activity != null)
{
AddExceptionTags(ex, activity, out httpStatusCode, out protocolVersion);
}
else if (ex is WebException wexc && wexc.Response is HttpWebResponse response)
if (ex is WebException wexc && wexc.Response is HttpWebResponse response)
{
httpStatusCode = response.StatusCode;
protocolVersion = response.ProtocolVersion;
activityStatus = SpanHelper.ResolveSpanStatusForHttpStatusCode(activity.Kind, (int)response.StatusCode);
if (activityStatus == ActivityStatusCode.Error)
{
// override the errorType to statusCode for failures.
errorType = TelemetryHelper.GetStatusCodeString(response.StatusCode);
}

if (activity != null)
{
AddResponseTags(response, activity);
AddExceptionEvent(ex, activity);
}
}
else
{
activityStatus = ActivityStatusCode.Error;
if (activity != null)
{
AddExceptionEvent(ex, activity);
}
}
}
else
Expand Down Expand Up @@ -465,9 +450,11 @@ private static void ProcessResult(IAsyncResult asyncResult, AsyncCallback asyncC
protocolVersion = response.ProtocolVersion;
}

if (SpanHelper.ResolveSpanStatusForHttpStatusCode(ActivityKind.Client, (int)httpStatusCode.Value) == ActivityStatusCode.Error)
activityStatus = SpanHelper.ResolveSpanStatusForHttpStatusCode(activity.Kind, (int)httpStatusCode.Value);

if (activityStatus == ActivityStatusCode.Error)
{
// override the errorType to statusCode for failures.
// set the errorType to statusCode for failures.
errorType = TelemetryHelper.GetStatusCodeString(httpStatusCode.Value);
}
}
Expand All @@ -477,9 +464,13 @@ private static void ProcessResult(IAsyncResult asyncResult, AsyncCallback asyncC
HttpInstrumentationEventSource.Log.FailedProcessResult(ex);
}

if (tracingEmitNewAttributes && errorType != null)
if (activity != null && activity.IsAllDataRequested)
{
activity?.SetTag(SemanticConventions.AttributeErrorType, errorType);
activity.SetStatus(activityStatus);
if (tracingEmitNewAttributes && errorType != null)
{
activity.SetTag(SemanticConventions.AttributeErrorType, errorType);
}
}

activity?.Stop();
Expand Down

0 comments on commit 2a228f9

Please sign in to comment.