зеркало из https://github.com/docker/engine-api.git
55 строки
1.2 KiB
Go
55 строки
1.2 KiB
Go
package client
|
|
|
|
import (
|
|
"bytes"
|
|
"crypto/tls"
|
|
"io/ioutil"
|
|
"net/http"
|
|
|
|
"github.com/docker/engine-api/client/transport"
|
|
)
|
|
|
|
type mockClient struct {
|
|
do func(*http.Request) (*http.Response, error)
|
|
}
|
|
|
|
// TLSConfig returns the TLS configuration.
|
|
func (m *mockClient) TLSConfig() *tls.Config {
|
|
return &tls.Config{}
|
|
}
|
|
|
|
// Scheme returns protocol scheme to use.
|
|
func (m *mockClient) Scheme() string {
|
|
return "http"
|
|
}
|
|
|
|
// Secure returns true if there is a TLS configuration.
|
|
func (m *mockClient) Secure() bool {
|
|
return false
|
|
}
|
|
|
|
// NewMockClient returns a mocked client that runs the function supplied as `client.Do` call
|
|
func newMockClient(tlsConfig *tls.Config, doer func(*http.Request) (*http.Response, error)) transport.Client {
|
|
if tlsConfig != nil {
|
|
panic("this actually gets set!")
|
|
}
|
|
|
|
return &mockClient{
|
|
do: doer,
|
|
}
|
|
}
|
|
|
|
// Do executes the supplied function for the mock.
|
|
func (m mockClient) Do(req *http.Request) (*http.Response, error) {
|
|
return m.do(req)
|
|
}
|
|
|
|
func errorMock(statusCode int, message string) func(req *http.Request) (*http.Response, error) {
|
|
return func(req *http.Request) (*http.Response, error) {
|
|
return &http.Response{
|
|
StatusCode: statusCode,
|
|
Body: ioutil.NopCloser(bytes.NewReader([]byte(message))),
|
|
}, nil
|
|
}
|
|
}
|