2020-06-18 16:13:24 +02:00
|
|
|
/*
|
2020-09-22 12:13:00 +02:00
|
|
|
Copyright 2020 Docker Compose CLI authors
|
2020-06-18 16:13:24 +02:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2020-06-02 15:29:16 +02:00
|
|
|
package convert
|
|
|
|
|
|
|
|
import (
|
2020-08-07 16:33:20 +02:00
|
|
|
"errors"
|
2020-06-02 15:29:16 +02:00
|
|
|
"strconv"
|
2020-06-30 16:11:54 +02:00
|
|
|
"testing"
|
2020-06-02 15:29:16 +02:00
|
|
|
|
2020-08-05 15:09:33 +02:00
|
|
|
"github.com/Azure/azure-sdk-for-go/profiles/latest/containerinstance/mgmt/containerinstance"
|
2020-06-02 15:29:16 +02:00
|
|
|
"github.com/Azure/go-autorest/autorest/to"
|
|
|
|
"github.com/compose-spec/compose-go/types"
|
|
|
|
cliconfigtypes "github.com/docker/cli/cli/config/types"
|
2021-01-31 20:15:00 +01:00
|
|
|
"github.com/docker/compose-cli/aci/login"
|
2020-06-02 15:29:16 +02:00
|
|
|
"github.com/stretchr/testify/mock"
|
2020-08-05 15:09:33 +02:00
|
|
|
"gotest.tools/v3/assert"
|
2020-07-31 14:24:04 +02:00
|
|
|
is "gotest.tools/v3/assert/cmp"
|
2020-06-02 15:29:16 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
const getAllCredentials = "getAllRegistryCredentials"
|
2020-08-07 16:33:20 +02:00
|
|
|
const autoLoginAcr = "autoLoginAcr"
|
2020-06-02 15:29:16 +02:00
|
|
|
|
2020-08-05 15:09:33 +02:00
|
|
|
func TestHubPrivateImage(t *testing.T) {
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper := &MockRegistryHelper{}
|
|
|
|
registryHelper.On(getAllCredentials).Return(registry("https://index.docker.io", userPwdCreds("toto", "pwd")), nil)
|
2020-06-02 15:29:16 +02:00
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
creds, err := getRegistryCredentials(composeServices("gtardif/privateimg"), registryHelper)
|
2020-08-05 15:09:33 +02:00
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.DeepEqual(t, creds, []containerinstance.ImageRegistryCredential{
|
2020-06-02 15:29:16 +02:00
|
|
|
{
|
|
|
|
Server: to.StringPtr(dockerHub),
|
|
|
|
Username: to.StringPtr("toto"),
|
|
|
|
Password: to.StringPtr("pwd"),
|
|
|
|
},
|
2020-08-05 15:09:33 +02:00
|
|
|
})
|
2020-06-02 15:29:16 +02:00
|
|
|
}
|
|
|
|
|
2020-08-05 15:09:33 +02:00
|
|
|
func TestRegistryNameWithoutProtocol(t *testing.T) {
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper := &MockRegistryHelper{}
|
|
|
|
registryHelper.On(getAllCredentials).Return(registry("index.docker.io", userPwdCreds("toto", "pwd")), nil)
|
2020-06-02 15:29:16 +02:00
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
creds, err := getRegistryCredentials(composeServices("gtardif/privateimg"), registryHelper)
|
2020-08-05 15:09:33 +02:00
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.DeepEqual(t, creds, []containerinstance.ImageRegistryCredential{
|
2020-06-02 15:29:16 +02:00
|
|
|
{
|
|
|
|
Server: to.StringPtr(dockerHub),
|
|
|
|
Username: to.StringPtr("toto"),
|
|
|
|
Password: to.StringPtr("pwd"),
|
|
|
|
},
|
2020-08-05 15:09:33 +02:00
|
|
|
})
|
2020-06-02 15:29:16 +02:00
|
|
|
}
|
|
|
|
|
2020-08-05 15:22:13 +02:00
|
|
|
func TestInvalidCredentials(t *testing.T) {
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper := &MockRegistryHelper{}
|
|
|
|
registryHelper.On(getAllCredentials).Return(registry("18.195.159.6:444", userPwdCreds("toto", "pwd")), nil)
|
2020-08-05 15:22:13 +02:00
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
creds, err := getRegistryCredentials(composeServices("gtardif/privateimg"), registryHelper)
|
2020-08-05 15:22:13 +02:00
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.Equal(t, len(creds), 0)
|
|
|
|
}
|
|
|
|
|
2020-08-05 15:09:33 +02:00
|
|
|
func TestImageWithDotInName(t *testing.T) {
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper := &MockRegistryHelper{}
|
|
|
|
registryHelper.On(getAllCredentials).Return(registry("index.docker.io", userPwdCreds("toto", "pwd")), nil)
|
2020-06-02 15:29:16 +02:00
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
creds, err := getRegistryCredentials(composeServices("my.image"), registryHelper)
|
2020-08-05 15:09:33 +02:00
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.DeepEqual(t, creds, []containerinstance.ImageRegistryCredential{
|
2020-06-02 15:29:16 +02:00
|
|
|
{
|
|
|
|
Server: to.StringPtr(dockerHub),
|
|
|
|
Username: to.StringPtr("toto"),
|
|
|
|
Password: to.StringPtr("pwd"),
|
|
|
|
},
|
2020-08-05 15:09:33 +02:00
|
|
|
})
|
2020-06-02 15:29:16 +02:00
|
|
|
}
|
|
|
|
|
2020-08-05 15:09:33 +02:00
|
|
|
func TestAcrPrivateImage(t *testing.T) {
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper := &MockRegistryHelper{}
|
|
|
|
registryHelper.On(getAllCredentials).Return(registry("https://mycontainerregistrygta.azurecr.io", tokenCreds("123456")), nil)
|
|
|
|
registryHelper.On(autoLoginAcr, "mycontainerregistrygta.azurecr.io").Return(nil)
|
2020-06-02 15:29:16 +02:00
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
creds, err := getRegistryCredentials(composeServices("mycontainerregistrygta.azurecr.io/privateimg"), registryHelper)
|
2020-08-05 15:09:33 +02:00
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.DeepEqual(t, creds, []containerinstance.ImageRegistryCredential{
|
2020-06-02 15:29:16 +02:00
|
|
|
{
|
|
|
|
Server: to.StringPtr("mycontainerregistrygta.azurecr.io"),
|
|
|
|
Username: to.StringPtr(tokenUsername),
|
|
|
|
Password: to.StringPtr("123456"),
|
|
|
|
},
|
2020-08-05 15:09:33 +02:00
|
|
|
})
|
2020-06-02 15:29:16 +02:00
|
|
|
}
|
|
|
|
|
2020-08-05 15:09:33 +02:00
|
|
|
func TestAcrPrivateImageLinux(t *testing.T) {
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper := &MockRegistryHelper{}
|
2020-06-30 16:11:54 +02:00
|
|
|
token := tokenCreds("123456")
|
|
|
|
token.Username = tokenUsername
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper.On(getAllCredentials).Return(registry("https://mycontainerregistrygta.azurecr.io", token), nil)
|
|
|
|
registryHelper.On(autoLoginAcr, "mycontainerregistrygta.azurecr.io").Return(nil)
|
2020-06-30 16:11:54 +02:00
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
creds, err := getRegistryCredentials(composeServices("mycontainerregistrygta.azurecr.io/privateimg"), registryHelper)
|
2020-08-05 15:09:33 +02:00
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.DeepEqual(t, creds, []containerinstance.ImageRegistryCredential{
|
2020-06-30 16:11:54 +02:00
|
|
|
{
|
|
|
|
Server: to.StringPtr("mycontainerregistrygta.azurecr.io"),
|
|
|
|
Username: to.StringPtr(tokenUsername),
|
|
|
|
Password: to.StringPtr("123456"),
|
|
|
|
},
|
2020-08-05 15:09:33 +02:00
|
|
|
})
|
2020-06-30 16:11:54 +02:00
|
|
|
}
|
|
|
|
|
2020-08-05 15:09:33 +02:00
|
|
|
func TestNoMoreRegistriesThanImages(t *testing.T) {
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper := &MockRegistryHelper{}
|
2020-06-02 15:29:16 +02:00
|
|
|
configs := map[string]cliconfigtypes.AuthConfig{
|
|
|
|
"https://mycontainerregistrygta.azurecr.io": tokenCreds("123456"),
|
|
|
|
"https://index.docker.io": userPwdCreds("toto", "pwd"),
|
|
|
|
}
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper.On(getAllCredentials).Return(configs, nil)
|
|
|
|
registryHelper.On(autoLoginAcr, "mycontainerregistrygta.azurecr.io").Return(nil)
|
2020-06-02 15:29:16 +02:00
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
creds, err := getRegistryCredentials(composeServices("mycontainerregistrygta.azurecr.io/privateimg"), registryHelper)
|
2020-08-05 15:09:33 +02:00
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.DeepEqual(t, creds, []containerinstance.ImageRegistryCredential{
|
2020-06-02 15:29:16 +02:00
|
|
|
{
|
|
|
|
Server: to.StringPtr("mycontainerregistrygta.azurecr.io"),
|
|
|
|
Username: to.StringPtr(tokenUsername),
|
|
|
|
Password: to.StringPtr("123456"),
|
|
|
|
},
|
2020-08-05 15:09:33 +02:00
|
|
|
})
|
2020-06-02 15:29:16 +02:00
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
creds, err = getRegistryCredentials(composeServices("someuser/privateimg"), registryHelper)
|
2020-08-05 15:09:33 +02:00
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.DeepEqual(t, creds, []containerinstance.ImageRegistryCredential{
|
2020-06-02 15:29:16 +02:00
|
|
|
{
|
|
|
|
Server: to.StringPtr(dockerHub),
|
|
|
|
Username: to.StringPtr("toto"),
|
|
|
|
Password: to.StringPtr("pwd"),
|
|
|
|
},
|
2020-08-05 15:09:33 +02:00
|
|
|
})
|
2020-06-02 15:29:16 +02:00
|
|
|
}
|
|
|
|
|
2020-08-05 15:09:33 +02:00
|
|
|
func TestHubAndSeveralACRRegistries(t *testing.T) {
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper := &MockRegistryHelper{}
|
2020-06-02 15:29:16 +02:00
|
|
|
configs := map[string]cliconfigtypes.AuthConfig{
|
|
|
|
"https://mycontainerregistry1.azurecr.io": tokenCreds("123456"),
|
|
|
|
"https://mycontainerregistry2.azurecr.io": tokenCreds("456789"),
|
|
|
|
"https://mycontainerregistry3.azurecr.io": tokenCreds("123456789"),
|
|
|
|
"https://index.docker.io": userPwdCreds("toto", "pwd"),
|
|
|
|
"https://other.registry.io": userPwdCreds("user", "password"),
|
|
|
|
}
|
2020-08-07 16:33:20 +02:00
|
|
|
registryHelper.On(getAllCredentials).Return(configs, nil)
|
|
|
|
registryHelper.On(autoLoginAcr, "mycontainerregistry1.azurecr.io").Return(nil)
|
|
|
|
registryHelper.On(autoLoginAcr, "mycontainerregistry2.azurecr.io").Return(nil)
|
2020-06-02 15:29:16 +02:00
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
creds, err := getRegistryCredentials(composeServices("mycontainerregistry1.azurecr.io/privateimg", "someuser/privateImg2", "mycontainerregistry2.azurecr.io/privateimg"), registryHelper)
|
2020-08-05 15:09:33 +02:00
|
|
|
assert.NilError(t, err)
|
|
|
|
|
2020-07-31 14:24:04 +02:00
|
|
|
assert.Assert(t, is.Contains(creds, containerinstance.ImageRegistryCredential{
|
2020-06-02 15:29:16 +02:00
|
|
|
Server: to.StringPtr("mycontainerregistry1.azurecr.io"),
|
|
|
|
Username: to.StringPtr(tokenUsername),
|
|
|
|
Password: to.StringPtr("123456"),
|
|
|
|
}))
|
2020-07-31 14:24:04 +02:00
|
|
|
assert.Assert(t, is.Contains(creds, containerinstance.ImageRegistryCredential{
|
2020-06-02 15:29:16 +02:00
|
|
|
Server: to.StringPtr("mycontainerregistry2.azurecr.io"),
|
|
|
|
Username: to.StringPtr(tokenUsername),
|
|
|
|
Password: to.StringPtr("456789"),
|
|
|
|
}))
|
2020-07-31 14:24:04 +02:00
|
|
|
assert.Assert(t, is.Contains(creds, containerinstance.ImageRegistryCredential{
|
2020-06-02 15:29:16 +02:00
|
|
|
Server: to.StringPtr(dockerHub),
|
|
|
|
Username: to.StringPtr("toto"),
|
|
|
|
Password: to.StringPtr("pwd"),
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
func TestIgnoreACRRegistryFailedAutoLogin(t *testing.T) {
|
|
|
|
registryHelper := &MockRegistryHelper{}
|
|
|
|
configs := map[string]cliconfigtypes.AuthConfig{
|
|
|
|
"https://mycontainerregistry1.azurecr.io": tokenCreds("123456"),
|
|
|
|
"https://mycontainerregistry3.azurecr.io": tokenCreds("123456789"),
|
|
|
|
"https://index.docker.io": userPwdCreds("toto", "pwd"),
|
|
|
|
"https://other.registry.io": userPwdCreds("user", "password"),
|
|
|
|
}
|
|
|
|
registryHelper.On(getAllCredentials).Return(configs, nil)
|
|
|
|
registryHelper.On(autoLoginAcr, "mycontainerregistry1.azurecr.io").Return(nil)
|
|
|
|
registryHelper.On(autoLoginAcr, "mycontainerregistry2.azurecr.io").Return(errors.New("could not login"))
|
|
|
|
|
|
|
|
creds, err := getRegistryCredentials(composeServices("mycontainerregistry1.azurecr.io/privateimg", "someuser/privateImg2", "mycontainerregistry2.azurecr.io/privateimg"), registryHelper)
|
|
|
|
assert.NilError(t, err)
|
|
|
|
assert.Equal(t, len(creds), 2)
|
|
|
|
|
|
|
|
assert.Assert(t, is.Contains(creds, containerinstance.ImageRegistryCredential{
|
|
|
|
Server: to.StringPtr("mycontainerregistry1.azurecr.io"),
|
|
|
|
Username: to.StringPtr(tokenUsername),
|
|
|
|
Password: to.StringPtr("123456"),
|
|
|
|
}))
|
|
|
|
|
|
|
|
assert.Assert(t, is.Contains(creds, containerinstance.ImageRegistryCredential{
|
|
|
|
Server: to.StringPtr(dockerHub),
|
|
|
|
Username: to.StringPtr("toto"),
|
|
|
|
Password: to.StringPtr("pwd"),
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
|
2020-07-02 16:05:45 +02:00
|
|
|
func composeServices(images ...string) types.Project {
|
2020-06-02 15:29:16 +02:00
|
|
|
var services []types.ServiceConfig
|
|
|
|
for index, name := range images {
|
|
|
|
service := types.ServiceConfig{
|
|
|
|
Name: "service" + strconv.Itoa(index),
|
|
|
|
Image: name,
|
|
|
|
}
|
|
|
|
services = append(services, service)
|
|
|
|
}
|
2020-07-02 16:05:45 +02:00
|
|
|
return types.Project{
|
|
|
|
Services: services,
|
2020-06-02 15:29:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func registry(host string, configregistryData cliconfigtypes.AuthConfig) map[string]cliconfigtypes.AuthConfig {
|
|
|
|
return map[string]cliconfigtypes.AuthConfig{
|
|
|
|
host: configregistryData,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func userPwdCreds(user string, password string) cliconfigtypes.AuthConfig {
|
|
|
|
return cliconfigtypes.AuthConfig{
|
|
|
|
Username: user,
|
|
|
|
Password: password,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func tokenCreds(token string) cliconfigtypes.AuthConfig {
|
|
|
|
return cliconfigtypes.AuthConfig{
|
|
|
|
IdentityToken: token,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
type MockRegistryHelper struct {
|
2020-06-02 15:29:16 +02:00
|
|
|
mock.Mock
|
|
|
|
}
|
|
|
|
|
2020-08-07 16:33:20 +02:00
|
|
|
func (s *MockRegistryHelper) getAllRegistryCredentials() (map[string]cliconfigtypes.AuthConfig, error) {
|
2020-06-02 15:29:16 +02:00
|
|
|
args := s.Called()
|
|
|
|
return args.Get(0).(map[string]cliconfigtypes.AuthConfig), args.Error(1)
|
|
|
|
}
|
2020-08-07 16:33:20 +02:00
|
|
|
|
2021-01-31 20:15:00 +01:00
|
|
|
func (s *MockRegistryHelper) autoLoginAcr(registry string, loginService login.AzureLoginService) error {
|
|
|
|
args := s.Called(registry, loginService)
|
2020-08-07 16:33:20 +02:00
|
|
|
return args.Error(0)
|
|
|
|
}
|