refactor: httpc package for easy to use (#1645)

master
Kevin Wan 3 years ago committed by GitHub
parent b5d1d8b0d1
commit f9e6013a6c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -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) {

Loading…
Cancel
Save