agola/internal/services/gateway/common/variables_test.go
2019-03-14 14:36:18 +01:00

284 lines
6.6 KiB
Go

// Copyright 2019 Sorint.lab
//
// 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.
package common
import (
"testing"
"github.com/google/go-cmp/cmp"
"github.com/sorintlab/agola/internal/services/types"
)
func TestFilterOverridenVariables(t *testing.T) {
tests := []struct {
name string
variables []*types.Variable
out []*types.Variable
}{
{
name: "test empty variables",
variables: []*types.Variable{},
out: []*types.Variable{},
},
{
name: "test variable overrides",
variables: []*types.Variable{
// variables must be in depth (from leaves to root) order as returned by the
// configstore apis
&types.Variable{
Name: "var04",
Parent: types.Parent{
Path: "org/org01/projectgroup02/projectgroup03/project02",
},
},
&types.Variable{
Name: "var03",
Parent: types.Parent{
Path: "org/org01/projectgroup01/project01",
},
},
&types.Variable{
Name: "var02",
Parent: types.Parent{
Path: "org/org01/projectgroup01/project01",
},
},
&types.Variable{
Name: "var02",
Parent: types.Parent{
Path: "org/org01/projectgroup01",
},
},
&types.Variable{
Name: "var01",
Parent: types.Parent{
Path: "org/org01/projectgroup01",
},
},
&types.Variable{
Name: "var01",
Parent: types.Parent{
Path: "org/org01",
},
},
},
out: []*types.Variable{
&types.Variable{
Name: "var04",
Parent: types.Parent{
Path: "org/org01/projectgroup02/projectgroup03/project02",
},
},
&types.Variable{
Name: "var03",
Parent: types.Parent{
Path: "org/org01/projectgroup01/project01",
},
},
&types.Variable{
Name: "var02",
Parent: types.Parent{
Path: "org/org01/projectgroup01/project01",
},
},
&types.Variable{
Name: "var01",
Parent: types.Parent{
Path: "org/org01/projectgroup01",
},
},
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
out := FilterOverridenVariables(tt.variables)
if diff := cmp.Diff(tt.out, out); diff != "" {
t.Error(diff)
}
})
}
}
func TestGetVarValueMatchingSecret(t *testing.T) {
tests := []struct {
name string
varValue types.VariableValue
varParentPath string
secrets []*types.Secret
out *types.Secret
}{
{
name: "test empty secrets",
varValue: types.VariableValue{
SecretName: "secret01",
SecretVar: "secretvar01",
},
varParentPath: "org/org01/projectgroup01/project01",
secrets: []*types.Secret{},
out: nil,
},
{
name: "test secret with different name",
varValue: types.VariableValue{
SecretName: "secret01",
SecretVar: "secretvar01",
},
varParentPath: "org/org01/projectgroup01/projectgroup02",
secrets: []*types.Secret{
&types.Secret{
Name: "secret02",
Parent: types.Parent{
Path: "org/org01/projectgroup01/projectgroup02",
},
},
},
out: nil,
},
{
name: "test secret with tree",
varValue: types.VariableValue{
SecretName: "secret01",
SecretVar: "secretvar01",
},
varParentPath: "org/org01/projectgroup01/projectgroup02",
secrets: []*types.Secret{
&types.Secret{
Name: "secret02",
Parent: types.Parent{
Path: "org/org01/projectgroup01/projectgroup03",
},
},
},
out: nil,
},
{
name: "test secret in child of variable parent",
varValue: types.VariableValue{
SecretName: "secret01",
SecretVar: "secretvar01",
},
varParentPath: "org/org01/projectgroup01/projectgroup02",
secrets: []*types.Secret{
&types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01/projectgroup02/project01",
},
},
},
out: nil,
},
{
name: "test secret in same parent and also child of variable parent",
varValue: types.VariableValue{
SecretName: "secret01",
SecretVar: "secretvar01",
},
varParentPath: "org/org01/projectgroup01/projectgroup02",
secrets: []*types.Secret{
&types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01/projectgroup02/project01",
},
},
&types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01/projectgroup02",
},
},
},
out: &types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01/projectgroup02",
},
},
},
{
name: "test secret in parent",
varValue: types.VariableValue{
SecretName: "secret01",
SecretVar: "secretvar01",
},
varParentPath: "org/org01/projectgroup01/projectgroup02",
secrets: []*types.Secret{
&types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01",
},
},
},
out: &types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01",
},
},
},
{
name: "test multiple secrets in same branch and also child of variable parent",
varValue: types.VariableValue{
SecretName: "secret01",
SecretVar: "secretvar01",
},
varParentPath: "org/org01/projectgroup01/projectgroup02",
secrets: []*types.Secret{
// secrets must be in depth (from leaves to root) order as returned by the
// configstore apis
&types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01/projectgroup02/project01",
},
},
&types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01/projectgroup02",
},
},
&types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01",
},
},
},
out: &types.Secret{
Name: "secret01",
Parent: types.Parent{
Path: "org/org01/projectgroup01/projectgroup02",
},
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
out := GetVarValueMatchingSecret(tt.varValue, tt.varParentPath, tt.secrets)
if diff := cmp.Diff(tt.out, out); diff != "" {
t.Error(diff)
}
})
}
}