-
Notifications
You must be signed in to change notification settings - Fork 930
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
14 changed files
with
542 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
package wrapper | ||
|
||
import ( | ||
"code.cloudfoundry.org/cli/api/cloudcontroller" | ||
"code.cloudfoundry.org/cli/api/shared" | ||
) | ||
|
||
// CCTraceHeaderRequest is a wrapper that adds b3 trace headers to requests. | ||
type CCTraceHeaderRequest struct { | ||
headers *shared.TraceHeaders | ||
connection cloudcontroller.Connection | ||
} | ||
|
||
// NewCCTraceHeaderRequest returns a pointer to a CCTraceHeaderRequest wrapper. | ||
func NewCCTraceHeaderRequest(trace, span string) *CCTraceHeaderRequest { | ||
return &CCTraceHeaderRequest{ | ||
headers: shared.NewTraceHeaders(trace, span), | ||
} | ||
} | ||
|
||
// Add tracing headers | ||
func (t *CCTraceHeaderRequest) Make(request *cloudcontroller.Request, passedResponse *cloudcontroller.Response) error { | ||
t.headers.SetHeaders(request.Request) | ||
return t.connection.Make(request, passedResponse) | ||
} | ||
|
||
// Wrap sets the connection in the CCTraceHeaderRequest and returns itself. | ||
func (t *CCTraceHeaderRequest) Wrap(innerconnection cloudcontroller.Connection) cloudcontroller.Connection { | ||
t.connection = innerconnection | ||
return t | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
package wrapper_test | ||
|
||
import ( | ||
"bytes" | ||
"net/http" | ||
|
||
"code.cloudfoundry.org/cli/api/cloudcontroller" | ||
"code.cloudfoundry.org/cli/api/cloudcontroller/cloudcontrollerfakes" | ||
. "code.cloudfoundry.org/cli/api/cloudcontroller/wrapper" | ||
|
||
. "github.com/onsi/ginkgo/v2" | ||
. "github.com/onsi/gomega" | ||
) | ||
|
||
var _ = Describe("CCTraceHeaderRequest", func() { | ||
var ( | ||
fakeConnection *cloudcontrollerfakes.FakeConnection | ||
|
||
wrapper cloudcontroller.Connection | ||
|
||
request *cloudcontroller.Request | ||
response *cloudcontroller.Response | ||
makeErr error | ||
|
||
traceHeader string | ||
spanHeader string | ||
) | ||
|
||
BeforeEach(func() { | ||
fakeConnection = new(cloudcontrollerfakes.FakeConnection) | ||
|
||
traceHeader = "trace-id" | ||
spanHeader = "span-id" | ||
|
||
wrapper = NewCCTraceHeaderRequest(traceHeader, spanHeader).Wrap(fakeConnection) | ||
|
||
body := bytes.NewReader([]byte("foo")) | ||
|
||
req, err := http.NewRequest(http.MethodGet, "https://foo.bar.com/banana", body) | ||
Expect(err).NotTo(HaveOccurred()) | ||
|
||
response = &cloudcontroller.Response{ | ||
RawResponse: []byte("some-response-body"), | ||
HTTPResponse: &http.Response{}, | ||
} | ||
request = cloudcontroller.NewRequest(req, body) | ||
}) | ||
|
||
JustBeforeEach(func() { | ||
makeErr = wrapper.Make(request, response) | ||
}) | ||
|
||
Describe("Make", func() { | ||
It("Adds the request headers", func() { | ||
Expect(makeErr).NotTo(HaveOccurred()) | ||
Expect(request.Header.Get("X-B3-TraceId")).To(Equal(traceHeader)) | ||
Expect(request.Header.Get("X-B3-SpanId")).To(Equal(spanHeader)) | ||
}) | ||
|
||
It("Calls the inner connection", func() { | ||
Expect(fakeConnection.MakeCallCount()).To(Equal(1)) | ||
req, resp := fakeConnection.MakeArgsForCall(0) | ||
Expect(req).To(Equal(request)) | ||
Expect(resp).To(Equal(response)) | ||
}) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
package wrapper | ||
|
||
import ( | ||
"code.cloudfoundry.org/cli/api/router" | ||
"code.cloudfoundry.org/cli/api/shared" | ||
) | ||
|
||
// RoutingTraceHeaderRequest is a wrapper that adds b3 trace headers to requests. | ||
type RoutingTraceHeaderRequest struct { | ||
headers *shared.TraceHeaders | ||
connection router.Connection | ||
} | ||
|
||
// NewRoutingTraceHeaderRequest returns a pointer to a RoutingTraceHeaderRequest wrapper. | ||
func NewRoutingTraceHeaderRequest(trace, span string) *RoutingTraceHeaderRequest { | ||
return &RoutingTraceHeaderRequest{ | ||
headers: shared.NewTraceHeaders(trace, span), | ||
} | ||
} | ||
|
||
// Add tracing headers | ||
func (t *RoutingTraceHeaderRequest) Make(request *router.Request, passedResponse *router.Response) error { | ||
t.headers.SetHeaders(request.Request) | ||
return t.connection.Make(request, passedResponse) | ||
} | ||
|
||
// Wrap sets the connection in the RoutingTraceHeaderRequest and returns itself. | ||
func (t *RoutingTraceHeaderRequest) Wrap(innerconnection router.Connection) router.Connection { | ||
t.connection = innerconnection | ||
return t | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
package wrapper_test | ||
|
||
import ( | ||
"bytes" | ||
"net/http" | ||
|
||
"code.cloudfoundry.org/cli/api/router" | ||
"code.cloudfoundry.org/cli/api/router/routerfakes" | ||
. "code.cloudfoundry.org/cli/api/router/wrapper" | ||
|
||
. "github.com/onsi/ginkgo/v2" | ||
. "github.com/onsi/gomega" | ||
) | ||
|
||
var _ = Describe("CCTraceHeaderRequest", func() { | ||
var ( | ||
fakeConnection *routerfakes.FakeConnection | ||
|
||
wrapper router.Connection | ||
|
||
request *router.Request | ||
response *router.Response | ||
makeErr error | ||
|
||
traceHeader string | ||
spanHeader string | ||
) | ||
|
||
BeforeEach(func() { | ||
fakeConnection = new(routerfakes.FakeConnection) | ||
|
||
traceHeader = "trace-id" | ||
spanHeader = "span-id" | ||
|
||
wrapper = NewRoutingTraceHeaderRequest(traceHeader, spanHeader).Wrap(fakeConnection) | ||
|
||
body := bytes.NewReader([]byte("foo")) | ||
|
||
req, err := http.NewRequest(http.MethodGet, "https://foo.bar.com/banana", body) | ||
Expect(err).NotTo(HaveOccurred()) | ||
|
||
response = &router.Response{ | ||
RawResponse: []byte("some-response-body"), | ||
HTTPResponse: &http.Response{}, | ||
} | ||
request = router.NewRequest(req, body) | ||
}) | ||
|
||
JustBeforeEach(func() { | ||
makeErr = wrapper.Make(request, response) | ||
}) | ||
|
||
Describe("Make", func() { | ||
It("Adds the request headers", func() { | ||
Expect(makeErr).NotTo(HaveOccurred()) | ||
Expect(request.Header.Get("X-B3-TraceId")).To(Equal(traceHeader)) | ||
Expect(request.Header.Get("X-B3-SpanId")).To(Equal(spanHeader)) | ||
}) | ||
|
||
It("Calls the inner connection", func() { | ||
Expect(fakeConnection.MakeCallCount()).To(Equal(1)) | ||
req, resp := fakeConnection.MakeArgsForCall(0) | ||
Expect(req).To(Equal(request)) | ||
Expect(resp).To(Equal(response)) | ||
}) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
package shared | ||
|
||
import ( | ||
"net/http" | ||
) | ||
|
||
const ( | ||
B3TraceIDHeader = "X-B3-TraceId" | ||
B3SpanIDHeader = "X-B3-SpanId" | ||
) | ||
|
||
// TraceHeaders sets b3 trace headers to requests. | ||
type TraceHeaders struct { | ||
b3trace string | ||
b3span string | ||
} | ||
|
||
// NewTraceHeaders returns a pointer to a TraceHeaderRequest. | ||
func NewTraceHeaders(trace, span string) *TraceHeaders { | ||
return &TraceHeaders{ | ||
b3trace: trace, | ||
b3span: span, | ||
} | ||
} | ||
|
||
// Add tracing headers if they are not already set. | ||
func (t *TraceHeaders) SetHeaders(request *http.Request) { | ||
// only override the trace headers if they are not already set (e.g. already explicitly set by cf curl) | ||
if request.Header.Get(B3TraceIDHeader) == "" { | ||
request.Header.Add(B3TraceIDHeader, t.b3trace) | ||
} | ||
if request.Header.Get(B3SpanIDHeader) == "" { | ||
request.Header.Add(B3SpanIDHeader, t.b3span) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
package shared_test | ||
|
||
import ( | ||
"net/http" | ||
|
||
. "code.cloudfoundry.org/cli/api/shared" | ||
|
||
. "github.com/onsi/ginkgo/v2" | ||
. "github.com/onsi/gomega" | ||
) | ||
|
||
var _ = Describe("B3 Trace Headers", func() { | ||
Describe("SetHeaders", func() { | ||
Context("when there are already headers set", func() { | ||
It("does not add the headers", func() { | ||
traceHeaders := NewTraceHeaders("new_trace_id", "new_span_id") | ||
request := &http.Request{ | ||
Header: http.Header{}, | ||
} | ||
request.Header.Set("X-B3-TraceId", "old_trace_id") | ||
request.Header.Set("X-B3-SpanId", "old_span_id") | ||
traceHeaders.SetHeaders(request) | ||
|
||
Expect(request.Header.Get("X-B3-TraceId")).To(Equal("old_trace_id")) | ||
Expect(request.Header.Get("X-B3-SpanId")).To(Equal("old_span_id")) | ||
}) | ||
}) | ||
|
||
Context("when there are no headers set", func() { | ||
It("adds the headers", func() { | ||
traceHeaders := NewTraceHeaders("new_trace_id", "new_span_id") | ||
request := &http.Request{ | ||
Header: http.Header{}, | ||
} | ||
traceHeaders.SetHeaders(request) | ||
|
||
Expect(request.Header.Get("X-B3-TraceId")).To(Equal("new_trace_id")) | ||
Expect(request.Header.Get("X-B3-SpanId")).To(Equal("new_span_id")) | ||
}) | ||
}) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
package wrapper | ||
|
||
import ( | ||
"net/http" | ||
|
||
"code.cloudfoundry.org/cli/api/shared" | ||
"code.cloudfoundry.org/cli/api/uaa" | ||
) | ||
|
||
// UAATraceHeaderRequest is a wrapper that adds b3 trace headers to requests. | ||
type UAATraceHeaderRequest struct { | ||
headers *shared.TraceHeaders | ||
connection uaa.Connection | ||
} | ||
|
||
// NewUAATraceHeaderRequest returns a pointer to a UAATraceHeaderRequest wrapper. | ||
func NewUAATraceHeaderRequest(trace, span string) *UAATraceHeaderRequest { | ||
return &UAATraceHeaderRequest{ | ||
headers: shared.NewTraceHeaders(trace, span), | ||
} | ||
} | ||
|
||
// Add tracing headers | ||
func (t *UAATraceHeaderRequest) Make(request *http.Request, passedResponse *uaa.Response) error { | ||
t.headers.SetHeaders(request) | ||
return t.connection.Make(request, passedResponse) | ||
} | ||
|
||
// Wrap sets the connection in the UAATraceHeaderRequest and returns itself. | ||
func (t *UAATraceHeaderRequest) Wrap(innerconnection uaa.Connection) uaa.Connection { | ||
t.connection = innerconnection | ||
return t | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
package wrapper_test | ||
|
||
import ( | ||
"bytes" | ||
"net/http" | ||
|
||
"code.cloudfoundry.org/cli/api/uaa" | ||
"code.cloudfoundry.org/cli/api/uaa/uaafakes" | ||
. "code.cloudfoundry.org/cli/api/uaa/wrapper" | ||
|
||
. "github.com/onsi/ginkgo/v2" | ||
. "github.com/onsi/gomega" | ||
) | ||
|
||
var _ = Describe("CCTraceHeaderRequest", func() { | ||
var ( | ||
fakeConnection *uaafakes.FakeConnection | ||
|
||
wrapper uaa.Connection | ||
|
||
request *http.Request | ||
response *uaa.Response | ||
makeErr error | ||
|
||
traceHeader string | ||
spanHeader string | ||
) | ||
|
||
BeforeEach(func() { | ||
fakeConnection = new(uaafakes.FakeConnection) | ||
|
||
traceHeader = "trace-id" | ||
spanHeader = "span-id" | ||
|
||
wrapper = NewUAATraceHeaderRequest(traceHeader, spanHeader).Wrap(fakeConnection) | ||
|
||
body := bytes.NewReader([]byte("foo")) | ||
|
||
var err error | ||
request, err = http.NewRequest(http.MethodGet, "https://foo.bar.com/banana", body) | ||
Expect(err).NotTo(HaveOccurred()) | ||
|
||
response = &uaa.Response{ | ||
RawResponse: []byte("some-response-body"), | ||
HTTPResponse: &http.Response{}, | ||
} | ||
}) | ||
|
||
JustBeforeEach(func() { | ||
makeErr = wrapper.Make(request, response) | ||
}) | ||
|
||
Describe("Make", func() { | ||
It("Adds the request headers", func() { | ||
Expect(makeErr).NotTo(HaveOccurred()) | ||
Expect(request.Header.Get("X-B3-TraceId")).To(Equal(traceHeader)) | ||
Expect(request.Header.Get("X-B3-SpanId")).To(Equal(spanHeader)) | ||
}) | ||
|
||
It("Calls the inner connection", func() { | ||
Expect(fakeConnection.MakeCallCount()).To(Equal(1)) | ||
req, resp := fakeConnection.MakeArgsForCall(0) | ||
Expect(req).To(Equal(request)) | ||
Expect(resp).To(Equal(response)) | ||
}) | ||
}) | ||
}) |
Oops, something went wrong.