2017-05-24 00:45:38 -04:00
|
|
|
package command_test
|
|
|
|
|
|
|
|
import (
|
2017-05-30 17:36:15 -04:00
|
|
|
"bytes"
|
2018-05-03 21:02:44 -04:00
|
|
|
"context"
|
2017-05-30 17:36:15 -04:00
|
|
|
"fmt"
|
2017-05-24 00:45:38 -04:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
2020-02-22 12:12:14 -05:00
|
|
|
"gotest.tools/v3/assert"
|
|
|
|
is "gotest.tools/v3/assert/cmp"
|
2017-05-24 00:45:38 -04:00
|
|
|
|
2017-08-21 16:30:09 -04:00
|
|
|
// Prevents a circular import with "github.com/docker/cli/internal/test"
|
2017-05-30 17:36:15 -04:00
|
|
|
|
2017-05-24 00:45:38 -04:00
|
|
|
. "github.com/docker/cli/cli/command"
|
2017-10-15 15:39:56 -04:00
|
|
|
configtypes "github.com/docker/cli/cli/config/types"
|
2018-03-19 18:56:51 -04:00
|
|
|
"github.com/docker/cli/cli/debug"
|
2017-08-21 16:30:09 -04:00
|
|
|
"github.com/docker/cli/internal/test"
|
2017-05-24 00:45:38 -04:00
|
|
|
"github.com/docker/docker/api/types"
|
|
|
|
"github.com/docker/docker/client"
|
|
|
|
)
|
|
|
|
|
|
|
|
type fakeClient struct {
|
|
|
|
client.Client
|
|
|
|
infoFunc func() (types.Info, error)
|
|
|
|
}
|
|
|
|
|
2017-05-30 17:36:15 -04:00
|
|
|
var testAuthConfigs = []types.AuthConfig{
|
|
|
|
{
|
|
|
|
ServerAddress: "https://index.docker.io/v1/",
|
|
|
|
Username: "u0",
|
|
|
|
Password: "p0",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
ServerAddress: "server1.io",
|
|
|
|
Username: "u1",
|
|
|
|
Password: "p1",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2017-05-24 00:45:38 -04:00
|
|
|
func (cli *fakeClient) Info(_ context.Context) (types.Info, error) {
|
|
|
|
if cli.infoFunc != nil {
|
|
|
|
return cli.infoFunc()
|
|
|
|
}
|
|
|
|
return types.Info{}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestElectAuthServer(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
expectedAuthServer string
|
|
|
|
expectedWarning string
|
|
|
|
infoFunc func() (types.Info, error)
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
expectedAuthServer: "https://index.docker.io/v1/",
|
|
|
|
expectedWarning: "",
|
|
|
|
infoFunc: func() (types.Info, error) {
|
|
|
|
return types.Info{IndexServerAddress: "https://index.docker.io/v1/"}, nil
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
expectedAuthServer: "https://index.docker.io/v1/",
|
|
|
|
expectedWarning: "Empty registry endpoint from daemon",
|
|
|
|
infoFunc: func() (types.Info, error) {
|
|
|
|
return types.Info{IndexServerAddress: ""}, nil
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-04-30 03:31:41 -04:00
|
|
|
expectedAuthServer: "https://foo.example.com",
|
2017-05-24 00:45:38 -04:00
|
|
|
expectedWarning: "",
|
|
|
|
infoFunc: func() (types.Info, error) {
|
2021-04-30 03:31:41 -04:00
|
|
|
return types.Info{IndexServerAddress: "https://foo.example.com"}, nil
|
2017-05-24 00:45:38 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
expectedAuthServer: "https://index.docker.io/v1/",
|
|
|
|
expectedWarning: "failed to get default registry endpoint from daemon",
|
|
|
|
infoFunc: func() (types.Info, error) {
|
|
|
|
return types.Info{}, errors.Errorf("error getting info")
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
2018-03-19 18:56:51 -04:00
|
|
|
// Enable debug to see warnings we're checking for
|
|
|
|
debug.Enable()
|
2017-05-24 00:45:38 -04:00
|
|
|
for _, tc := range testCases {
|
2017-07-05 14:43:39 -04:00
|
|
|
cli := test.NewFakeCli(&fakeClient{infoFunc: tc.infoFunc})
|
2017-05-24 00:45:38 -04:00
|
|
|
server := ElectAuthServer(context.Background(), cli)
|
2018-03-05 18:53:52 -05:00
|
|
|
assert.Check(t, is.Equal(tc.expectedAuthServer, server))
|
2017-07-05 14:43:39 -04:00
|
|
|
actual := cli.ErrBuffer().String()
|
2017-05-24 00:45:38 -04:00
|
|
|
if tc.expectedWarning == "" {
|
2018-03-05 18:53:52 -05:00
|
|
|
assert.Check(t, is.Len(actual, 0))
|
2017-05-24 00:45:38 -04:00
|
|
|
} else {
|
2018-03-05 18:53:52 -05:00
|
|
|
assert.Check(t, is.Contains(actual, tc.expectedWarning))
|
2017-05-24 00:45:38 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2017-05-30 17:36:15 -04:00
|
|
|
|
|
|
|
func TestGetDefaultAuthConfig(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
checkCredStore bool
|
|
|
|
inputServerAddress string
|
|
|
|
expectedErr string
|
|
|
|
expectedAuthConfig types.AuthConfig
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
checkCredStore: false,
|
|
|
|
inputServerAddress: "",
|
|
|
|
expectedErr: "",
|
|
|
|
expectedAuthConfig: types.AuthConfig{
|
|
|
|
ServerAddress: "",
|
|
|
|
Username: "",
|
|
|
|
Password: "",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
checkCredStore: true,
|
|
|
|
inputServerAddress: testAuthConfigs[0].ServerAddress,
|
|
|
|
expectedErr: "",
|
|
|
|
expectedAuthConfig: testAuthConfigs[0],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
checkCredStore: true,
|
|
|
|
inputServerAddress: testAuthConfigs[1].ServerAddress,
|
|
|
|
expectedErr: "",
|
|
|
|
expectedAuthConfig: testAuthConfigs[1],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
checkCredStore: true,
|
|
|
|
inputServerAddress: fmt.Sprintf("https://%s", testAuthConfigs[1].ServerAddress),
|
|
|
|
expectedErr: "",
|
|
|
|
expectedAuthConfig: testAuthConfigs[1],
|
|
|
|
},
|
|
|
|
}
|
|
|
|
cli := test.NewFakeCli(&fakeClient{})
|
|
|
|
errBuf := new(bytes.Buffer)
|
|
|
|
cli.SetErr(errBuf)
|
|
|
|
for _, authconfig := range testAuthConfigs {
|
2017-10-15 15:39:56 -04:00
|
|
|
cli.ConfigFile().GetCredentialsStore(authconfig.ServerAddress).Store(configtypes.AuthConfig(authconfig))
|
2017-05-30 17:36:15 -04:00
|
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
|
|
serverAddress := tc.inputServerAddress
|
|
|
|
authconfig, err := GetDefaultAuthConfig(cli, tc.checkCredStore, serverAddress, serverAddress == "https://index.docker.io/v1/")
|
|
|
|
if tc.expectedErr != "" {
|
2018-03-05 18:53:52 -05:00
|
|
|
assert.Check(t, err != nil)
|
|
|
|
assert.Check(t, is.Equal(tc.expectedErr, err.Error()))
|
2017-05-30 17:36:15 -04:00
|
|
|
} else {
|
2018-03-06 14:44:13 -05:00
|
|
|
assert.NilError(t, err)
|
2018-03-05 18:53:52 -05:00
|
|
|
assert.Check(t, is.DeepEqual(tc.expectedAuthConfig, *authconfig))
|
2017-05-30 17:36:15 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|