refactor: httpc package for easy to use (#1645)
This commit is contained in:
@@ -6,16 +6,16 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
// Do sends an HTTP request to the service assocated with the given key.
|
// Do sends an HTTP request to the service assocated with the given key.
|
||||||
func Do(key string, r *http.Request, opts ...Option) (*http.Response, error) {
|
func Do(key string, r *http.Request) (*http.Response, error) {
|
||||||
return NewService(key, opts...).Do(r)
|
return NewService(key).Do(r)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get sends an HTTP GET request to the service assocated with the given key.
|
// Get sends an HTTP GET request to the service assocated with the given key.
|
||||||
func Get(key, url string, opts ...Option) (*http.Response, error) {
|
func Get(key, url string) (*http.Response, error) {
|
||||||
return NewService(key, opts...).Get(url)
|
return NewService(key).Get(url)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Post sends an HTTP POST request to the service assocated with the given key.
|
// Post sends an HTTP POST request to the service assocated with the given key.
|
||||||
func Post(key, url, contentType string, body io.Reader, opts ...Option) (*http.Response, error) {
|
func Post(key, url, contentType string, body io.Reader) (*http.Response, error) {
|
||||||
return NewService(key, opts...).Post(url, contentType, body)
|
return NewService(key).Post(url, contentType, body)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,9 +13,7 @@ func TestDo(t *testing.T) {
|
|||||||
}))
|
}))
|
||||||
_, err := Get("foo", "tcp://bad request")
|
_, err := Get("foo", "tcp://bad request")
|
||||||
assert.NotNil(t, err)
|
assert.NotNil(t, err)
|
||||||
resp, err := Get("foo", svr.URL, func(cli *http.Client) {
|
resp, err := Get("foo", svr.URL)
|
||||||
cli.Transport = http.DefaultTransport
|
|
||||||
})
|
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ var interceptors = []internal.Interceptor{
|
|||||||
|
|
||||||
type (
|
type (
|
||||||
// Option is used to customize the *http.Client.
|
// Option is used to customize the *http.Client.
|
||||||
Option func(cli *http.Client)
|
Option func(r *http.Request) *http.Request
|
||||||
|
|
||||||
// Service represents a remote HTTP service.
|
// Service represents a remote HTTP service.
|
||||||
Service interface {
|
Service interface {
|
||||||
@@ -33,26 +33,23 @@ type (
|
|||||||
namedService struct {
|
namedService struct {
|
||||||
name string
|
name string
|
||||||
cli *http.Client
|
cli *http.Client
|
||||||
|
opts []Option
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
// NewService returns a remote service with the given name.
|
// NewService returns a remote service with the given name.
|
||||||
// opts are used to customize the *http.Client.
|
// opts are used to customize the *http.Client.
|
||||||
func NewService(name string, opts ...Option) Service {
|
func NewService(name string, opts ...Option) Service {
|
||||||
var cli *http.Client
|
return NewServiceWithClient(name, http.DefaultClient, opts...)
|
||||||
|
|
||||||
if len(opts) == 0 {
|
|
||||||
cli = http.DefaultClient
|
|
||||||
} else {
|
|
||||||
cli = &http.Client{}
|
|
||||||
for _, opt := range opts {
|
|
||||||
opt(cli)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NewServiceWithClient returns a remote service with the given name.
|
||||||
|
// opts are used to customize the *http.Client.
|
||||||
|
func NewServiceWithClient(name string, cli *http.Client, opts ...Option) Service {
|
||||||
return namedService{
|
return namedService{
|
||||||
name: name,
|
name: name,
|
||||||
cli: cli,
|
cli: cli,
|
||||||
|
opts: opts,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -100,6 +97,10 @@ func (s namedService) Post(url, contentType string, body io.Reader) (*http.Respo
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (s namedService) doRequest(r *http.Request) (resp *http.Response, err error) {
|
func (s namedService) doRequest(r *http.Request) (resp *http.Response, err error) {
|
||||||
|
for _, opt := range s.opts {
|
||||||
|
r = opt(r)
|
||||||
|
}
|
||||||
|
|
||||||
brk := breaker.GetBreaker(s.name)
|
brk := breaker.GetBreaker(s.name)
|
||||||
err = brk.DoWithAcceptable(func() error {
|
err = brk.DoWithAcceptable(func() error {
|
||||||
resp, err = s.cli.Do(r)
|
resp, err = s.cli.Do(r)
|
||||||
|
|||||||
@@ -20,13 +20,16 @@ func TestNamedService_Do(t *testing.T) {
|
|||||||
|
|
||||||
func TestNamedService_Get(t *testing.T) {
|
func TestNamedService_Get(t *testing.T) {
|
||||||
svr := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
svr := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
w.Header().Set("foo", r.Header.Get("foo"))
|
||||||
}))
|
}))
|
||||||
service := NewService("foo", func(cli *http.Client) {
|
service := NewService("foo", func(r *http.Request) *http.Request {
|
||||||
cli.Transport = http.DefaultTransport
|
r.Header.Set("foo", "bar")
|
||||||
|
return r
|
||||||
})
|
})
|
||||||
resp, err := service.Get(svr.URL)
|
resp, err := service.Get(svr.URL)
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
||||||
|
assert.Equal(t, "bar", resp.Header.Get("foo"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestNamedService_Post(t *testing.T) {
|
func TestNamedService_Post(t *testing.T) {
|
||||||
|
|||||||
Reference in New Issue
Block a user