2023-10-24 09:39:18 -04:00
|
|
|
/*
|
|
|
|
Copyright (c) Edgeless Systems GmbH
|
|
|
|
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
2023-10-30 04:30:35 -04:00
|
|
|
"strings"
|
2023-10-24 09:39:18 -04:00
|
|
|
"testing"
|
2023-10-26 09:59:13 -04:00
|
|
|
"time"
|
2023-10-24 09:39:18 -04:00
|
|
|
|
|
|
|
"github.com/edgelesssys/constellation/v2/cli/internal/helm"
|
|
|
|
"github.com/edgelesssys/constellation/v2/internal/file"
|
|
|
|
"github.com/edgelesssys/constellation/v2/internal/logger"
|
|
|
|
"github.com/spf13/afero"
|
|
|
|
"github.com/spf13/pflag"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestParseApplyFlags(t *testing.T) {
|
|
|
|
require := require.New(t)
|
|
|
|
defaultFlags := func() *pflag.FlagSet {
|
2023-10-26 09:59:13 -04:00
|
|
|
flags := NewApplyCmd().Flags()
|
|
|
|
// Register persistent flags
|
2023-10-24 09:39:18 -04:00
|
|
|
flags.String("workspace", "", "")
|
|
|
|
flags.String("tf-log", "NONE", "")
|
|
|
|
flags.Bool("force", false, "")
|
|
|
|
flags.Bool("debug", false, "")
|
|
|
|
return flags
|
|
|
|
}
|
|
|
|
|
|
|
|
testCases := map[string]struct {
|
|
|
|
flags *pflag.FlagSet
|
|
|
|
wantFlags applyFlags
|
|
|
|
wantErr bool
|
|
|
|
}{
|
|
|
|
"default flags": {
|
|
|
|
flags: defaultFlags(),
|
|
|
|
wantFlags: applyFlags{
|
2023-10-26 09:59:13 -04:00
|
|
|
helmWaitMode: helm.WaitModeAtomic,
|
|
|
|
upgradeTimeout: 5 * time.Minute,
|
2023-10-24 09:39:18 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
"skip phases": {
|
|
|
|
flags: func() *pflag.FlagSet {
|
|
|
|
flags := defaultFlags()
|
|
|
|
require.NoError(flags.Set("skip-phases", fmt.Sprintf("%s,%s", skipHelmPhase, skipK8sPhase)))
|
|
|
|
return flags
|
|
|
|
}(),
|
|
|
|
wantFlags: applyFlags{
|
2023-10-26 09:59:13 -04:00
|
|
|
skipPhases: skipPhases{skipHelmPhase: struct{}{}, skipK8sPhase: struct{}{}},
|
|
|
|
helmWaitMode: helm.WaitModeAtomic,
|
|
|
|
upgradeTimeout: 5 * time.Minute,
|
2023-10-24 09:39:18 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
"skip helm wait": {
|
|
|
|
flags: func() *pflag.FlagSet {
|
|
|
|
flags := defaultFlags()
|
|
|
|
require.NoError(flags.Set("skip-helm-wait", "true"))
|
|
|
|
return flags
|
|
|
|
}(),
|
|
|
|
wantFlags: applyFlags{
|
2023-10-26 09:59:13 -04:00
|
|
|
helmWaitMode: helm.WaitModeNone,
|
|
|
|
upgradeTimeout: 5 * time.Minute,
|
2023-10-24 09:39:18 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for name, tc := range testCases {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
assert := assert.New(t)
|
|
|
|
var flags applyFlags
|
|
|
|
|
|
|
|
err := flags.parse(tc.flags)
|
|
|
|
if tc.wantErr {
|
|
|
|
assert.Error(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
assert.NoError(err)
|
|
|
|
assert.Equal(tc.wantFlags, flags)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestBackupHelmCharts(t *testing.T) {
|
|
|
|
testCases := map[string]struct {
|
|
|
|
helmApplier helm.Applier
|
|
|
|
backupClient *stubKubernetesUpgrader
|
|
|
|
includesUpgrades bool
|
|
|
|
wantErr bool
|
|
|
|
}{
|
|
|
|
"success, no upgrades": {
|
|
|
|
helmApplier: &stubRunner{},
|
|
|
|
backupClient: &stubKubernetesUpgrader{},
|
|
|
|
},
|
|
|
|
"success with upgrades": {
|
|
|
|
helmApplier: &stubRunner{},
|
|
|
|
backupClient: &stubKubernetesUpgrader{},
|
|
|
|
includesUpgrades: true,
|
|
|
|
},
|
|
|
|
"saving charts fails": {
|
|
|
|
helmApplier: &stubRunner{
|
|
|
|
saveChartsErr: assert.AnError,
|
|
|
|
},
|
|
|
|
backupClient: &stubKubernetesUpgrader{},
|
|
|
|
wantErr: true,
|
|
|
|
},
|
|
|
|
"backup CRDs fails": {
|
|
|
|
helmApplier: &stubRunner{},
|
|
|
|
backupClient: &stubKubernetesUpgrader{
|
|
|
|
backupCRDsErr: assert.AnError,
|
|
|
|
},
|
|
|
|
includesUpgrades: true,
|
|
|
|
wantErr: true,
|
|
|
|
},
|
|
|
|
"backup CRs fails": {
|
|
|
|
helmApplier: &stubRunner{},
|
|
|
|
backupClient: &stubKubernetesUpgrader{
|
|
|
|
backupCRsErr: assert.AnError,
|
|
|
|
},
|
|
|
|
includesUpgrades: true,
|
|
|
|
wantErr: true,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for name, tc := range testCases {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
assert := assert.New(t)
|
|
|
|
|
|
|
|
a := applyCmd{
|
|
|
|
fileHandler: file.NewHandler(afero.NewMemMapFs()),
|
|
|
|
log: logger.NewTest(t),
|
|
|
|
}
|
|
|
|
|
|
|
|
err := a.backupHelmCharts(context.Background(), tc.backupClient, tc.helmApplier, tc.includesUpgrades, "")
|
|
|
|
if tc.wantErr {
|
|
|
|
assert.Error(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
assert.NoError(err)
|
|
|
|
if tc.includesUpgrades {
|
|
|
|
assert.True(tc.backupClient.backupCRDsCalled)
|
|
|
|
assert.True(tc.backupClient.backupCRsCalled)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2023-10-30 04:30:35 -04:00
|
|
|
|
|
|
|
func TestSkipPhases(t *testing.T) {
|
|
|
|
require := require.New(t)
|
|
|
|
cmd := NewApplyCmd()
|
|
|
|
// register persistent flags manually
|
|
|
|
cmd.Flags().String("workspace", "", "")
|
|
|
|
cmd.Flags().Bool("force", true, "")
|
|
|
|
cmd.Flags().String("tf-log", "NONE", "")
|
|
|
|
cmd.Flags().Bool("debug", false, "")
|
|
|
|
|
|
|
|
require.NoError(cmd.Flags().Set("skip-phases", strings.Join(allPhases(), ",")))
|
|
|
|
wantPhases := skipPhases{}
|
|
|
|
wantPhases.add(skipInfrastructurePhase, skipInitPhase, skipAttestationConfigPhase, skipCertSANsPhase, skipHelmPhase, skipK8sPhase, skipImagePhase)
|
|
|
|
|
|
|
|
var flags applyFlags
|
|
|
|
err := flags.parse(cmd.Flags())
|
|
|
|
require.NoError(err)
|
|
|
|
assert.Equal(t, wantPhases, flags.skipPhases)
|
|
|
|
}
|