-
Notifications
You must be signed in to change notification settings - Fork 103
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
Codecov ReportAttention: Patch coverage is
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. |
1037c9f
to
5f291fa
Compare
5f291fa
to
09b3d5f
Compare
@@ -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 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is this comment intentional?
There was a problem hiding this comment.
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
transport/tchannel/header.go
Outdated
|
||
func deleteReservedPrefixHeaders(headers transport.Headers, edgeMetrics observability.ReservedHeaderEdgeMetrics) { | ||
for key := range headers.Items() { | ||
if isReservedHeaderPrefix(key) { |
There was a problem hiding this comment.
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?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed
another question, I don't see reuse here
It's reused here: https://github.com/yarpc/yarpc-go/pull/2272/files#diff-72c944f1bd46d354d3c1255093274ae1ec4fca8fef63abdcd2fbc0f6ee738e86R188
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), |
There was a problem hiding this comment.
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?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Makes sense, fixed
…der feature flag.
09b3d5f
to
38ecd35
Compare
Part of #2265