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

[2/3 header changes][tchannel] Emit metrics for new headers handling behaviour. Hide actual changes under feature flag. #2272

Conversation

biosvs
Copy link
Collaborator

@biosvs biosvs commented May 3, 2024

Part of #2265

Copy link

codecov bot commented May 3, 2024

Codecov Report

Attention: Patch coverage is 90.76923% with 12 lines in your changes missing coverage. Please review.

Project coverage is 85.34%. Comparing base (f7b3c8e) to head (38ecd35).
Report is 2 commits behind head on emit-metrics-for-new-behavior-step-1.

Files with missing lines Patch % Lines
transport/tchannel/response_writer.go 85.50% 5 Missing and 5 partials ⚠️
transport/tchannel/outbound.go 75.00% 1 Missing and 1 partial ⚠️
Additional details and impacted files
@@                           Coverage Diff                            @@
##           emit-metrics-for-new-behavior-step-1    #2272      +/-   ##
========================================================================
+ Coverage                                 85.33%   85.34%   +0.01%     
========================================================================
  Files                                       271      272       +1     
  Lines                                     15624    15669      +45     
========================================================================
+ Hits                                      13333    13373      +40     
- Misses                                     1872     1874       +2     
- Partials                                    419      422       +3     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@biosvs biosvs changed the title [3/4 tchannel] Emit metrics for new headers handling behaviour. Hide actual changes under feature flag. [2/3 header changes][tchannel] Emit metrics for new headers handling behaviour. Hide actual changes under feature flag. May 7, 2024
@biosvs biosvs force-pushed the emit-metrics-for-new-behavior-step-2 branch from 1037c9f to 5f291fa Compare May 7, 2024 11:35
@biosvs biosvs changed the base branch from emit-metrics-for-new-behavior-step-1-2 to tchannel-refactoring-2 May 7, 2024 11:36
@biosvs biosvs force-pushed the emit-metrics-for-new-behavior-step-2 branch from 5f291fa to 09b3d5f Compare May 10, 2024 11:54
@@ -195,7 +195,9 @@ func (o *ChannelOutbound) Call(ctx context.Context, req *transport.Request) (*tr
}

err = getResponseError(headers)
deleteReservedHeaders(headers)
// no check: err will be returned as is
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is this comment intentional?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah, for some reason I was asking myself "where's error handling?" every time I look at this line, so I decided to left a comment


func deleteReservedPrefixHeaders(headers transport.Headers, edgeMetrics observability.ReservedHeaderEdgeMetrics) {
for key := range headers.Items() {
if isReservedHeaderPrefix(key) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

let's reduce some nesting here:

if !isReservedHeaderPrefix(key) {
   continue
}
edgeMetrics.IncStripped()
if enforceHeaderRules {
	headers.Del(key)
}

another question, I don't see reuse here. Can we just combine those 2 and make a single deleteReservedHeaders func?

Copy link
Collaborator Author

@biosvs biosvs May 23, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

if isReservedHeaderKey(k) {
w.failedWith = appendError(w.failedWith, fmt.Errorf("cannot use reserved header key: %s", k))
return
}

// Header with reserved prefix is used, but it's not a reserved key (existing rule),
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove existing rule? after this change is merged, we don't know what it means?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Makes sense, fixed

@biosvs biosvs force-pushed the emit-metrics-for-new-behavior-step-2 branch from 09b3d5f to 38ecd35 Compare May 23, 2024 08:31
Base automatically changed from tchannel-refactoring-2 to tchannel-refactoring-1 July 30, 2024 12:26
Base automatically changed from tchannel-refactoring-1 to emit-metrics-for-new-behavior-step-1 July 30, 2024 12:40
@biosvs biosvs closed this Dec 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

Successfully merging this pull request may close these issues.

2 participants