diff --git a/.gitignore b/.gitignore index 7850f288c6..a999a148ad 100644 --- a/.gitignore +++ b/.gitignore @@ -34,6 +34,7 @@ kotsdata/ sbom/ cosign.key pkg/tests/pull/cases/*/results +pkg/tests/renderdir/cases/*/results melange.rsa melange.rsa.pub diff --git a/pkg/handlers/config.go b/pkg/handlers/config.go index 9aee7e35c6..408889d081 100644 --- a/pkg/handlers/config.go +++ b/pkg/handlers/config.go @@ -28,6 +28,7 @@ import ( "github.com/replicatedhq/kots/pkg/preflight" registrytypes "github.com/replicatedhq/kots/pkg/registry/types" "github.com/replicatedhq/kots/pkg/render" + rendertypes "github.com/replicatedhq/kots/pkg/render/types" "github.com/replicatedhq/kots/pkg/replicatedapp" "github.com/replicatedhq/kots/pkg/store" storetypes "github.com/replicatedhq/kots/pkg/store/types" @@ -893,7 +894,13 @@ func updateAppConfig(updateApp *apptypes.App, sequence int64, configGroups []kot renderSequence = nextAppSequence } - err = render.RenderDir(archiveDir, app, downstreams, registrySettings, renderSequence) + err = render.RenderDir(rendertypes.RenderDirOptions{ + ArchiveDir: archiveDir, + App: app, + Downstreams: downstreams, + RegistrySettings: registrySettings, + Sequence: renderSequence, + }) if err != nil { cause := errors.Cause(err) if _, ok := cause.(util.ActionableError); ok { diff --git a/pkg/handlers/identity.go b/pkg/handlers/identity.go index f0e9b4459b..e5f2f083da 100644 --- a/pkg/handlers/identity.go +++ b/pkg/handlers/identity.go @@ -25,6 +25,7 @@ import ( "github.com/replicatedhq/kots/pkg/preflight" "github.com/replicatedhq/kots/pkg/rbac" "github.com/replicatedhq/kots/pkg/render" + rendertypes "github.com/replicatedhq/kots/pkg/render/types" "github.com/replicatedhq/kots/pkg/store" "github.com/replicatedhq/kots/pkg/util" "github.com/replicatedhq/kots/pkg/version" @@ -455,7 +456,13 @@ func (h *Handler) ConfigureAppIdentityService(w http.ResponseWriter, r *http.Req return } - err = render.RenderDir(archiveDir, a, downstreams, registrySettings, nextAppSequence) + err = render.RenderDir(rendertypes.RenderDirOptions{ + ArchiveDir: archiveDir, + App: a, + Downstreams: downstreams, + RegistrySettings: registrySettings, + Sequence: nextAppSequence, + }) if err != nil { err = errors.Wrap(err, "failed to render archive directory") logger.Error(err) diff --git a/pkg/handlers/registry.go b/pkg/handlers/registry.go index ebabf8a05b..42c4594d6c 100644 --- a/pkg/handlers/registry.go +++ b/pkg/handlers/registry.go @@ -238,7 +238,7 @@ func (h *Handler) UpdateAppRegistry(w http.ResponseWriter, r *http.Request) { appDir, err := registry.RewriteImages( foundApp.ID, latestSequence, updateAppRegistryRequest.Hostname, updateAppRegistryRequest.Username, registryPassword, - updateAppRegistryRequest.Namespace, skipImagePush, nil) + updateAppRegistryRequest.Namespace, skipImagePush) if err != nil { // log credential errors at info level causeErr := errors.Cause(err) diff --git a/pkg/handlers/upload.go b/pkg/handlers/upload.go index f87b18bec7..fcd2a14ba9 100644 --- a/pkg/handlers/upload.go +++ b/pkg/handlers/upload.go @@ -15,6 +15,7 @@ import ( "github.com/replicatedhq/kots/pkg/logger" "github.com/replicatedhq/kots/pkg/preflight" "github.com/replicatedhq/kots/pkg/render" + rendertypes "github.com/replicatedhq/kots/pkg/render/types" "github.com/replicatedhq/kots/pkg/store" storetypes "github.com/replicatedhq/kots/pkg/store/types" "github.com/replicatedhq/kots/pkg/util" @@ -158,7 +159,13 @@ func (h *Handler) UploadExistingApp(w http.ResponseWriter, r *http.Request) { return } - err = render.RenderDir(archiveDir, a, downstreams, registrySettings, nextAppSequence) + err = render.RenderDir(rendertypes.RenderDirOptions{ + ArchiveDir: archiveDir, + App: a, + Downstreams: downstreams, + RegistrySettings: registrySettings, + Sequence: nextAppSequence, + }) if err != nil { cause := errors.Cause(err) if _, ok := cause.(util.ActionableError); ok { diff --git a/pkg/operator/operator.go b/pkg/operator/operator.go index 7b5c4f306e..003b9ef12c 100644 --- a/pkg/operator/operator.go +++ b/pkg/operator/operator.go @@ -886,7 +886,15 @@ func (o *Operator) renderKotsApplicationSpec(app *apptypes.App, sequence int64, return nil, errors.Wrap(err, "failed to marshal kots app spec") } - renderedKotsAppSpec, err := renderer.RenderFile(kotsKinds, registrySettings, app.Slug, sequence, app.IsAirgap, namespace, []byte(marshalledKotsAppSpec)) + renderedKotsAppSpec, err := renderer.RenderFile(rendertypes.RenderFileOptions{ + KotsKinds: kotsKinds, + RegistrySettings: registrySettings, + AppSlug: app.Slug, + Sequence: sequence, + IsAirgap: app.IsAirgap, + Namespace: namespace, + InputContent: []byte(marshalledKotsAppSpec), + }) if err != nil { return nil, errors.Wrap(err, "failed to render preflights") } diff --git a/pkg/preflight/preflight.go b/pkg/preflight/preflight.go index d1d46c2cc9..d32e69a03c 100644 --- a/pkg/preflight/preflight.go +++ b/pkg/preflight/preflight.go @@ -20,6 +20,7 @@ import ( registrytypes "github.com/replicatedhq/kots/pkg/registry/types" "github.com/replicatedhq/kots/pkg/render" "github.com/replicatedhq/kots/pkg/render/helper" + rendertypes "github.com/replicatedhq/kots/pkg/render/types" "github.com/replicatedhq/kots/pkg/reporting" "github.com/replicatedhq/kots/pkg/store" storetypes "github.com/replicatedhq/kots/pkg/store/types" @@ -107,7 +108,15 @@ func Run(appID string, appSlug string, sequence int64, isAirgap bool, archiveDir return errors.Wrap(err, "failed to marshal rendered preflight") } - renderedPreflight, err := render.RenderFile(kotsKinds, registrySettings, appSlug, sequence, isAirgap, util.PodNamespace, []byte(renderedMarshalledPreflights)) + renderedPreflight, err := render.RenderFile(rendertypes.RenderFileOptions{ + KotsKinds: kotsKinds, + RegistrySettings: registrySettings, + AppSlug: appSlug, + Sequence: sequence, + IsAirgap: isAirgap, + Namespace: util.PodNamespace, + InputContent: []byte(renderedMarshalledPreflights), + }) if err != nil { return errors.Wrap(err, "failed to render preflights") } diff --git a/pkg/registry/registry.go b/pkg/registry/registry.go index cca11302b5..91917dd119 100644 --- a/pkg/registry/registry.go +++ b/pkg/registry/registry.go @@ -21,7 +21,6 @@ import ( "github.com/replicatedhq/kots/pkg/rewrite" "github.com/replicatedhq/kots/pkg/store" "github.com/replicatedhq/kots/pkg/util" - kotsv1beta1 "github.com/replicatedhq/kotskinds/apis/kots/v1beta1" corev1 "k8s.io/api/core/v1" kuberneteserrors "k8s.io/apimachinery/pkg/api/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" @@ -30,7 +29,7 @@ import ( // RewriteImages will use the app (a) and send the images to the registry specified. It will create patches for these // and create a new version of the application // the caller is responsible for deleting the appDir returned -func RewriteImages(appID string, sequence int64, hostname string, username string, password string, namespace string, isReadOnly bool, configValues *kotsv1beta1.ConfigValues) (appDir string, finalError error) { +func RewriteImages(appID string, sequence int64, hostname string, username string, password string, namespace string, isReadOnly bool) (appDir string, finalError error) { if err := store.GetStore().SetTaskStatus("image-rewrite", "Updating registry settings", "running"); err != nil { return "", errors.Wrap(err, "failed to set task status") } @@ -76,15 +75,6 @@ func RewriteImages(appID string, sequence int64, hostname string, username strin return "", errors.Wrap(err, "failed to get app version archive") } - kotsKinds, err := kotsutil.LoadKotsKinds(appDir) - if err != nil { - return "", errors.Wrap(err, "failed to load kotskinds from path") - } - - if configValues == nil { - configValues = kotsKinds.ConfigValues - } - // get the downstream names only downstreams, err := store.GetStore().ListDownstreamsForApp(appID) if err != nil { @@ -123,15 +113,30 @@ func RewriteImages(appID string, sequence int64, hostname string, username strin return "", errors.Wrap(err, "failed to get next app sequence") } + installation, err := kotsutil.LoadInstallationFromPath(filepath.Join(appDir, "upstream", "userdata", "installation.yaml")) + if err != nil { + return "", errors.Wrap(err, "failed to load installation from path") + } + + license, err := kotsutil.LoadLicenseFromPath(filepath.Join(appDir, "upstream", "userdata", "license.yaml")) + if err != nil { + return "", errors.Wrap(err, "failed to load license from path") + } + + configValues, err := kotsutil.LoadConfigValuesFromFile(filepath.Join(appDir, "upstream", "userdata", "config.yaml")) + if err != nil && !os.IsNotExist(errors.Cause(err)) { + return "", errors.Wrap(err, "failed to load config values from path") + } + options := rewrite.RewriteOptions{ RootDir: appDir, - UpstreamURI: fmt.Sprintf("replicated://%s", kotsKinds.License.Spec.AppSlug), + UpstreamURI: fmt.Sprintf("replicated://%s", license.Spec.AppSlug), UpstreamPath: filepath.Join(appDir, "upstream"), - Installation: &kotsKinds.Installation, + Installation: installation, Downstreams: downstreamNames, CreateAppDir: false, ExcludeKotsKinds: true, - License: kotsKinds.License, + License: license, ConfigValues: configValues, K8sNamespace: appNamespace, ReportWriter: pipeWriter, diff --git a/pkg/render/helper/appfile.go b/pkg/render/helper/appfile.go index 1c89a9a674..c8bb94b37a 100644 --- a/pkg/render/helper/appfile.go +++ b/pkg/render/helper/appfile.go @@ -6,6 +6,7 @@ import ( "github.com/replicatedhq/kots/pkg/kotsutil" registrytypes "github.com/replicatedhq/kots/pkg/registry/types" "github.com/replicatedhq/kots/pkg/render" + rendertypes "github.com/replicatedhq/kots/pkg/render/types" "github.com/replicatedhq/kots/pkg/store" "github.com/replicatedhq/kots/pkg/util" ) @@ -33,5 +34,13 @@ func RenderAppFile(a types.AppType, overrideSequence *int64, inputContent []byte registrySettings = s } - return render.RenderFile(kotsKinds, registrySettings, a.GetSlug(), sequence, a.GetIsAirgap(), namespace, inputContent) + return render.RenderFile(rendertypes.RenderFileOptions{ + KotsKinds: kotsKinds, + RegistrySettings: registrySettings, + AppSlug: a.GetSlug(), + Sequence: sequence, + IsAirgap: a.GetIsAirgap(), + Namespace: namespace, + InputContent: []byte(inputContent), + }) } diff --git a/pkg/render/render.go b/pkg/render/render.go index 16ecee507d..d63e10ae14 100644 --- a/pkg/render/render.go +++ b/pkg/render/render.go @@ -6,11 +6,10 @@ import ( "path/filepath" "github.com/pkg/errors" - downstreamtypes "github.com/replicatedhq/kots/pkg/api/downstream/types" - apptypes "github.com/replicatedhq/kots/pkg/app/types" "github.com/replicatedhq/kots/pkg/crypto" "github.com/replicatedhq/kots/pkg/kotsutil" registrytypes "github.com/replicatedhq/kots/pkg/registry/types" + types "github.com/replicatedhq/kots/pkg/render/types" "github.com/replicatedhq/kots/pkg/reporting" "github.com/replicatedhq/kots/pkg/rewrite" "github.com/replicatedhq/kots/pkg/template" @@ -23,28 +22,29 @@ type Renderer struct { // RenderFile renders a single file // this is useful for upstream/kotskinds files that are not rendered in the dir -func (r Renderer) RenderFile(kotsKinds *kotsutil.KotsKinds, registrySettings registrytypes.RegistrySettings, appSlug string, sequence int64, isAirgap bool, namespace string, inputContent []byte) ([]byte, error) { - return RenderFile(kotsKinds, registrySettings, appSlug, sequence, isAirgap, namespace, inputContent) +func (r Renderer) RenderFile(opts types.RenderFileOptions) ([]byte, error) { + return RenderFile(opts) } -func RenderFile(kotsKinds *kotsutil.KotsKinds, registrySettings registrytypes.RegistrySettings, appSlug string, sequence int64, isAirgap bool, namespace string, inputContent []byte) ([]byte, error) { - fixedUpContent, err := kotsutil.FixUpYAML(inputContent) +func RenderFile(opts types.RenderFileOptions) ([]byte, error) { + fixedUpContent, err := kotsutil.FixUpYAML(opts.InputContent) if err != nil { return nil, errors.Wrap(err, "failed to fix up yaml") } + opts.InputContent = fixedUpContent - return RenderContent(kotsKinds, registrySettings, appSlug, sequence, isAirgap, namespace, fixedUpContent) + return RenderContent(opts) } // RenderContent renders any string/content // this is useful for rendering single values, like a status informer -func RenderContent(kotsKinds *kotsutil.KotsKinds, registrySettings registrytypes.RegistrySettings, appSlug string, sequence int64, isAirgap bool, namespace string, inputContent []byte) ([]byte, error) { - builder, err := NewBuilder(kotsKinds, registrySettings, appSlug, sequence, isAirgap, namespace) +func RenderContent(opts types.RenderFileOptions) ([]byte, error) { + builder, err := NewBuilder(opts.KotsKinds, opts.RegistrySettings, opts.AppSlug, opts.Sequence, opts.IsAirgap, opts.Namespace) if err != nil { return nil, errors.Wrap(err, "failed to create builder") } - rendered, err := builder.RenderTemplate(string(inputContent), string(inputContent)) + rendered, err := builder.RenderTemplate(string(opts.InputContent), string(opts.InputContent)) if err != nil { return nil, errors.Wrap(err, "failed to render") } @@ -97,18 +97,28 @@ func NewBuilder(kotsKinds *kotsutil.KotsKinds, registrySettings registrytypes.Re // RenderDir renders an app archive dir // this is useful for when the license/config have updated, and template functions need to be evaluated again -func (r Renderer) RenderDir(archiveDir string, a *apptypes.App, downstreams []downstreamtypes.Downstream, registrySettings registrytypes.RegistrySettings, sequence int64) error { - return RenderDir(archiveDir, a, downstreams, registrySettings, sequence) +func (r Renderer) RenderDir(opts types.RenderDirOptions) error { + return RenderDir(opts) } -func RenderDir(archiveDir string, a *apptypes.App, downstreams []downstreamtypes.Downstream, registrySettings registrytypes.RegistrySettings, sequence int64) error { - kotsKinds, err := kotsutil.LoadKotsKinds(archiveDir) +func RenderDir(opts types.RenderDirOptions) error { + installation, err := kotsutil.LoadInstallationFromPath(filepath.Join(opts.ArchiveDir, "upstream", "userdata", "installation.yaml")) if err != nil { - return errors.Wrap(err, "failed to load kotskinds from path") + return errors.Wrap(err, "failed to load installation from path") + } + + license, err := kotsutil.LoadLicenseFromPath(filepath.Join(opts.ArchiveDir, "upstream", "userdata", "license.yaml")) + if err != nil { + return errors.Wrap(err, "failed to load license from path") + } + + configValues, err := kotsutil.LoadConfigValuesFromFile(filepath.Join(opts.ArchiveDir, "upstream", "userdata", "config.yaml")) + if err != nil && !os.IsNotExist(errors.Cause(err)) { + return errors.Wrap(err, "failed to load config values from path") } downstreamNames := []string{} - for _, d := range downstreams { + for _, d := range opts.Downstreams { downstreamNames = append(downstreamNames, d.Name) } @@ -118,25 +128,25 @@ func RenderDir(archiveDir string, a *apptypes.App, downstreams []downstreamtypes } reOptions := rewrite.RewriteOptions{ - RootDir: archiveDir, - UpstreamURI: fmt.Sprintf("replicated://%s", kotsKinds.License.Spec.AppSlug), - UpstreamPath: filepath.Join(archiveDir, "upstream"), - Installation: &kotsKinds.Installation, + RootDir: opts.ArchiveDir, + UpstreamURI: fmt.Sprintf("replicated://%s", license.Spec.AppSlug), + UpstreamPath: filepath.Join(opts.ArchiveDir, "upstream"), + Installation: installation, Downstreams: downstreamNames, Silent: true, CreateAppDir: false, ExcludeKotsKinds: true, - License: kotsKinds.License, - ConfigValues: kotsKinds.ConfigValues, + License: license, + ConfigValues: configValues, K8sNamespace: appNamespace, CopyImages: false, - IsAirgap: a.IsAirgap, - AppID: a.ID, - AppSlug: a.Slug, - IsGitOps: a.IsGitOps, - AppSequence: sequence, - ReportingInfo: reporting.GetReportingInfo(a.ID), - RegistrySettings: registrySettings, + IsAirgap: opts.App.IsAirgap, + AppID: opts.App.ID, + AppSlug: opts.App.Slug, + IsGitOps: opts.App.IsGitOps, + AppSequence: opts.Sequence, + ReportingInfo: reporting.GetReportingInfo(opts.App.ID), + RegistrySettings: opts.RegistrySettings, // TODO: pass in as arguments if this is ever called from CLI HTTPProxyEnvValue: os.Getenv("HTTP_PROXY"), diff --git a/pkg/render/types/interface.go b/pkg/render/types/interface.go index 0d9a7abf62..8bc5d85808 100644 --- a/pkg/render/types/interface.go +++ b/pkg/render/types/interface.go @@ -7,7 +7,25 @@ import ( registrytypes "github.com/replicatedhq/kots/pkg/registry/types" ) +type RenderFileOptions struct { + KotsKinds *kotsutil.KotsKinds + RegistrySettings registrytypes.RegistrySettings + AppSlug string + Sequence int64 + IsAirgap bool + Namespace string + InputContent []byte +} + +type RenderDirOptions struct { + ArchiveDir string + App *apptypes.App + Downstreams []downstreamtypes.Downstream + RegistrySettings registrytypes.RegistrySettings + Sequence int64 +} + type Renderer interface { - RenderFile(kotsKinds *kotsutil.KotsKinds, registrySettings registrytypes.RegistrySettings, appSlug string, sequence int64, isAirgap bool, namespace string, inputContent []byte) ([]byte, error) - RenderDir(archiveDir string, a *apptypes.App, downstreams []downstreamtypes.Downstream, registrySettings registrytypes.RegistrySettings, sequence int64) error + RenderFile(opts RenderFileOptions) ([]byte, error) + RenderDir(opts RenderDirOptions) error } diff --git a/pkg/store/kotsstore/license_store.go b/pkg/store/kotsstore/license_store.go index 1890e34726..bcf32fb9fc 100644 --- a/pkg/store/kotsstore/license_store.go +++ b/pkg/store/kotsstore/license_store.go @@ -185,7 +185,13 @@ func (s *KOTSStore) createNewVersionForLicenseChangeStatements(appID string, bas return nil, int64(0), errors.Wrap(err, "failed to get next app sequence") } - if err := renderer.RenderDir(archiveDir, app, downstreams, registrySettings, nextAppSequence); err != nil { + if err := renderer.RenderDir(rendertypes.RenderDirOptions{ + ArchiveDir: archiveDir, + App: app, + Downstreams: downstreams, + RegistrySettings: registrySettings, + Sequence: nextAppSequence, + }); err != nil { return nil, int64(0), errors.Wrap(err, "failed to render new version") } diff --git a/pkg/store/kotsstore/version_store.go b/pkg/store/kotsstore/version_store.go index 37ffdf6956..6424967f17 100644 --- a/pkg/store/kotsstore/version_store.go +++ b/pkg/store/kotsstore/version_store.go @@ -141,7 +141,15 @@ func (s *KOTSStore) IsSnapshotsSupportedForVersion(a *apptypes.App, sequence int } // as far as I can tell, this is the only place within pkg/store that uses templating - rendered, err := renderer.RenderFile(kotsKinds, registrySettings, a.Slug, sequence, a.IsAirgap, util.PodNamespace, []byte(backupSpecStr.String)) + rendered, err := renderer.RenderFile(rendertypes.RenderFileOptions{ + KotsKinds: kotsKinds, + RegistrySettings: registrySettings, + AppSlug: a.Slug, + Sequence: sequence, + IsAirgap: a.IsAirgap, + Namespace: util.PodNamespace, + InputContent: []byte(backupSpecStr.String), + }) if err != nil { return false, errors.Wrap(err, "failed to render backup spec") } @@ -1070,7 +1078,15 @@ func (s *KOTSStore) renderPreflightSpec(appID string, appSlug string, sequence i return nil, errors.Wrap(err, "failed to get registry settings for app") } - renderedPreflight, err := renderer.RenderFile(kotsKinds, registrySettings, appSlug, sequence, isAirgap, util.PodNamespace, []byte(renderedMarshalledPreflights)) + renderedPreflight, err := renderer.RenderFile(rendertypes.RenderFileOptions{ + KotsKinds: kotsKinds, + RegistrySettings: registrySettings, + AppSlug: appSlug, + Sequence: sequence, + IsAirgap: isAirgap, + Namespace: util.PodNamespace, + InputContent: []byte(renderedMarshalledPreflights), + }) if err != nil { return nil, errors.Wrap(err, "failed to render preflights") } @@ -1098,7 +1114,15 @@ func (s *KOTSStore) renderApplicationSpec(appID string, appSlug string, sequence return nil, errors.Wrap(err, "failed to get registry settings for app") } - renderedApplication, err := renderer.RenderFile(kotsKinds, registrySettings, appSlug, sequence, isAirgap, util.PodNamespace, []byte(renderedMarshalledPreflights)) + renderedApplication, err := renderer.RenderFile(rendertypes.RenderFileOptions{ + KotsKinds: kotsKinds, + RegistrySettings: registrySettings, + AppSlug: appSlug, + Sequence: sequence, + IsAirgap: isAirgap, + Namespace: util.PodNamespace, + InputContent: []byte(renderedMarshalledPreflights), + }) if err != nil { return nil, errors.Wrap(err, "failed to render application") } diff --git a/pkg/store/store.go b/pkg/store/store.go index 6b33204202..409eb32e97 100644 --- a/pkg/store/store.go +++ b/pkg/store/store.go @@ -28,6 +28,7 @@ func SetStore(s Store) { if s == nil { hasStore = false globalStore = nil + return } hasStore = true globalStore = s diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/base/kustomization.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/base/kustomization.yaml new file mode 100644 index 0000000000..b746efdcde --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/base/kustomization.yaml @@ -0,0 +1,7 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization +metadata: + annotations: + kots.io/kustomization: base +resources: +- subdir/configmap.yaml diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/base/subdir/configmap.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/base/subdir/configmap.yaml new file mode 100644 index 0000000000..cb312455ad --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/base/subdir/configmap.yaml @@ -0,0 +1,25 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + name: test-licenseinfo +data: + dockerCfg: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= + licenseFieldValueIsGitOpsSupported: true + licenseFieldValueIsIdentityServiceSupported: false + licenseFieldValueIsGeoaxisSupported: false + licenseFieldValueIsAirgapSupported: true + licenseFieldValueLicenseType: prod + licenseFieldValueLicenseSequence: 7 + licenseFieldValueSignature: '{"licenseData":"eyJhcGlWZXJzaW9uIjoia290cy5pby92MWJldGExIiwia2luZCI6IkxpY2Vuc2UiLCJtZXRhZGF0YSI6eyJuYW1lIjoidGVzdGN1c3RvbWVyIn0sInNwZWMiOnsibGljZW5zZUlEIjoiMXZ1c09va3hBVnAxdGtSR3V5eG5GMjNQSmNxIiwibGljZW5zZVR5cGUiOiJwcm9kIiwiY3VzdG9tZXJOYW1lIjoiVGVzdCBDdXN0b21lciIsImFwcFNsdWciOiJteS1hcHAiLCJjaGFubmVsSUQiOiIxdnVzSVlaTEFWeE1HNnE3NjBPSm1SS2o1aTUiLCJjaGFubmVsTmFtZSI6Ik15IENoYW5uZWwiLCJsaWNlbnNlU2VxdWVuY2UiOjcsImVuZHBvaW50IjoiaHR0cHM6Ly9yZXBsaWNhdGVkLmFwcCIsImVudGl0bGVtZW50cyI6eyJib29sX2ZpZWxkIjp7InRpdGxlIjoiQm9vbCBGaWVsZCIsInZhbHVlIjp0cnVlLCJ2YWx1ZVR5cGUiOiJCb29sZWFuIn0sImV4cGlyZXNfYXQiOnsidGl0bGUiOiJFeHBpcmF0aW9uIiwiZGVzY3JpcHRpb24iOiJMaWNlbnNlIEV4cGlyYXRpb24iLCJ2YWx1ZSI6IjIwMzAtMDctMjdUMDA6MDA6MDBaIiwidmFsdWVUeXBlIjoiU3RyaW5nIn0sImhpZGRlbl9maWVsZCI6eyJ0aXRsZSI6IkhpZGRlbiBGaWVsZCIsInZhbHVlIjoidGhpcyBpcyBzZWNyZXQiLCJ2YWx1ZVR5cGUiOiJTdHJpbmciLCJpc0hpZGRlbiI6dHJ1ZX0sImludF9maWVsZCI6eyJ0aXRsZSI6IkludCBGaWVsZCIsInZhbHVlIjoxMjMsInZhbHVlVHlwZSI6IkludGVnZXIifSwic3RyaW5nX2ZpZWxkIjp7InRpdGxlIjoiU3RyaW5nRmllbGQiLCJ2YWx1ZSI6InNpbmdsZSBsaW5lIHRleHQiLCJ2YWx1ZVR5cGUiOiJTdHJpbmcifSwidGV4dF9maWVsZCI6eyJ0aXRsZSI6IlRleHQgRmllbGQiLCJ2YWx1ZSI6Im11bHRpXG5saW5lXG50ZXh0IiwidmFsdWVUeXBlIjoiVGV4dCJ9fSwiaXNBaXJnYXBTdXBwb3J0ZWQiOnRydWUsImlzR2l0T3BzU3VwcG9ydGVkIjp0cnVlLCJpc1NuYXBzaG90U3VwcG9ydGVkIjp0cnVlfX0=","innerSignature":"eyJsaWNlbnNlU2lnbmF0dXJlIjoiaHgxMWMvTGZ3Q3hTNXFkQXBFSXFuTk1OM0pKa2s4VGdXRUZsT1JVRzR2cGV3dFhWV3lmejdYcHAwQ1k2YjdrQTRKczNIaGwwbFI0WTA1LzcvQUdCaDdVMHg3RHZMZ3QzU3M0bnFLVStXWEpSTzJYQUFvR0N1dTVGTFprQUhXcTRQQm1zaHV6cVlvcnpxelhFYVVVZERUdUxCMmg5aHgwWEhPRlpRMzludm9OR2ZOdy94SVdZdHRPdXdva2w2MVloRUxVeFd1SVRFc0NUa3lmMTMwOHk5RlRsZTJyV2dEeHFMa0RPSWUyOEl3S2RBL2IwVUIyTFFmTVpwVzl2Q3BJL2lyVzNnbjZyNVZ3V20vSWpybm43RzRkVjZuV3pTd0hPQ2Rua014MEt5UUNkL1B1ZXJTb3RuQ09tS013ZTRLbjhDd1NXUTQ4dTFDMm1iWUsxdXNZN3V3PT0iLCJwdWJsaWNLZXkiOiItLS0tLUJFR0lOIFBVQkxJQyBLRVktLS0tLVxuTUlJQklqQU5CZ2txaGtpRzl3MEJBUUVGQUFPQ0FROEFNSUlCQ2dLQ0FRRUFzNHJvUHp1aWRMeXN2b1Y2dzlaNFxuWGFib0NmY2MxaGdVaCswWUdKcE5DRUxrN0ZLQy92azdzdDlGNmcwT29kSERleXdRWkhKdU5MZlRsQlBGQ2NiNlxuNm9sTFNycFA4clU3SGxHblFER0RMaXdKQ2hkRDdUUGR3aWtpd0tFcm5jWjhGZjVlSnowdDNiTXZrT2ZUYnJBbFxuYkFCY0o5MVlUOXJuUW9qdUcxRWJQTjhFVnR6MlY4NHdubGd4MHBwbDV4OHZNbXppMHJublFUWUFjbzZqa2pIM1xuTnNUdXN1S1dvRFR5MXNrdkRROHlBYWJmY3M0N3ZsQk00SDFORE4vRHRaYlYvYnl2bkJ6bC8xVkVzTFdjZVVpTFxuRXF1OEdyaytQUDd2RGRwbER3cXZPWkxFdXk3djhnRm5SOVRURWprNUo5dnZUSGdmSnUzenlEOGlKY0RDNXpqOVxub1FJREFRQUJcbi0tLS0tRU5EIFBVQkxJQyBLRVktLS0tLVxuIiwia2V5U2lnbmF0dXJlIjoiZXlKemFXZHVZWFIxY21VaU9pSjBRWHB2WTNKVk56aFhSR2RsUTJocmNIWkVUVTlFWjBKWU1FRkZTRE5FU0hKbE1rTTNLMHBEVDNGeFNtNURUVTVVYm01bVpFRnlZWHB6ZERjMVZHaExPWEJUUkZrdkwwbzNZMFZJUmxWVEwyOUhWRWxsVkVOMFRHMVZRMGN3VGxGbFkzSnRTRms0VUZOa1ZVSjBUMVl3Ymt0cFRrVnBjbkJhTVc5amJWbHFZa3hoU2xsVWJFRkVXbUZvVjFKUFdqbFJhWEZuWldoQ2FuQjNSR3MwYVZJNU5WVldWVTVyT0hKb1lVTXlhbTg0V0daeFlqVlZibXhxZEZFd055czBhVlJJVEZONmVFMHplVXRvTUZGVmEwVTRRVzlHUlhKUE1YRlBSMVpRU1RCNllWaHpWVXBtY0RSbE1UQk9OV3RSVnpWT1NWY3ZSVXRFU0hsbU9VbFhkM1IwY1VsYWNXRjBSa05EYUZkcmJ6VkRSM0JYTDI1Rk1YYzJlV3RJVVhBMlUxSlJiSFpwUkUwMFZEUktUMkZsUVd0c1RWUk1UVWNyWTBaTGIzZE9TVm95YkhORGRsTnZRakZaZVdOTlNVSmxabEpuZWtSdU0xRTlQU0lzSW1kc2IySmhiRXRsZVVsa0lqb2lZbVJsWlRVMk5UWXdZMlppTkROak9XSXlPR0ptT1RobFlXTmhabUUyTkRZaWZRPT0ifQ=="}' + licenseFieldValueAppSlug: my-app + licenseFieldValueChannelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + licenseFieldValueChannelName: My Channel + licenseFieldValueCustomerName: Test Customer + licenseFieldValueEndpoint: https://replicated.app + licenseFieldValueLicenseID: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseFieldValueLicenseId: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseFieldValueCustomIntField: 123 + licenseFieldValueCustomStringField: single line text + licenseFieldValueCustomTextField: "multi\nline\ntext" + licenseFieldValueCustomBoolField: "true" + licenseFieldValueCustomHiddenField: "this is secret" diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/config.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/config.yaml new file mode 100644 index 0000000000..af995cc7f7 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/config.yaml @@ -0,0 +1,19 @@ +apiVersion: kots.io/v1beta1 +kind: Config +metadata: + creationTimestamp: null + name: my-app +spec: + groups: + - items: + - default: "" + help_text: | + Use this field to provide a hostname for your Example Application installation. + name: hostname + required: true + title: Hostname + type: text + value: my-app.somebigbank.com + name: setup + title: Setup +status: {} diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/userdata/config.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/userdata/config.yaml new file mode 100644 index 0000000000..4b2800d1ad --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/userdata/config.yaml @@ -0,0 +1,10 @@ +apiVersion: kots.io/v1beta1 +kind: ConfigValues +metadata: + creationTimestamp: null + name: replicated-kots-app +spec: + values: + hostname: + value: my-app.somebigbank.com +status: {} diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/userdata/installation.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/userdata/installation.yaml new file mode 100644 index 0000000000..b0c5471181 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/userdata/installation.yaml @@ -0,0 +1,9 @@ +apiVersion: kots.io/v1beta1 +kind: Installation +metadata: + creationTimestamp: null + name: replicated-kots-app +spec: + channelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + channelName: My Channel +status: {} diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/userdata/license.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/userdata/license.yaml new file mode 100644 index 0000000000..daa549c24c --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/kotsKinds/userdata/license.yaml @@ -0,0 +1,50 @@ +apiVersion: kots.io/v1beta1 +kind: License +metadata: + creationTimestamp: null + name: testcustomer +spec: + appSlug: my-app + channelID: old-1vusIYZLAVxMG6q760OJmRKj5i5 + channelName: My Old Channel + customerName: Test Customer + endpoint: https://replicated.app + entitlements: + bool_field: + title: Bool Field + value: false + valueType: Boolean + expires_at: + description: License Expiration + title: Expiration + value: "2029-07-27T00:00:00Z" + valueType: String + hidden_field: + isHidden: true + title: Hidden Field + value: this is an old secret + valueType: String + int_field: + title: Int Field + value: 12 + valueType: Integer + string_field: + title: StringField + value: old single line text + valueType: String + text_field: + title: Text Field + value: |- + old + multi + line + text + valueType: Text + isAirgapSupported: false + isGitOpsSupported: false + isSnapshotSupported: false + licenseID: old-1vusOokxAVp1tkRGuyxnF23PJcq + licenseSequence: 6 + licenseType: dev + signature: eyJsaWNlbnNlRGF0YSI6ImV5SmhjR2xXWlhKemFXOXVJam9pYTI5MGN5NXBieTkyTVdKbGRHRXhJaXdpYTJsdVpDSTZJa3hwWTJWdWMyVWlMQ0p0WlhSaFpHRjBZU0k2ZXlKdVlXMWxJam9pZEdWemRHTjFjM1J2YldWeUluMHNJbk53WldNaU9uc2liR2xqWlc1elpVbEVJam9pTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54SWl3aWJHbGpaVzV6WlZSNWNHVWlPaUp3Y205a0lpd2lZM1Z6ZEc5dFpYSk9ZVzFsSWpvaVZHVnpkQ0JEZFhOMGIyMWxjaUlzSW1Gd2NGTnNkV2NpT2lKdGVTMWhjSEFpTENKamFHRnVibVZzU1VRaU9pSXhkblZ6U1ZsYVRFRldlRTFITm5FM05qQlBTbTFTUzJvMWFUVWlMQ0pqYUdGdWJtVnNUbUZ0WlNJNklrMTVJRU5vWVc1dVpXd2lMQ0pzYVdObGJuTmxVMlZ4ZFdWdVkyVWlPamNzSW1WdVpIQnZhVzUwSWpvaWFIUjBjSE02THk5eVpYQnNhV05oZEdWa0xtRndjQ0lzSW1WdWRHbDBiR1Z0Wlc1MGN5STZleUppYjI5c1gyWnBaV3hrSWpwN0luUnBkR3hsSWpvaVFtOXZiQ0JHYVdWc1pDSXNJblpoYkhWbElqcDBjblZsTENKMllXeDFaVlI1Y0dVaU9pSkNiMjlzWldGdUluMHNJbVY0Y0dseVpYTmZZWFFpT25zaWRHbDBiR1VpT2lKRmVIQnBjbUYwYVc5dUlpd2laR1Z6WTNKcGNIUnBiMjRpT2lKTWFXTmxibk5sSUVWNGNHbHlZWFJwYjI0aUxDSjJZV3gxWlNJNklqSXdNekF0TURjdE1qZFVNREE2TURBNk1EQmFJaXdpZG1Gc2RXVlVlWEJsSWpvaVUzUnlhVzVuSW4wc0ltaHBaR1JsYmw5bWFXVnNaQ0k2ZXlKMGFYUnNaU0k2SWtocFpHUmxiaUJHYVdWc1pDSXNJblpoYkhWbElqb2lkR2hwY3lCcGN5QnpaV055WlhRaUxDSjJZV3gxWlZSNWNHVWlPaUpUZEhKcGJtY2lMQ0pwYzBocFpHUmxiaUk2ZEhKMVpYMHNJbWx1ZEY5bWFXVnNaQ0k2ZXlKMGFYUnNaU0k2SWtsdWRDQkdhV1ZzWkNJc0luWmhiSFZsSWpveE1qTXNJblpoYkhWbFZIbHdaU0k2SWtsdWRHVm5aWElpZlN3aWMzUnlhVzVuWDJacFpXeGtJanA3SW5ScGRHeGxJam9pVTNSeWFXNW5SbWxsYkdRaUxDSjJZV3gxWlNJNkluTnBibWRzWlNCc2FXNWxJSFJsZUhRaUxDSjJZV3gxWlZSNWNHVWlPaUpUZEhKcGJtY2lmU3dpZEdWNGRGOW1hV1ZzWkNJNmV5SjBhWFJzWlNJNklsUmxlSFFnUm1sbGJHUWlMQ0oyWVd4MVpTSTZJbTExYkhScFhHNXNhVzVsWEc1MFpYaDBJaXdpZG1Gc2RXVlVlWEJsSWpvaVZHVjRkQ0o5ZlN3aWFYTkJhWEpuWVhCVGRYQndiM0owWldRaU9uUnlkV1VzSW1selIybDBUM0J6VTNWd2NHOXlkR1ZrSWpwMGNuVmxMQ0pwYzFOdVlYQnphRzkwVTNWd2NHOXlkR1ZrSWpwMGNuVmxmWDA9IiwiaW5uZXJTaWduYXR1cmUiOiJleUpzYVdObGJuTmxVMmxuYm1GMGRYSmxJam9pYUhneE1XTXZUR1ozUTNoVE5YRmtRWEJGU1hGdVRrMU9NMHBLYTJzNFZHZFhSVVpzVDFKVlJ6UjJjR1YzZEZoV1YzbG1lamRZY0hBd1ExazJZamRyUVRSS2N6TklhR3d3YkZJMFdUQTFMemN2UVVkQ2FEZFZNSGczUkhaTVozUXpVM00wYm5GTFZTdFhXRXBTVHpKWVFVRnZSME4xZFRWR1RGcHJRVWhYY1RSUVFtMXphSFY2Y1ZsdmNucHhlbGhGWVZWVlpFUlVkVXhDTW1nNWFIZ3dXRWhQUmxwUk16bHVkbTlPUjJaT2R5OTRTVmRaZEhSUGRYZHZhMncyTVZsb1JVeFZlRmQxU1ZSRmMwTlVhM2xtTVRNd09IazVSbFJzWlRKeVYyZEVlSEZNYTBSUFNXVXlPRWwzUzJSQkwySXdWVUl5VEZGbVRWcHdWemwyUTNCSkwybHlWek5uYmpaeU5WWjNWMjB2U1dweWJtNDNSelJrVmpadVYzcFRkMGhQUTJSdWEwMTRNRXQ1VVVOa0wxQjFaWEpUYjNSdVEwOXRTMDEzWlRSTGJqaERkMU5YVVRRNGRURkRNbTFpV1VzeGRYTlpOM1YzUFQwaUxDSndkV0pzYVdOTFpYa2lPaUl0TFMwdExVSkZSMGxPSUZCVlFreEpReUJMUlZrdExTMHRMVnh1VFVsSlFrbHFRVTVDWjJ0eGFHdHBSemwzTUVKQlVVVkdRVUZQUTBGUk9FRk5TVWxDUTJkTFEwRlJSVUZ6TkhKdlVIcDFhV1JNZVhOMmIxWTJkemxhTkZ4dVdHRmliME5tWTJNeGFHZFZhQ3N3V1VkS2NFNURSVXhyTjBaTFF5OTJhemR6ZERsR05tY3dUMjlrU0VSbGVYZFJXa2hLZFU1TVpsUnNRbEJHUTJOaU5seHVObTlzVEZOeWNGQTRjbFUzU0d4SGJsRkVSMFJNYVhkS1EyaGtSRGRVVUdSM2FXdHBkMHRGY201aldqaEdaalZsU25vd2RETmlUWFpyVDJaVVluSkJiRnh1WWtGQ1kwbzVNVmxVT1hKdVVXOXFkVWN4UldKUVRqaEZWblI2TWxZNE5IZHViR2Q0TUhCd2JEVjRPSFpOYlhwcE1ISnVibEZVV1VGamJ6WnFhMnBJTTF4dVRuTlVkWE4xUzFkdlJGUjVNWE5yZGtSUk9IbEJZV0ptWTNNME4zWnNRazAwU0RGT1JFNHZSSFJhWWxZdllubDJia0o2YkM4eFZrVnpURmRqWlZWcFRGeHVSWEYxT0VkeWF5dFFVRGQyUkdSd2JFUjNjWFpQV2t4RmRYazNkamhuUm01U09WUlVSV3ByTlVvNWRuWlVTR2RtU25VemVubEVPR2xLWTBSRE5YcHFPVnh1YjFGSlJFRlJRVUpjYmkwdExTMHRSVTVFSUZCVlFreEpReUJMUlZrdExTMHRMVnh1SWl3aWEyVjVVMmxuYm1GMGRYSmxJam9pWlhsS2VtRlhaSFZaV0ZJeFkyMVZhVTlwU2pCUldIQjJXVE5LVms1NmFGaFNSMlJzVVRKb2NtTklXa1ZVVlRsRldqQktXVTFGUmtaVFJFNUZVMGhLYkUxclRUTkxNSEJFVkROR2VGTnROVVJVVlRWVlltMDFiVnBGUm5sWldIQjZaRVJqTVZaSGFFeFBXRUpVVWtacmRrd3diek5aTUZaSlVteFdWRXd5T1VoV1JXeHNWa1ZPTUZSSE1WWlJNR04zVkd4R2JGa3pTblJUUm1zMFZVWk9hMVpWU2pCVU1WbDNZbXQwY0ZSclZuQmpia0poVFZjNWFtSldiSEZaYTNob1UyeHNWV0pGUmtWWGJVWnZWakZLVUZkcWJGSmhXRVp1V2xkb1EyRnVRak5TUjNNd1lWWkpOVTVXVmxkV1ZUVnlUMGhLYjFsVlRYbGhiVGcwVjBkYWVGbHFWbFppYlhoeFpFWkZkMDU1Y3pCaFZsSkpWRVpPTm1WRk1IcGxWWFJ2VFVaR1ZtRXdWVFJSVnpsSFVsaEtVRTFZUmxCU01WcFJVMVJDTmxsV2FIcFdWWEJ0WTBSU2JFMVVRazlPVjNSU1ZucFdUMU5XWTNaU1ZYUkZVMGhzYlU5VmJGaGtNMUl3WTFWc1lXTlhSakJTYTA1RVlVWmtjbUo2VmtSU00wSllUREkxUmsxWVl6SmxWM1JKVlZoQk1sVXhTbEppU0Zwd1VrVXdNRlpFVWt0VU1rWnNVVmQwYzFSV1VrMVVWV055V1RCYVRHSXpaRTlUVm05NVlraE9SR1JzVG5aUmFrWmFaVmRPVGxOVlNteGFiRXB1Wld0U2RVMHhSVGxRVTBselNXMWtjMkl5U21oaVJYUnNaVlZzYTBscWIybFpiVkpzV2xSVk1rNVVXWGRaTWxwcFRrUk9hazlYU1hsUFIwcHRUMVJvYkZsWFRtaGFiVVV5VGtSWmFXWlJQVDBpZlE9PSJ9 +status: {} diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/overlays/downstreams/this-cluster/kustomization.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/overlays/downstreams/this-cluster/kustomization.yaml new file mode 100644 index 0000000000..73a609d8fa --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/overlays/downstreams/this-cluster/kustomization.yaml @@ -0,0 +1,4 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +bases: +- ../../midstream +kind: Kustomization diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/overlays/midstream/backup-label-transformer.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/overlays/midstream/backup-label-transformer.yaml new file mode 100644 index 0000000000..c3acc6c5b9 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/overlays/midstream/backup-label-transformer.yaml @@ -0,0 +1,39 @@ +apiVersion: builtin +kind: LabelTransformer +metadata: + name: backup-label-transformer +labels: + kots.io/app-slug: my-app + kots.io/backup: velero +fieldSpecs: +- path: metadata/labels + create: true +- version: v1 + kind: ReplicationController + path: spec/template/metadata/labels + create: true +- kind: Deployment + path: spec/template/metadata/labels + create: true +- kind: ReplicaSet + path: spec/template/metadata/labels + create: true +- kind: DaemonSet + path: spec/template/metadata/labels + create: true +- group: apps + kind: StatefulSet + path: spec/template/metadata/labels + create: true +- group: batch + kind: Job + path: spec/template/metadata/labels + create: true +- group: batch + kind: CronJob + path: spec/jobTemplate/metadata/labels + create: true +- group: batch + kind: CronJob + path: spec/jobTemplate/spec/template/metadata/labels + create: true diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/overlays/midstream/kustomization.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/overlays/midstream/kustomization.yaml new file mode 100644 index 0000000000..bb6f5b2615 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/overlays/midstream/kustomization.yaml @@ -0,0 +1,10 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +bases: +- ../../base +commonAnnotations: + kots.io/app-slug: my-app +kind: Kustomization +resources: +- secret.yaml +transformers: +- backup-label-transformer.yaml diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/overlays/midstream/secret.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/overlays/midstream/secret.yaml new file mode 100644 index 0000000000..4d81bc057f --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/overlays/midstream/secret.yaml @@ -0,0 +1,28 @@ +apiVersion: v1 +data: + .dockerconfigjson: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= +kind: Secret +metadata: + annotations: + helm.sh/hook: pre-install,pre-upgrade + helm.sh/hook-weight: "-9999" + kots.io/creation-phase: "-9999" + creationTimestamp: null + name: my-app-registry + namespace: app-namespace +type: kubernetes.io/dockerconfigjson + +--- +apiVersion: v1 +data: + .dockerconfigjson: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= +kind: Secret +metadata: + annotations: + helm.sh/hook: pre-install,pre-upgrade + helm.sh/hook-weight: "-9999" + kots.io/creation-phase: "-9999" + creationTimestamp: null + name: kotsadm-replicated-registry + namespace: app-namespace +type: kubernetes.io/dockerconfigjson diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/rendered/this-cluster/kotsadm-replicated-registry-secret.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/rendered/this-cluster/kotsadm-replicated-registry-secret.yaml new file mode 100644 index 0000000000..6f52289831 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/rendered/this-cluster/kotsadm-replicated-registry-secret.yaml @@ -0,0 +1,17 @@ +apiVersion: v1 +data: + .dockerconfigjson: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= +kind: Secret +metadata: + annotations: + helm.sh/hook: pre-install,pre-upgrade + helm.sh/hook-weight: "-9999" + kots.io/app-slug: my-app + kots.io/creation-phase: "-9999" + creationTimestamp: null + labels: + kots.io/app-slug: my-app + kots.io/backup: velero + name: kotsadm-replicated-registry + namespace: app-namespace +type: kubernetes.io/dockerconfigjson \ No newline at end of file diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/rendered/this-cluster/my-app-registry-secret.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/rendered/this-cluster/my-app-registry-secret.yaml new file mode 100644 index 0000000000..a8b369b451 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/rendered/this-cluster/my-app-registry-secret.yaml @@ -0,0 +1,17 @@ +apiVersion: v1 +data: + .dockerconfigjson: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= +kind: Secret +metadata: + annotations: + helm.sh/hook: pre-install,pre-upgrade + helm.sh/hook-weight: "-9999" + kots.io/app-slug: my-app + kots.io/creation-phase: "-9999" + creationTimestamp: null + labels: + kots.io/app-slug: my-app + kots.io/backup: velero + name: my-app-registry + namespace: app-namespace +type: kubernetes.io/dockerconfigjson diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/rendered/this-cluster/test-licenseinfo-configmap.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/rendered/this-cluster/test-licenseinfo-configmap.yaml new file mode 100644 index 0000000000..db9a488146 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/rendered/this-cluster/test-licenseinfo-configmap.yaml @@ -0,0 +1,33 @@ +apiVersion: v1 +data: + dockerCfg: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= + licenseFieldValueAppSlug: my-app + licenseFieldValueChannelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + licenseFieldValueChannelName: My Channel + licenseFieldValueCustomBoolField: "true" + licenseFieldValueCustomHiddenField: this is secret + licenseFieldValueCustomIntField: 123 + licenseFieldValueCustomStringField: single line text + licenseFieldValueCustomTextField: |- + multi + line + text + licenseFieldValueCustomerName: Test Customer + licenseFieldValueEndpoint: https://replicated.app + licenseFieldValueIsAirgapSupported: true + licenseFieldValueIsGeoaxisSupported: false + licenseFieldValueIsGitOpsSupported: true + licenseFieldValueIsIdentityServiceSupported: false + licenseFieldValueLicenseID: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseFieldValueLicenseId: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseFieldValueLicenseSequence: 7 + licenseFieldValueLicenseType: prod + licenseFieldValueSignature: '{"licenseData":"eyJhcGlWZXJzaW9uIjoia290cy5pby92MWJldGExIiwia2luZCI6IkxpY2Vuc2UiLCJtZXRhZGF0YSI6eyJuYW1lIjoidGVzdGN1c3RvbWVyIn0sInNwZWMiOnsibGljZW5zZUlEIjoiMXZ1c09va3hBVnAxdGtSR3V5eG5GMjNQSmNxIiwibGljZW5zZVR5cGUiOiJwcm9kIiwiY3VzdG9tZXJOYW1lIjoiVGVzdCBDdXN0b21lciIsImFwcFNsdWciOiJteS1hcHAiLCJjaGFubmVsSUQiOiIxdnVzSVlaTEFWeE1HNnE3NjBPSm1SS2o1aTUiLCJjaGFubmVsTmFtZSI6Ik15IENoYW5uZWwiLCJsaWNlbnNlU2VxdWVuY2UiOjcsImVuZHBvaW50IjoiaHR0cHM6Ly9yZXBsaWNhdGVkLmFwcCIsImVudGl0bGVtZW50cyI6eyJib29sX2ZpZWxkIjp7InRpdGxlIjoiQm9vbCBGaWVsZCIsInZhbHVlIjp0cnVlLCJ2YWx1ZVR5cGUiOiJCb29sZWFuIn0sImV4cGlyZXNfYXQiOnsidGl0bGUiOiJFeHBpcmF0aW9uIiwiZGVzY3JpcHRpb24iOiJMaWNlbnNlIEV4cGlyYXRpb24iLCJ2YWx1ZSI6IjIwMzAtMDctMjdUMDA6MDA6MDBaIiwidmFsdWVUeXBlIjoiU3RyaW5nIn0sImhpZGRlbl9maWVsZCI6eyJ0aXRsZSI6IkhpZGRlbiBGaWVsZCIsInZhbHVlIjoidGhpcyBpcyBzZWNyZXQiLCJ2YWx1ZVR5cGUiOiJTdHJpbmciLCJpc0hpZGRlbiI6dHJ1ZX0sImludF9maWVsZCI6eyJ0aXRsZSI6IkludCBGaWVsZCIsInZhbHVlIjoxMjMsInZhbHVlVHlwZSI6IkludGVnZXIifSwic3RyaW5nX2ZpZWxkIjp7InRpdGxlIjoiU3RyaW5nRmllbGQiLCJ2YWx1ZSI6InNpbmdsZSBsaW5lIHRleHQiLCJ2YWx1ZVR5cGUiOiJTdHJpbmcifSwidGV4dF9maWVsZCI6eyJ0aXRsZSI6IlRleHQgRmllbGQiLCJ2YWx1ZSI6Im11bHRpXG5saW5lXG50ZXh0IiwidmFsdWVUeXBlIjoiVGV4dCJ9fSwiaXNBaXJnYXBTdXBwb3J0ZWQiOnRydWUsImlzR2l0T3BzU3VwcG9ydGVkIjp0cnVlLCJpc1NuYXBzaG90U3VwcG9ydGVkIjp0cnVlfX0=","innerSignature":"eyJsaWNlbnNlU2lnbmF0dXJlIjoiaHgxMWMvTGZ3Q3hTNXFkQXBFSXFuTk1OM0pKa2s4VGdXRUZsT1JVRzR2cGV3dFhWV3lmejdYcHAwQ1k2YjdrQTRKczNIaGwwbFI0WTA1LzcvQUdCaDdVMHg3RHZMZ3QzU3M0bnFLVStXWEpSTzJYQUFvR0N1dTVGTFprQUhXcTRQQm1zaHV6cVlvcnpxelhFYVVVZERUdUxCMmg5aHgwWEhPRlpRMzludm9OR2ZOdy94SVdZdHRPdXdva2w2MVloRUxVeFd1SVRFc0NUa3lmMTMwOHk5RlRsZTJyV2dEeHFMa0RPSWUyOEl3S2RBL2IwVUIyTFFmTVpwVzl2Q3BJL2lyVzNnbjZyNVZ3V20vSWpybm43RzRkVjZuV3pTd0hPQ2Rua014MEt5UUNkL1B1ZXJTb3RuQ09tS013ZTRLbjhDd1NXUTQ4dTFDMm1iWUsxdXNZN3V3PT0iLCJwdWJsaWNLZXkiOiItLS0tLUJFR0lOIFBVQkxJQyBLRVktLS0tLVxuTUlJQklqQU5CZ2txaGtpRzl3MEJBUUVGQUFPQ0FROEFNSUlCQ2dLQ0FRRUFzNHJvUHp1aWRMeXN2b1Y2dzlaNFxuWGFib0NmY2MxaGdVaCswWUdKcE5DRUxrN0ZLQy92azdzdDlGNmcwT29kSERleXdRWkhKdU5MZlRsQlBGQ2NiNlxuNm9sTFNycFA4clU3SGxHblFER0RMaXdKQ2hkRDdUUGR3aWtpd0tFcm5jWjhGZjVlSnowdDNiTXZrT2ZUYnJBbFxuYkFCY0o5MVlUOXJuUW9qdUcxRWJQTjhFVnR6MlY4NHdubGd4MHBwbDV4OHZNbXppMHJublFUWUFjbzZqa2pIM1xuTnNUdXN1S1dvRFR5MXNrdkRROHlBYWJmY3M0N3ZsQk00SDFORE4vRHRaYlYvYnl2bkJ6bC8xVkVzTFdjZVVpTFxuRXF1OEdyaytQUDd2RGRwbER3cXZPWkxFdXk3djhnRm5SOVRURWprNUo5dnZUSGdmSnUzenlEOGlKY0RDNXpqOVxub1FJREFRQUJcbi0tLS0tRU5EIFBVQkxJQyBLRVktLS0tLVxuIiwia2V5U2lnbmF0dXJlIjoiZXlKemFXZHVZWFIxY21VaU9pSjBRWHB2WTNKVk56aFhSR2RsUTJocmNIWkVUVTlFWjBKWU1FRkZTRE5FU0hKbE1rTTNLMHBEVDNGeFNtNURUVTVVYm01bVpFRnlZWHB6ZERjMVZHaExPWEJUUkZrdkwwbzNZMFZJUmxWVEwyOUhWRWxsVkVOMFRHMVZRMGN3VGxGbFkzSnRTRms0VUZOa1ZVSjBUMVl3Ymt0cFRrVnBjbkJhTVc5amJWbHFZa3hoU2xsVWJFRkVXbUZvVjFKUFdqbFJhWEZuWldoQ2FuQjNSR3MwYVZJNU5WVldWVTVyT0hKb1lVTXlhbTg0V0daeFlqVlZibXhxZEZFd055czBhVlJJVEZONmVFMHplVXRvTUZGVmEwVTRRVzlHUlhKUE1YRlBSMVpRU1RCNllWaHpWVXBtY0RSbE1UQk9OV3RSVnpWT1NWY3ZSVXRFU0hsbU9VbFhkM1IwY1VsYWNXRjBSa05EYUZkcmJ6VkRSM0JYTDI1Rk1YYzJlV3RJVVhBMlUxSlJiSFpwUkUwMFZEUktUMkZsUVd0c1RWUk1UVWNyWTBaTGIzZE9TVm95YkhORGRsTnZRakZaZVdOTlNVSmxabEpuZWtSdU0xRTlQU0lzSW1kc2IySmhiRXRsZVVsa0lqb2lZbVJsWlRVMk5UWXdZMlppTkROak9XSXlPR0ptT1RobFlXTmhabUUyTkRZaWZRPT0ifQ=="}' +kind: ConfigMap +metadata: + annotations: + kots.io/app-slug: my-app + labels: + kots.io/app-slug: my-app + kots.io/backup: velero + name: test-licenseinfo \ No newline at end of file diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/upstream/config.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/config.yaml new file mode 100644 index 0000000000..aff6c18cbf --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/config.yaml @@ -0,0 +1,15 @@ +apiVersion: kots.io/v1beta1 +kind: Config +metadata: + name: my-app +spec: + groups: + - name: setup + title: Setup + items: + - name: hostname + type: text + title: Hostname + help_text: | + Use this field to provide a hostname for your Example Application installation. + required: true diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/upstream/subdir/configmap.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/subdir/configmap.yaml new file mode 100644 index 0000000000..73843036cb --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/subdir/configmap.yaml @@ -0,0 +1,25 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + name: test-licenseinfo +data: + dockerCfg: {{repl LicenseDockerCfg }} + licenseFieldValueIsGitOpsSupported: {{repl LicenseFieldValue "isGitOpsSupported" }} + licenseFieldValueIsIdentityServiceSupported: {{repl LicenseFieldValue "isIdentityServiceSupported" }} + licenseFieldValueIsGeoaxisSupported: {{repl LicenseFieldValue "isGeoaxisSupported" }} + licenseFieldValueIsAirgapSupported: {{repl LicenseFieldValue "isAirgapSupported" }} + licenseFieldValueLicenseType: {{repl LicenseFieldValue "licenseType" }} + licenseFieldValueLicenseSequence: {{repl LicenseFieldValue "licenseSequence" }} + licenseFieldValueSignature: '{{repl LicenseFieldValue "signature" }}' + licenseFieldValueAppSlug: {{repl LicenseFieldValue "appSlug" }} + licenseFieldValueChannelID: {{repl LicenseFieldValue "channelID" }} + licenseFieldValueChannelName: {{repl LicenseFieldValue "channelName" }} + licenseFieldValueCustomerName: {{repl LicenseFieldValue "customerName" }} + licenseFieldValueEndpoint: {{repl LicenseFieldValue "endpoint" }} + licenseFieldValueLicenseID: {{repl LicenseFieldValue "licenseID" }} + licenseFieldValueLicenseId: {{repl LicenseFieldValue "licenseId" }} + licenseFieldValueCustomIntField: {{repl LicenseFieldValue "int_field" }} + licenseFieldValueCustomStringField: {{repl LicenseFieldValue "string_field" }} + licenseFieldValueCustomTextField: "{{repl LicenseFieldValue "text_field" | replace "\n" "\\n" }}" + licenseFieldValueCustomBoolField: "{{repl LicenseFieldValue "bool_field" }}" + licenseFieldValueCustomHiddenField: "{{repl LicenseFieldValue "hidden_field" }}" diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/upstream/userdata/config.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/userdata/config.yaml new file mode 100644 index 0000000000..4b2800d1ad --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/userdata/config.yaml @@ -0,0 +1,10 @@ +apiVersion: kots.io/v1beta1 +kind: ConfigValues +metadata: + creationTimestamp: null + name: replicated-kots-app +spec: + values: + hostname: + value: my-app.somebigbank.com +status: {} diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/upstream/userdata/installation.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/userdata/installation.yaml new file mode 100644 index 0000000000..b0c5471181 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/userdata/installation.yaml @@ -0,0 +1,9 @@ +apiVersion: kots.io/v1beta1 +kind: Installation +metadata: + creationTimestamp: null + name: replicated-kots-app +spec: + channelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + channelName: My Channel +status: {} diff --git a/pkg/tests/renderdir/cases/simple/archiveDir/upstream/userdata/license.yaml b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/userdata/license.yaml new file mode 100644 index 0000000000..9fa3a14d7f --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/archiveDir/upstream/userdata/license.yaml @@ -0,0 +1,49 @@ +apiVersion: kots.io/v1beta1 +kind: License +metadata: + creationTimestamp: null + name: testcustomer +spec: + appSlug: my-app + channelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + channelName: My Channel + customerName: Test Customer + endpoint: https://replicated.app + entitlements: + bool_field: + title: Bool Field + value: true + valueType: Boolean + expires_at: + description: License Expiration + title: Expiration + value: "2030-07-27T00:00:00Z" + valueType: String + hidden_field: + isHidden: true + title: Hidden Field + value: this is secret + valueType: String + int_field: + title: Int Field + value: 123 + valueType: Integer + string_field: + title: StringField + value: single line text + valueType: String + text_field: + title: Text Field + value: |- + multi + line + text + valueType: Text + isAirgapSupported: true + isGitOpsSupported: true + isSnapshotSupported: true + licenseID: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseSequence: 7 + licenseType: prod + signature: eyJsaWNlbnNlRGF0YSI6ImV5SmhjR2xXWlhKemFXOXVJam9pYTI5MGN5NXBieTkyTVdKbGRHRXhJaXdpYTJsdVpDSTZJa3hwWTJWdWMyVWlMQ0p0WlhSaFpHRjBZU0k2ZXlKdVlXMWxJam9pZEdWemRHTjFjM1J2YldWeUluMHNJbk53WldNaU9uc2liR2xqWlc1elpVbEVJam9pTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54SWl3aWJHbGpaVzV6WlZSNWNHVWlPaUp3Y205a0lpd2lZM1Z6ZEc5dFpYSk9ZVzFsSWpvaVZHVnpkQ0JEZFhOMGIyMWxjaUlzSW1Gd2NGTnNkV2NpT2lKdGVTMWhjSEFpTENKamFHRnVibVZzU1VRaU9pSXhkblZ6U1ZsYVRFRldlRTFITm5FM05qQlBTbTFTUzJvMWFUVWlMQ0pqYUdGdWJtVnNUbUZ0WlNJNklrMTVJRU5vWVc1dVpXd2lMQ0pzYVdObGJuTmxVMlZ4ZFdWdVkyVWlPamNzSW1WdVpIQnZhVzUwSWpvaWFIUjBjSE02THk5eVpYQnNhV05oZEdWa0xtRndjQ0lzSW1WdWRHbDBiR1Z0Wlc1MGN5STZleUppYjI5c1gyWnBaV3hrSWpwN0luUnBkR3hsSWpvaVFtOXZiQ0JHYVdWc1pDSXNJblpoYkhWbElqcDBjblZsTENKMllXeDFaVlI1Y0dVaU9pSkNiMjlzWldGdUluMHNJbVY0Y0dseVpYTmZZWFFpT25zaWRHbDBiR1VpT2lKRmVIQnBjbUYwYVc5dUlpd2laR1Z6WTNKcGNIUnBiMjRpT2lKTWFXTmxibk5sSUVWNGNHbHlZWFJwYjI0aUxDSjJZV3gxWlNJNklqSXdNekF0TURjdE1qZFVNREE2TURBNk1EQmFJaXdpZG1Gc2RXVlVlWEJsSWpvaVUzUnlhVzVuSW4wc0ltaHBaR1JsYmw5bWFXVnNaQ0k2ZXlKMGFYUnNaU0k2SWtocFpHUmxiaUJHYVdWc1pDSXNJblpoYkhWbElqb2lkR2hwY3lCcGN5QnpaV055WlhRaUxDSjJZV3gxWlZSNWNHVWlPaUpUZEhKcGJtY2lMQ0pwYzBocFpHUmxiaUk2ZEhKMVpYMHNJbWx1ZEY5bWFXVnNaQ0k2ZXlKMGFYUnNaU0k2SWtsdWRDQkdhV1ZzWkNJc0luWmhiSFZsSWpveE1qTXNJblpoYkhWbFZIbHdaU0k2SWtsdWRHVm5aWElpZlN3aWMzUnlhVzVuWDJacFpXeGtJanA3SW5ScGRHeGxJam9pVTNSeWFXNW5SbWxsYkdRaUxDSjJZV3gxWlNJNkluTnBibWRzWlNCc2FXNWxJSFJsZUhRaUxDSjJZV3gxWlZSNWNHVWlPaUpUZEhKcGJtY2lmU3dpZEdWNGRGOW1hV1ZzWkNJNmV5SjBhWFJzWlNJNklsUmxlSFFnUm1sbGJHUWlMQ0oyWVd4MVpTSTZJbTExYkhScFhHNXNhVzVsWEc1MFpYaDBJaXdpZG1Gc2RXVlVlWEJsSWpvaVZHVjRkQ0o5ZlN3aWFYTkJhWEpuWVhCVGRYQndiM0owWldRaU9uUnlkV1VzSW1selIybDBUM0J6VTNWd2NHOXlkR1ZrSWpwMGNuVmxMQ0pwYzFOdVlYQnphRzkwVTNWd2NHOXlkR1ZrSWpwMGNuVmxmWDA9IiwiaW5uZXJTaWduYXR1cmUiOiJleUpzYVdObGJuTmxVMmxuYm1GMGRYSmxJam9pYUhneE1XTXZUR1ozUTNoVE5YRmtRWEJGU1hGdVRrMU9NMHBLYTJzNFZHZFhSVVpzVDFKVlJ6UjJjR1YzZEZoV1YzbG1lamRZY0hBd1ExazJZamRyUVRSS2N6TklhR3d3YkZJMFdUQTFMemN2UVVkQ2FEZFZNSGczUkhaTVozUXpVM00wYm5GTFZTdFhXRXBTVHpKWVFVRnZSME4xZFRWR1RGcHJRVWhYY1RSUVFtMXphSFY2Y1ZsdmNucHhlbGhGWVZWVlpFUlVkVXhDTW1nNWFIZ3dXRWhQUmxwUk16bHVkbTlPUjJaT2R5OTRTVmRaZEhSUGRYZHZhMncyTVZsb1JVeFZlRmQxU1ZSRmMwTlVhM2xtTVRNd09IazVSbFJzWlRKeVYyZEVlSEZNYTBSUFNXVXlPRWwzUzJSQkwySXdWVUl5VEZGbVRWcHdWemwyUTNCSkwybHlWek5uYmpaeU5WWjNWMjB2U1dweWJtNDNSelJrVmpadVYzcFRkMGhQUTJSdWEwMTRNRXQ1VVVOa0wxQjFaWEpUYjNSdVEwOXRTMDEzWlRSTGJqaERkMU5YVVRRNGRURkRNbTFpV1VzeGRYTlpOM1YzUFQwaUxDSndkV0pzYVdOTFpYa2lPaUl0TFMwdExVSkZSMGxPSUZCVlFreEpReUJMUlZrdExTMHRMVnh1VFVsSlFrbHFRVTVDWjJ0eGFHdHBSemwzTUVKQlVVVkdRVUZQUTBGUk9FRk5TVWxDUTJkTFEwRlJSVUZ6TkhKdlVIcDFhV1JNZVhOMmIxWTJkemxhTkZ4dVdHRmliME5tWTJNeGFHZFZhQ3N3V1VkS2NFNURSVXhyTjBaTFF5OTJhemR6ZERsR05tY3dUMjlrU0VSbGVYZFJXa2hLZFU1TVpsUnNRbEJHUTJOaU5seHVObTlzVEZOeWNGQTRjbFUzU0d4SGJsRkVSMFJNYVhkS1EyaGtSRGRVVUdSM2FXdHBkMHRGY201aldqaEdaalZsU25vd2RETmlUWFpyVDJaVVluSkJiRnh1WWtGQ1kwbzVNVmxVT1hKdVVXOXFkVWN4UldKUVRqaEZWblI2TWxZNE5IZHViR2Q0TUhCd2JEVjRPSFpOYlhwcE1ISnVibEZVV1VGamJ6WnFhMnBJTTF4dVRuTlVkWE4xUzFkdlJGUjVNWE5yZGtSUk9IbEJZV0ptWTNNME4zWnNRazAwU0RGT1JFNHZSSFJhWWxZdllubDJia0o2YkM4eFZrVnpURmRqWlZWcFRGeHVSWEYxT0VkeWF5dFFVRGQyUkdSd2JFUjNjWFpQV2t4RmRYazNkamhuUm01U09WUlVSV3ByTlVvNWRuWlVTR2RtU25VemVubEVPR2xLWTBSRE5YcHFPVnh1YjFGSlJFRlJRVUpjYmkwdExTMHRSVTVFSUZCVlFreEpReUJMUlZrdExTMHRMVnh1SWl3aWEyVjVVMmxuYm1GMGRYSmxJam9pWlhsS2VtRlhaSFZaV0ZJeFkyMVZhVTlwU2pCUldIQjJXVE5LVms1NmFGaFNSMlJzVVRKb2NtTklXa1ZVVlRsRldqQktXVTFGUmtaVFJFNUZVMGhLYkUxclRUTkxNSEJFVkROR2VGTnROVVJVVlRWVlltMDFiVnBGUm5sWldIQjZaRVJqTVZaSGFFeFBXRUpVVWtacmRrd3diek5aTUZaSlVteFdWRXd5T1VoV1JXeHNWa1ZPTUZSSE1WWlJNR04zVkd4R2JGa3pTblJUUm1zMFZVWk9hMVpWU2pCVU1WbDNZbXQwY0ZSclZuQmpia0poVFZjNWFtSldiSEZaYTNob1UyeHNWV0pGUmtWWGJVWnZWakZLVUZkcWJGSmhXRVp1V2xkb1EyRnVRak5TUjNNd1lWWkpOVTVXVmxkV1ZUVnlUMGhLYjFsVlRYbGhiVGcwVjBkYWVGbHFWbFppYlhoeFpFWkZkMDU1Y3pCaFZsSkpWRVpPTm1WRk1IcGxWWFJ2VFVaR1ZtRXdWVFJSVnpsSFVsaEtVRTFZUmxCU01WcFJVMVJDTmxsV2FIcFdWWEJ0WTBSU2JFMVVRazlPVjNSU1ZucFdUMU5XWTNaU1ZYUkZVMGhzYlU5VmJGaGtNMUl3WTFWc1lXTlhSakJTYTA1RVlVWmtjbUo2VmtSU00wSllUREkxUmsxWVl6SmxWM1JKVlZoQk1sVXhTbEppU0Zwd1VrVXdNRlpFVWt0VU1rWnNVVmQwYzFSV1VrMVVWV055V1RCYVRHSXpaRTlUVm05NVlraE9SR1JzVG5aUmFrWmFaVmRPVGxOVlNteGFiRXB1Wld0U2RVMHhSVGxRVTBselNXMWtjMkl5U21oaVJYUnNaVlZzYTBscWIybFpiVkpzV2xSVk1rNVVXWGRaTWxwcFRrUk9hazlYU1hsUFIwcHRUMVJvYkZsWFRtaGFiVVV5VGtSWmFXWlJQVDBpZlE9PSJ9 +status: {} diff --git a/pkg/tests/renderdir/cases/simple/testcase.yaml b/pkg/tests/renderdir/cases/simple/testcase.yaml new file mode 100644 index 0000000000..e84298ca5a --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/testcase.yaml @@ -0,0 +1,9 @@ +Name: test simple renderdir +RenderDirOptions: + ArchiveDir: cases/simple/archiveDir + App: + ID: app-id + Slug: my-app + Downstreams: + - Name: this-cluster + Sequence: 1 \ No newline at end of file diff --git a/pkg/tests/renderdir/cases/simple/wantResults/base/kustomization.yaml b/pkg/tests/renderdir/cases/simple/wantResults/base/kustomization.yaml new file mode 100644 index 0000000000..b746efdcde --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/base/kustomization.yaml @@ -0,0 +1,7 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization +metadata: + annotations: + kots.io/kustomization: base +resources: +- subdir/configmap.yaml diff --git a/pkg/tests/renderdir/cases/simple/wantResults/base/subdir/configmap.yaml b/pkg/tests/renderdir/cases/simple/wantResults/base/subdir/configmap.yaml new file mode 100644 index 0000000000..cb312455ad --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/base/subdir/configmap.yaml @@ -0,0 +1,25 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + name: test-licenseinfo +data: + dockerCfg: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= + licenseFieldValueIsGitOpsSupported: true + licenseFieldValueIsIdentityServiceSupported: false + licenseFieldValueIsGeoaxisSupported: false + licenseFieldValueIsAirgapSupported: true + licenseFieldValueLicenseType: prod + licenseFieldValueLicenseSequence: 7 + licenseFieldValueSignature: '{"licenseData":"eyJhcGlWZXJzaW9uIjoia290cy5pby92MWJldGExIiwia2luZCI6IkxpY2Vuc2UiLCJtZXRhZGF0YSI6eyJuYW1lIjoidGVzdGN1c3RvbWVyIn0sInNwZWMiOnsibGljZW5zZUlEIjoiMXZ1c09va3hBVnAxdGtSR3V5eG5GMjNQSmNxIiwibGljZW5zZVR5cGUiOiJwcm9kIiwiY3VzdG9tZXJOYW1lIjoiVGVzdCBDdXN0b21lciIsImFwcFNsdWciOiJteS1hcHAiLCJjaGFubmVsSUQiOiIxdnVzSVlaTEFWeE1HNnE3NjBPSm1SS2o1aTUiLCJjaGFubmVsTmFtZSI6Ik15IENoYW5uZWwiLCJsaWNlbnNlU2VxdWVuY2UiOjcsImVuZHBvaW50IjoiaHR0cHM6Ly9yZXBsaWNhdGVkLmFwcCIsImVudGl0bGVtZW50cyI6eyJib29sX2ZpZWxkIjp7InRpdGxlIjoiQm9vbCBGaWVsZCIsInZhbHVlIjp0cnVlLCJ2YWx1ZVR5cGUiOiJCb29sZWFuIn0sImV4cGlyZXNfYXQiOnsidGl0bGUiOiJFeHBpcmF0aW9uIiwiZGVzY3JpcHRpb24iOiJMaWNlbnNlIEV4cGlyYXRpb24iLCJ2YWx1ZSI6IjIwMzAtMDctMjdUMDA6MDA6MDBaIiwidmFsdWVUeXBlIjoiU3RyaW5nIn0sImhpZGRlbl9maWVsZCI6eyJ0aXRsZSI6IkhpZGRlbiBGaWVsZCIsInZhbHVlIjoidGhpcyBpcyBzZWNyZXQiLCJ2YWx1ZVR5cGUiOiJTdHJpbmciLCJpc0hpZGRlbiI6dHJ1ZX0sImludF9maWVsZCI6eyJ0aXRsZSI6IkludCBGaWVsZCIsInZhbHVlIjoxMjMsInZhbHVlVHlwZSI6IkludGVnZXIifSwic3RyaW5nX2ZpZWxkIjp7InRpdGxlIjoiU3RyaW5nRmllbGQiLCJ2YWx1ZSI6InNpbmdsZSBsaW5lIHRleHQiLCJ2YWx1ZVR5cGUiOiJTdHJpbmcifSwidGV4dF9maWVsZCI6eyJ0aXRsZSI6IlRleHQgRmllbGQiLCJ2YWx1ZSI6Im11bHRpXG5saW5lXG50ZXh0IiwidmFsdWVUeXBlIjoiVGV4dCJ9fSwiaXNBaXJnYXBTdXBwb3J0ZWQiOnRydWUsImlzR2l0T3BzU3VwcG9ydGVkIjp0cnVlLCJpc1NuYXBzaG90U3VwcG9ydGVkIjp0cnVlfX0=","innerSignature":"eyJsaWNlbnNlU2lnbmF0dXJlIjoiaHgxMWMvTGZ3Q3hTNXFkQXBFSXFuTk1OM0pKa2s4VGdXRUZsT1JVRzR2cGV3dFhWV3lmejdYcHAwQ1k2YjdrQTRKczNIaGwwbFI0WTA1LzcvQUdCaDdVMHg3RHZMZ3QzU3M0bnFLVStXWEpSTzJYQUFvR0N1dTVGTFprQUhXcTRQQm1zaHV6cVlvcnpxelhFYVVVZERUdUxCMmg5aHgwWEhPRlpRMzludm9OR2ZOdy94SVdZdHRPdXdva2w2MVloRUxVeFd1SVRFc0NUa3lmMTMwOHk5RlRsZTJyV2dEeHFMa0RPSWUyOEl3S2RBL2IwVUIyTFFmTVpwVzl2Q3BJL2lyVzNnbjZyNVZ3V20vSWpybm43RzRkVjZuV3pTd0hPQ2Rua014MEt5UUNkL1B1ZXJTb3RuQ09tS013ZTRLbjhDd1NXUTQ4dTFDMm1iWUsxdXNZN3V3PT0iLCJwdWJsaWNLZXkiOiItLS0tLUJFR0lOIFBVQkxJQyBLRVktLS0tLVxuTUlJQklqQU5CZ2txaGtpRzl3MEJBUUVGQUFPQ0FROEFNSUlCQ2dLQ0FRRUFzNHJvUHp1aWRMeXN2b1Y2dzlaNFxuWGFib0NmY2MxaGdVaCswWUdKcE5DRUxrN0ZLQy92azdzdDlGNmcwT29kSERleXdRWkhKdU5MZlRsQlBGQ2NiNlxuNm9sTFNycFA4clU3SGxHblFER0RMaXdKQ2hkRDdUUGR3aWtpd0tFcm5jWjhGZjVlSnowdDNiTXZrT2ZUYnJBbFxuYkFCY0o5MVlUOXJuUW9qdUcxRWJQTjhFVnR6MlY4NHdubGd4MHBwbDV4OHZNbXppMHJublFUWUFjbzZqa2pIM1xuTnNUdXN1S1dvRFR5MXNrdkRROHlBYWJmY3M0N3ZsQk00SDFORE4vRHRaYlYvYnl2bkJ6bC8xVkVzTFdjZVVpTFxuRXF1OEdyaytQUDd2RGRwbER3cXZPWkxFdXk3djhnRm5SOVRURWprNUo5dnZUSGdmSnUzenlEOGlKY0RDNXpqOVxub1FJREFRQUJcbi0tLS0tRU5EIFBVQkxJQyBLRVktLS0tLVxuIiwia2V5U2lnbmF0dXJlIjoiZXlKemFXZHVZWFIxY21VaU9pSjBRWHB2WTNKVk56aFhSR2RsUTJocmNIWkVUVTlFWjBKWU1FRkZTRE5FU0hKbE1rTTNLMHBEVDNGeFNtNURUVTVVYm01bVpFRnlZWHB6ZERjMVZHaExPWEJUUkZrdkwwbzNZMFZJUmxWVEwyOUhWRWxsVkVOMFRHMVZRMGN3VGxGbFkzSnRTRms0VUZOa1ZVSjBUMVl3Ymt0cFRrVnBjbkJhTVc5amJWbHFZa3hoU2xsVWJFRkVXbUZvVjFKUFdqbFJhWEZuWldoQ2FuQjNSR3MwYVZJNU5WVldWVTVyT0hKb1lVTXlhbTg0V0daeFlqVlZibXhxZEZFd055czBhVlJJVEZONmVFMHplVXRvTUZGVmEwVTRRVzlHUlhKUE1YRlBSMVpRU1RCNllWaHpWVXBtY0RSbE1UQk9OV3RSVnpWT1NWY3ZSVXRFU0hsbU9VbFhkM1IwY1VsYWNXRjBSa05EYUZkcmJ6VkRSM0JYTDI1Rk1YYzJlV3RJVVhBMlUxSlJiSFpwUkUwMFZEUktUMkZsUVd0c1RWUk1UVWNyWTBaTGIzZE9TVm95YkhORGRsTnZRakZaZVdOTlNVSmxabEpuZWtSdU0xRTlQU0lzSW1kc2IySmhiRXRsZVVsa0lqb2lZbVJsWlRVMk5UWXdZMlppTkROak9XSXlPR0ptT1RobFlXTmhabUUyTkRZaWZRPT0ifQ=="}' + licenseFieldValueAppSlug: my-app + licenseFieldValueChannelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + licenseFieldValueChannelName: My Channel + licenseFieldValueCustomerName: Test Customer + licenseFieldValueEndpoint: https://replicated.app + licenseFieldValueLicenseID: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseFieldValueLicenseId: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseFieldValueCustomIntField: 123 + licenseFieldValueCustomStringField: single line text + licenseFieldValueCustomTextField: "multi\nline\ntext" + licenseFieldValueCustomBoolField: "true" + licenseFieldValueCustomHiddenField: "this is secret" diff --git a/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/config.yaml b/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/config.yaml new file mode 100644 index 0000000000..af995cc7f7 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/config.yaml @@ -0,0 +1,19 @@ +apiVersion: kots.io/v1beta1 +kind: Config +metadata: + creationTimestamp: null + name: my-app +spec: + groups: + - items: + - default: "" + help_text: | + Use this field to provide a hostname for your Example Application installation. + name: hostname + required: true + title: Hostname + type: text + value: my-app.somebigbank.com + name: setup + title: Setup +status: {} diff --git a/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/userdata/config.yaml b/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/userdata/config.yaml new file mode 100644 index 0000000000..4b2800d1ad --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/userdata/config.yaml @@ -0,0 +1,10 @@ +apiVersion: kots.io/v1beta1 +kind: ConfigValues +metadata: + creationTimestamp: null + name: replicated-kots-app +spec: + values: + hostname: + value: my-app.somebigbank.com +status: {} diff --git a/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/userdata/installation.yaml b/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/userdata/installation.yaml new file mode 100644 index 0000000000..b0c5471181 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/userdata/installation.yaml @@ -0,0 +1,9 @@ +apiVersion: kots.io/v1beta1 +kind: Installation +metadata: + creationTimestamp: null + name: replicated-kots-app +spec: + channelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + channelName: My Channel +status: {} diff --git a/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/userdata/license.yaml b/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/userdata/license.yaml new file mode 100644 index 0000000000..9fa3a14d7f --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/kotsKinds/userdata/license.yaml @@ -0,0 +1,49 @@ +apiVersion: kots.io/v1beta1 +kind: License +metadata: + creationTimestamp: null + name: testcustomer +spec: + appSlug: my-app + channelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + channelName: My Channel + customerName: Test Customer + endpoint: https://replicated.app + entitlements: + bool_field: + title: Bool Field + value: true + valueType: Boolean + expires_at: + description: License Expiration + title: Expiration + value: "2030-07-27T00:00:00Z" + valueType: String + hidden_field: + isHidden: true + title: Hidden Field + value: this is secret + valueType: String + int_field: + title: Int Field + value: 123 + valueType: Integer + string_field: + title: StringField + value: single line text + valueType: String + text_field: + title: Text Field + value: |- + multi + line + text + valueType: Text + isAirgapSupported: true + isGitOpsSupported: true + isSnapshotSupported: true + licenseID: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseSequence: 7 + licenseType: prod + signature: eyJsaWNlbnNlRGF0YSI6ImV5SmhjR2xXWlhKemFXOXVJam9pYTI5MGN5NXBieTkyTVdKbGRHRXhJaXdpYTJsdVpDSTZJa3hwWTJWdWMyVWlMQ0p0WlhSaFpHRjBZU0k2ZXlKdVlXMWxJam9pZEdWemRHTjFjM1J2YldWeUluMHNJbk53WldNaU9uc2liR2xqWlc1elpVbEVJam9pTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54SWl3aWJHbGpaVzV6WlZSNWNHVWlPaUp3Y205a0lpd2lZM1Z6ZEc5dFpYSk9ZVzFsSWpvaVZHVnpkQ0JEZFhOMGIyMWxjaUlzSW1Gd2NGTnNkV2NpT2lKdGVTMWhjSEFpTENKamFHRnVibVZzU1VRaU9pSXhkblZ6U1ZsYVRFRldlRTFITm5FM05qQlBTbTFTUzJvMWFUVWlMQ0pqYUdGdWJtVnNUbUZ0WlNJNklrMTVJRU5vWVc1dVpXd2lMQ0pzYVdObGJuTmxVMlZ4ZFdWdVkyVWlPamNzSW1WdVpIQnZhVzUwSWpvaWFIUjBjSE02THk5eVpYQnNhV05oZEdWa0xtRndjQ0lzSW1WdWRHbDBiR1Z0Wlc1MGN5STZleUppYjI5c1gyWnBaV3hrSWpwN0luUnBkR3hsSWpvaVFtOXZiQ0JHYVdWc1pDSXNJblpoYkhWbElqcDBjblZsTENKMllXeDFaVlI1Y0dVaU9pSkNiMjlzWldGdUluMHNJbVY0Y0dseVpYTmZZWFFpT25zaWRHbDBiR1VpT2lKRmVIQnBjbUYwYVc5dUlpd2laR1Z6WTNKcGNIUnBiMjRpT2lKTWFXTmxibk5sSUVWNGNHbHlZWFJwYjI0aUxDSjJZV3gxWlNJNklqSXdNekF0TURjdE1qZFVNREE2TURBNk1EQmFJaXdpZG1Gc2RXVlVlWEJsSWpvaVUzUnlhVzVuSW4wc0ltaHBaR1JsYmw5bWFXVnNaQ0k2ZXlKMGFYUnNaU0k2SWtocFpHUmxiaUJHYVdWc1pDSXNJblpoYkhWbElqb2lkR2hwY3lCcGN5QnpaV055WlhRaUxDSjJZV3gxWlZSNWNHVWlPaUpUZEhKcGJtY2lMQ0pwYzBocFpHUmxiaUk2ZEhKMVpYMHNJbWx1ZEY5bWFXVnNaQ0k2ZXlKMGFYUnNaU0k2SWtsdWRDQkdhV1ZzWkNJc0luWmhiSFZsSWpveE1qTXNJblpoYkhWbFZIbHdaU0k2SWtsdWRHVm5aWElpZlN3aWMzUnlhVzVuWDJacFpXeGtJanA3SW5ScGRHeGxJam9pVTNSeWFXNW5SbWxsYkdRaUxDSjJZV3gxWlNJNkluTnBibWRzWlNCc2FXNWxJSFJsZUhRaUxDSjJZV3gxWlZSNWNHVWlPaUpUZEhKcGJtY2lmU3dpZEdWNGRGOW1hV1ZzWkNJNmV5SjBhWFJzWlNJNklsUmxlSFFnUm1sbGJHUWlMQ0oyWVd4MVpTSTZJbTExYkhScFhHNXNhVzVsWEc1MFpYaDBJaXdpZG1Gc2RXVlVlWEJsSWpvaVZHVjRkQ0o5ZlN3aWFYTkJhWEpuWVhCVGRYQndiM0owWldRaU9uUnlkV1VzSW1selIybDBUM0J6VTNWd2NHOXlkR1ZrSWpwMGNuVmxMQ0pwYzFOdVlYQnphRzkwVTNWd2NHOXlkR1ZrSWpwMGNuVmxmWDA9IiwiaW5uZXJTaWduYXR1cmUiOiJleUpzYVdObGJuTmxVMmxuYm1GMGRYSmxJam9pYUhneE1XTXZUR1ozUTNoVE5YRmtRWEJGU1hGdVRrMU9NMHBLYTJzNFZHZFhSVVpzVDFKVlJ6UjJjR1YzZEZoV1YzbG1lamRZY0hBd1ExazJZamRyUVRSS2N6TklhR3d3YkZJMFdUQTFMemN2UVVkQ2FEZFZNSGczUkhaTVozUXpVM00wYm5GTFZTdFhXRXBTVHpKWVFVRnZSME4xZFRWR1RGcHJRVWhYY1RSUVFtMXphSFY2Y1ZsdmNucHhlbGhGWVZWVlpFUlVkVXhDTW1nNWFIZ3dXRWhQUmxwUk16bHVkbTlPUjJaT2R5OTRTVmRaZEhSUGRYZHZhMncyTVZsb1JVeFZlRmQxU1ZSRmMwTlVhM2xtTVRNd09IazVSbFJzWlRKeVYyZEVlSEZNYTBSUFNXVXlPRWwzUzJSQkwySXdWVUl5VEZGbVRWcHdWemwyUTNCSkwybHlWek5uYmpaeU5WWjNWMjB2U1dweWJtNDNSelJrVmpadVYzcFRkMGhQUTJSdWEwMTRNRXQ1VVVOa0wxQjFaWEpUYjNSdVEwOXRTMDEzWlRSTGJqaERkMU5YVVRRNGRURkRNbTFpV1VzeGRYTlpOM1YzUFQwaUxDSndkV0pzYVdOTFpYa2lPaUl0TFMwdExVSkZSMGxPSUZCVlFreEpReUJMUlZrdExTMHRMVnh1VFVsSlFrbHFRVTVDWjJ0eGFHdHBSemwzTUVKQlVVVkdRVUZQUTBGUk9FRk5TVWxDUTJkTFEwRlJSVUZ6TkhKdlVIcDFhV1JNZVhOMmIxWTJkemxhTkZ4dVdHRmliME5tWTJNeGFHZFZhQ3N3V1VkS2NFNURSVXhyTjBaTFF5OTJhemR6ZERsR05tY3dUMjlrU0VSbGVYZFJXa2hLZFU1TVpsUnNRbEJHUTJOaU5seHVObTlzVEZOeWNGQTRjbFUzU0d4SGJsRkVSMFJNYVhkS1EyaGtSRGRVVUdSM2FXdHBkMHRGY201aldqaEdaalZsU25vd2RETmlUWFpyVDJaVVluSkJiRnh1WWtGQ1kwbzVNVmxVT1hKdVVXOXFkVWN4UldKUVRqaEZWblI2TWxZNE5IZHViR2Q0TUhCd2JEVjRPSFpOYlhwcE1ISnVibEZVV1VGamJ6WnFhMnBJTTF4dVRuTlVkWE4xUzFkdlJGUjVNWE5yZGtSUk9IbEJZV0ptWTNNME4zWnNRazAwU0RGT1JFNHZSSFJhWWxZdllubDJia0o2YkM4eFZrVnpURmRqWlZWcFRGeHVSWEYxT0VkeWF5dFFVRGQyUkdSd2JFUjNjWFpQV2t4RmRYazNkamhuUm01U09WUlVSV3ByTlVvNWRuWlVTR2RtU25VemVubEVPR2xLWTBSRE5YcHFPVnh1YjFGSlJFRlJRVUpjYmkwdExTMHRSVTVFSUZCVlFreEpReUJMUlZrdExTMHRMVnh1SWl3aWEyVjVVMmxuYm1GMGRYSmxJam9pWlhsS2VtRlhaSFZaV0ZJeFkyMVZhVTlwU2pCUldIQjJXVE5LVms1NmFGaFNSMlJzVVRKb2NtTklXa1ZVVlRsRldqQktXVTFGUmtaVFJFNUZVMGhLYkUxclRUTkxNSEJFVkROR2VGTnROVVJVVlRWVlltMDFiVnBGUm5sWldIQjZaRVJqTVZaSGFFeFBXRUpVVWtacmRrd3diek5aTUZaSlVteFdWRXd5T1VoV1JXeHNWa1ZPTUZSSE1WWlJNR04zVkd4R2JGa3pTblJUUm1zMFZVWk9hMVpWU2pCVU1WbDNZbXQwY0ZSclZuQmpia0poVFZjNWFtSldiSEZaYTNob1UyeHNWV0pGUmtWWGJVWnZWakZLVUZkcWJGSmhXRVp1V2xkb1EyRnVRak5TUjNNd1lWWkpOVTVXVmxkV1ZUVnlUMGhLYjFsVlRYbGhiVGcwVjBkYWVGbHFWbFppYlhoeFpFWkZkMDU1Y3pCaFZsSkpWRVpPTm1WRk1IcGxWWFJ2VFVaR1ZtRXdWVFJSVnpsSFVsaEtVRTFZUmxCU01WcFJVMVJDTmxsV2FIcFdWWEJ0WTBSU2JFMVVRazlPVjNSU1ZucFdUMU5XWTNaU1ZYUkZVMGhzYlU5VmJGaGtNMUl3WTFWc1lXTlhSakJTYTA1RVlVWmtjbUo2VmtSU00wSllUREkxUmsxWVl6SmxWM1JKVlZoQk1sVXhTbEppU0Zwd1VrVXdNRlpFVWt0VU1rWnNVVmQwYzFSV1VrMVVWV055V1RCYVRHSXpaRTlUVm05NVlraE9SR1JzVG5aUmFrWmFaVmRPVGxOVlNteGFiRXB1Wld0U2RVMHhSVGxRVTBselNXMWtjMkl5U21oaVJYUnNaVlZzYTBscWIybFpiVkpzV2xSVk1rNVVXWGRaTWxwcFRrUk9hazlYU1hsUFIwcHRUMVJvYkZsWFRtaGFiVVV5VGtSWmFXWlJQVDBpZlE9PSJ9 +status: {} diff --git a/pkg/tests/renderdir/cases/simple/wantResults/overlays/downstreams/this-cluster/kustomization.yaml b/pkg/tests/renderdir/cases/simple/wantResults/overlays/downstreams/this-cluster/kustomization.yaml new file mode 100644 index 0000000000..73a609d8fa --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/overlays/downstreams/this-cluster/kustomization.yaml @@ -0,0 +1,4 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +bases: +- ../../midstream +kind: Kustomization diff --git a/pkg/tests/renderdir/cases/simple/wantResults/overlays/midstream/backup-label-transformer.yaml b/pkg/tests/renderdir/cases/simple/wantResults/overlays/midstream/backup-label-transformer.yaml new file mode 100644 index 0000000000..c3acc6c5b9 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/overlays/midstream/backup-label-transformer.yaml @@ -0,0 +1,39 @@ +apiVersion: builtin +kind: LabelTransformer +metadata: + name: backup-label-transformer +labels: + kots.io/app-slug: my-app + kots.io/backup: velero +fieldSpecs: +- path: metadata/labels + create: true +- version: v1 + kind: ReplicationController + path: spec/template/metadata/labels + create: true +- kind: Deployment + path: spec/template/metadata/labels + create: true +- kind: ReplicaSet + path: spec/template/metadata/labels + create: true +- kind: DaemonSet + path: spec/template/metadata/labels + create: true +- group: apps + kind: StatefulSet + path: spec/template/metadata/labels + create: true +- group: batch + kind: Job + path: spec/template/metadata/labels + create: true +- group: batch + kind: CronJob + path: spec/jobTemplate/metadata/labels + create: true +- group: batch + kind: CronJob + path: spec/jobTemplate/spec/template/metadata/labels + create: true diff --git a/pkg/tests/renderdir/cases/simple/wantResults/overlays/midstream/kustomization.yaml b/pkg/tests/renderdir/cases/simple/wantResults/overlays/midstream/kustomization.yaml new file mode 100644 index 0000000000..bb6f5b2615 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/overlays/midstream/kustomization.yaml @@ -0,0 +1,10 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +bases: +- ../../base +commonAnnotations: + kots.io/app-slug: my-app +kind: Kustomization +resources: +- secret.yaml +transformers: +- backup-label-transformer.yaml diff --git a/pkg/tests/renderdir/cases/simple/wantResults/overlays/midstream/secret.yaml b/pkg/tests/renderdir/cases/simple/wantResults/overlays/midstream/secret.yaml new file mode 100644 index 0000000000..4d81bc057f --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/overlays/midstream/secret.yaml @@ -0,0 +1,28 @@ +apiVersion: v1 +data: + .dockerconfigjson: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= +kind: Secret +metadata: + annotations: + helm.sh/hook: pre-install,pre-upgrade + helm.sh/hook-weight: "-9999" + kots.io/creation-phase: "-9999" + creationTimestamp: null + name: my-app-registry + namespace: app-namespace +type: kubernetes.io/dockerconfigjson + +--- +apiVersion: v1 +data: + .dockerconfigjson: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= +kind: Secret +metadata: + annotations: + helm.sh/hook: pre-install,pre-upgrade + helm.sh/hook-weight: "-9999" + kots.io/creation-phase: "-9999" + creationTimestamp: null + name: kotsadm-replicated-registry + namespace: app-namespace +type: kubernetes.io/dockerconfigjson diff --git a/pkg/tests/renderdir/cases/simple/wantResults/rendered/this-cluster/kotsadm-replicated-registry-secret.yaml b/pkg/tests/renderdir/cases/simple/wantResults/rendered/this-cluster/kotsadm-replicated-registry-secret.yaml new file mode 100644 index 0000000000..6f52289831 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/rendered/this-cluster/kotsadm-replicated-registry-secret.yaml @@ -0,0 +1,17 @@ +apiVersion: v1 +data: + .dockerconfigjson: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= +kind: Secret +metadata: + annotations: + helm.sh/hook: pre-install,pre-upgrade + helm.sh/hook-weight: "-9999" + kots.io/app-slug: my-app + kots.io/creation-phase: "-9999" + creationTimestamp: null + labels: + kots.io/app-slug: my-app + kots.io/backup: velero + name: kotsadm-replicated-registry + namespace: app-namespace +type: kubernetes.io/dockerconfigjson \ No newline at end of file diff --git a/pkg/tests/renderdir/cases/simple/wantResults/rendered/this-cluster/my-app-registry-secret.yaml b/pkg/tests/renderdir/cases/simple/wantResults/rendered/this-cluster/my-app-registry-secret.yaml new file mode 100644 index 0000000000..a8b369b451 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/rendered/this-cluster/my-app-registry-secret.yaml @@ -0,0 +1,17 @@ +apiVersion: v1 +data: + .dockerconfigjson: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= +kind: Secret +metadata: + annotations: + helm.sh/hook: pre-install,pre-upgrade + helm.sh/hook-weight: "-9999" + kots.io/app-slug: my-app + kots.io/creation-phase: "-9999" + creationTimestamp: null + labels: + kots.io/app-slug: my-app + kots.io/backup: velero + name: my-app-registry + namespace: app-namespace +type: kubernetes.io/dockerconfigjson diff --git a/pkg/tests/renderdir/cases/simple/wantResults/rendered/this-cluster/test-licenseinfo-configmap.yaml b/pkg/tests/renderdir/cases/simple/wantResults/rendered/this-cluster/test-licenseinfo-configmap.yaml new file mode 100644 index 0000000000..db9a488146 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/rendered/this-cluster/test-licenseinfo-configmap.yaml @@ -0,0 +1,33 @@ +apiVersion: v1 +data: + dockerCfg: eyJhdXRocyI6eyJwcm94eS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9LCJyZWdpc3RyeS5yZXBsaWNhdGVkLmNvbSI6eyJhdXRoIjoiTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54T2pGMmRYTlBiMnQ0UVZad01YUnJVa2QxZVhodVJqSXpVRXBqY1E9PSJ9fX0= + licenseFieldValueAppSlug: my-app + licenseFieldValueChannelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + licenseFieldValueChannelName: My Channel + licenseFieldValueCustomBoolField: "true" + licenseFieldValueCustomHiddenField: this is secret + licenseFieldValueCustomIntField: 123 + licenseFieldValueCustomStringField: single line text + licenseFieldValueCustomTextField: |- + multi + line + text + licenseFieldValueCustomerName: Test Customer + licenseFieldValueEndpoint: https://replicated.app + licenseFieldValueIsAirgapSupported: true + licenseFieldValueIsGeoaxisSupported: false + licenseFieldValueIsGitOpsSupported: true + licenseFieldValueIsIdentityServiceSupported: false + licenseFieldValueLicenseID: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseFieldValueLicenseId: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseFieldValueLicenseSequence: 7 + licenseFieldValueLicenseType: prod + licenseFieldValueSignature: '{"licenseData":"eyJhcGlWZXJzaW9uIjoia290cy5pby92MWJldGExIiwia2luZCI6IkxpY2Vuc2UiLCJtZXRhZGF0YSI6eyJuYW1lIjoidGVzdGN1c3RvbWVyIn0sInNwZWMiOnsibGljZW5zZUlEIjoiMXZ1c09va3hBVnAxdGtSR3V5eG5GMjNQSmNxIiwibGljZW5zZVR5cGUiOiJwcm9kIiwiY3VzdG9tZXJOYW1lIjoiVGVzdCBDdXN0b21lciIsImFwcFNsdWciOiJteS1hcHAiLCJjaGFubmVsSUQiOiIxdnVzSVlaTEFWeE1HNnE3NjBPSm1SS2o1aTUiLCJjaGFubmVsTmFtZSI6Ik15IENoYW5uZWwiLCJsaWNlbnNlU2VxdWVuY2UiOjcsImVuZHBvaW50IjoiaHR0cHM6Ly9yZXBsaWNhdGVkLmFwcCIsImVudGl0bGVtZW50cyI6eyJib29sX2ZpZWxkIjp7InRpdGxlIjoiQm9vbCBGaWVsZCIsInZhbHVlIjp0cnVlLCJ2YWx1ZVR5cGUiOiJCb29sZWFuIn0sImV4cGlyZXNfYXQiOnsidGl0bGUiOiJFeHBpcmF0aW9uIiwiZGVzY3JpcHRpb24iOiJMaWNlbnNlIEV4cGlyYXRpb24iLCJ2YWx1ZSI6IjIwMzAtMDctMjdUMDA6MDA6MDBaIiwidmFsdWVUeXBlIjoiU3RyaW5nIn0sImhpZGRlbl9maWVsZCI6eyJ0aXRsZSI6IkhpZGRlbiBGaWVsZCIsInZhbHVlIjoidGhpcyBpcyBzZWNyZXQiLCJ2YWx1ZVR5cGUiOiJTdHJpbmciLCJpc0hpZGRlbiI6dHJ1ZX0sImludF9maWVsZCI6eyJ0aXRsZSI6IkludCBGaWVsZCIsInZhbHVlIjoxMjMsInZhbHVlVHlwZSI6IkludGVnZXIifSwic3RyaW5nX2ZpZWxkIjp7InRpdGxlIjoiU3RyaW5nRmllbGQiLCJ2YWx1ZSI6InNpbmdsZSBsaW5lIHRleHQiLCJ2YWx1ZVR5cGUiOiJTdHJpbmcifSwidGV4dF9maWVsZCI6eyJ0aXRsZSI6IlRleHQgRmllbGQiLCJ2YWx1ZSI6Im11bHRpXG5saW5lXG50ZXh0IiwidmFsdWVUeXBlIjoiVGV4dCJ9fSwiaXNBaXJnYXBTdXBwb3J0ZWQiOnRydWUsImlzR2l0T3BzU3VwcG9ydGVkIjp0cnVlLCJpc1NuYXBzaG90U3VwcG9ydGVkIjp0cnVlfX0=","innerSignature":"eyJsaWNlbnNlU2lnbmF0dXJlIjoiaHgxMWMvTGZ3Q3hTNXFkQXBFSXFuTk1OM0pKa2s4VGdXRUZsT1JVRzR2cGV3dFhWV3lmejdYcHAwQ1k2YjdrQTRKczNIaGwwbFI0WTA1LzcvQUdCaDdVMHg3RHZMZ3QzU3M0bnFLVStXWEpSTzJYQUFvR0N1dTVGTFprQUhXcTRQQm1zaHV6cVlvcnpxelhFYVVVZERUdUxCMmg5aHgwWEhPRlpRMzludm9OR2ZOdy94SVdZdHRPdXdva2w2MVloRUxVeFd1SVRFc0NUa3lmMTMwOHk5RlRsZTJyV2dEeHFMa0RPSWUyOEl3S2RBL2IwVUIyTFFmTVpwVzl2Q3BJL2lyVzNnbjZyNVZ3V20vSWpybm43RzRkVjZuV3pTd0hPQ2Rua014MEt5UUNkL1B1ZXJTb3RuQ09tS013ZTRLbjhDd1NXUTQ4dTFDMm1iWUsxdXNZN3V3PT0iLCJwdWJsaWNLZXkiOiItLS0tLUJFR0lOIFBVQkxJQyBLRVktLS0tLVxuTUlJQklqQU5CZ2txaGtpRzl3MEJBUUVGQUFPQ0FROEFNSUlCQ2dLQ0FRRUFzNHJvUHp1aWRMeXN2b1Y2dzlaNFxuWGFib0NmY2MxaGdVaCswWUdKcE5DRUxrN0ZLQy92azdzdDlGNmcwT29kSERleXdRWkhKdU5MZlRsQlBGQ2NiNlxuNm9sTFNycFA4clU3SGxHblFER0RMaXdKQ2hkRDdUUGR3aWtpd0tFcm5jWjhGZjVlSnowdDNiTXZrT2ZUYnJBbFxuYkFCY0o5MVlUOXJuUW9qdUcxRWJQTjhFVnR6MlY4NHdubGd4MHBwbDV4OHZNbXppMHJublFUWUFjbzZqa2pIM1xuTnNUdXN1S1dvRFR5MXNrdkRROHlBYWJmY3M0N3ZsQk00SDFORE4vRHRaYlYvYnl2bkJ6bC8xVkVzTFdjZVVpTFxuRXF1OEdyaytQUDd2RGRwbER3cXZPWkxFdXk3djhnRm5SOVRURWprNUo5dnZUSGdmSnUzenlEOGlKY0RDNXpqOVxub1FJREFRQUJcbi0tLS0tRU5EIFBVQkxJQyBLRVktLS0tLVxuIiwia2V5U2lnbmF0dXJlIjoiZXlKemFXZHVZWFIxY21VaU9pSjBRWHB2WTNKVk56aFhSR2RsUTJocmNIWkVUVTlFWjBKWU1FRkZTRE5FU0hKbE1rTTNLMHBEVDNGeFNtNURUVTVVYm01bVpFRnlZWHB6ZERjMVZHaExPWEJUUkZrdkwwbzNZMFZJUmxWVEwyOUhWRWxsVkVOMFRHMVZRMGN3VGxGbFkzSnRTRms0VUZOa1ZVSjBUMVl3Ymt0cFRrVnBjbkJhTVc5amJWbHFZa3hoU2xsVWJFRkVXbUZvVjFKUFdqbFJhWEZuWldoQ2FuQjNSR3MwYVZJNU5WVldWVTVyT0hKb1lVTXlhbTg0V0daeFlqVlZibXhxZEZFd055czBhVlJJVEZONmVFMHplVXRvTUZGVmEwVTRRVzlHUlhKUE1YRlBSMVpRU1RCNllWaHpWVXBtY0RSbE1UQk9OV3RSVnpWT1NWY3ZSVXRFU0hsbU9VbFhkM1IwY1VsYWNXRjBSa05EYUZkcmJ6VkRSM0JYTDI1Rk1YYzJlV3RJVVhBMlUxSlJiSFpwUkUwMFZEUktUMkZsUVd0c1RWUk1UVWNyWTBaTGIzZE9TVm95YkhORGRsTnZRakZaZVdOTlNVSmxabEpuZWtSdU0xRTlQU0lzSW1kc2IySmhiRXRsZVVsa0lqb2lZbVJsWlRVMk5UWXdZMlppTkROak9XSXlPR0ptT1RobFlXTmhabUUyTkRZaWZRPT0ifQ=="}' +kind: ConfigMap +metadata: + annotations: + kots.io/app-slug: my-app + labels: + kots.io/app-slug: my-app + kots.io/backup: velero + name: test-licenseinfo \ No newline at end of file diff --git a/pkg/tests/renderdir/cases/simple/wantResults/upstream/config.yaml b/pkg/tests/renderdir/cases/simple/wantResults/upstream/config.yaml new file mode 100644 index 0000000000..aff6c18cbf --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/upstream/config.yaml @@ -0,0 +1,15 @@ +apiVersion: kots.io/v1beta1 +kind: Config +metadata: + name: my-app +spec: + groups: + - name: setup + title: Setup + items: + - name: hostname + type: text + title: Hostname + help_text: | + Use this field to provide a hostname for your Example Application installation. + required: true diff --git a/pkg/tests/renderdir/cases/simple/wantResults/upstream/subdir/configmap.yaml b/pkg/tests/renderdir/cases/simple/wantResults/upstream/subdir/configmap.yaml new file mode 100644 index 0000000000..73843036cb --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/upstream/subdir/configmap.yaml @@ -0,0 +1,25 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + name: test-licenseinfo +data: + dockerCfg: {{repl LicenseDockerCfg }} + licenseFieldValueIsGitOpsSupported: {{repl LicenseFieldValue "isGitOpsSupported" }} + licenseFieldValueIsIdentityServiceSupported: {{repl LicenseFieldValue "isIdentityServiceSupported" }} + licenseFieldValueIsGeoaxisSupported: {{repl LicenseFieldValue "isGeoaxisSupported" }} + licenseFieldValueIsAirgapSupported: {{repl LicenseFieldValue "isAirgapSupported" }} + licenseFieldValueLicenseType: {{repl LicenseFieldValue "licenseType" }} + licenseFieldValueLicenseSequence: {{repl LicenseFieldValue "licenseSequence" }} + licenseFieldValueSignature: '{{repl LicenseFieldValue "signature" }}' + licenseFieldValueAppSlug: {{repl LicenseFieldValue "appSlug" }} + licenseFieldValueChannelID: {{repl LicenseFieldValue "channelID" }} + licenseFieldValueChannelName: {{repl LicenseFieldValue "channelName" }} + licenseFieldValueCustomerName: {{repl LicenseFieldValue "customerName" }} + licenseFieldValueEndpoint: {{repl LicenseFieldValue "endpoint" }} + licenseFieldValueLicenseID: {{repl LicenseFieldValue "licenseID" }} + licenseFieldValueLicenseId: {{repl LicenseFieldValue "licenseId" }} + licenseFieldValueCustomIntField: {{repl LicenseFieldValue "int_field" }} + licenseFieldValueCustomStringField: {{repl LicenseFieldValue "string_field" }} + licenseFieldValueCustomTextField: "{{repl LicenseFieldValue "text_field" | replace "\n" "\\n" }}" + licenseFieldValueCustomBoolField: "{{repl LicenseFieldValue "bool_field" }}" + licenseFieldValueCustomHiddenField: "{{repl LicenseFieldValue "hidden_field" }}" diff --git a/pkg/tests/renderdir/cases/simple/wantResults/upstream/userdata/config.yaml b/pkg/tests/renderdir/cases/simple/wantResults/upstream/userdata/config.yaml new file mode 100644 index 0000000000..4b2800d1ad --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/upstream/userdata/config.yaml @@ -0,0 +1,10 @@ +apiVersion: kots.io/v1beta1 +kind: ConfigValues +metadata: + creationTimestamp: null + name: replicated-kots-app +spec: + values: + hostname: + value: my-app.somebigbank.com +status: {} diff --git a/pkg/tests/renderdir/cases/simple/wantResults/upstream/userdata/installation.yaml b/pkg/tests/renderdir/cases/simple/wantResults/upstream/userdata/installation.yaml new file mode 100644 index 0000000000..b0c5471181 --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/upstream/userdata/installation.yaml @@ -0,0 +1,9 @@ +apiVersion: kots.io/v1beta1 +kind: Installation +metadata: + creationTimestamp: null + name: replicated-kots-app +spec: + channelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + channelName: My Channel +status: {} diff --git a/pkg/tests/renderdir/cases/simple/wantResults/upstream/userdata/license.yaml b/pkg/tests/renderdir/cases/simple/wantResults/upstream/userdata/license.yaml new file mode 100644 index 0000000000..9fa3a14d7f --- /dev/null +++ b/pkg/tests/renderdir/cases/simple/wantResults/upstream/userdata/license.yaml @@ -0,0 +1,49 @@ +apiVersion: kots.io/v1beta1 +kind: License +metadata: + creationTimestamp: null + name: testcustomer +spec: + appSlug: my-app + channelID: 1vusIYZLAVxMG6q760OJmRKj5i5 + channelName: My Channel + customerName: Test Customer + endpoint: https://replicated.app + entitlements: + bool_field: + title: Bool Field + value: true + valueType: Boolean + expires_at: + description: License Expiration + title: Expiration + value: "2030-07-27T00:00:00Z" + valueType: String + hidden_field: + isHidden: true + title: Hidden Field + value: this is secret + valueType: String + int_field: + title: Int Field + value: 123 + valueType: Integer + string_field: + title: StringField + value: single line text + valueType: String + text_field: + title: Text Field + value: |- + multi + line + text + valueType: Text + isAirgapSupported: true + isGitOpsSupported: true + isSnapshotSupported: true + licenseID: 1vusOokxAVp1tkRGuyxnF23PJcq + licenseSequence: 7 + licenseType: prod + signature: eyJsaWNlbnNlRGF0YSI6ImV5SmhjR2xXWlhKemFXOXVJam9pYTI5MGN5NXBieTkyTVdKbGRHRXhJaXdpYTJsdVpDSTZJa3hwWTJWdWMyVWlMQ0p0WlhSaFpHRjBZU0k2ZXlKdVlXMWxJam9pZEdWemRHTjFjM1J2YldWeUluMHNJbk53WldNaU9uc2liR2xqWlc1elpVbEVJam9pTVhaMWMwOXZhM2hCVm5BeGRHdFNSM1Y1ZUc1R01qTlFTbU54SWl3aWJHbGpaVzV6WlZSNWNHVWlPaUp3Y205a0lpd2lZM1Z6ZEc5dFpYSk9ZVzFsSWpvaVZHVnpkQ0JEZFhOMGIyMWxjaUlzSW1Gd2NGTnNkV2NpT2lKdGVTMWhjSEFpTENKamFHRnVibVZzU1VRaU9pSXhkblZ6U1ZsYVRFRldlRTFITm5FM05qQlBTbTFTUzJvMWFUVWlMQ0pqYUdGdWJtVnNUbUZ0WlNJNklrMTVJRU5vWVc1dVpXd2lMQ0pzYVdObGJuTmxVMlZ4ZFdWdVkyVWlPamNzSW1WdVpIQnZhVzUwSWpvaWFIUjBjSE02THk5eVpYQnNhV05oZEdWa0xtRndjQ0lzSW1WdWRHbDBiR1Z0Wlc1MGN5STZleUppYjI5c1gyWnBaV3hrSWpwN0luUnBkR3hsSWpvaVFtOXZiQ0JHYVdWc1pDSXNJblpoYkhWbElqcDBjblZsTENKMllXeDFaVlI1Y0dVaU9pSkNiMjlzWldGdUluMHNJbVY0Y0dseVpYTmZZWFFpT25zaWRHbDBiR1VpT2lKRmVIQnBjbUYwYVc5dUlpd2laR1Z6WTNKcGNIUnBiMjRpT2lKTWFXTmxibk5sSUVWNGNHbHlZWFJwYjI0aUxDSjJZV3gxWlNJNklqSXdNekF0TURjdE1qZFVNREE2TURBNk1EQmFJaXdpZG1Gc2RXVlVlWEJsSWpvaVUzUnlhVzVuSW4wc0ltaHBaR1JsYmw5bWFXVnNaQ0k2ZXlKMGFYUnNaU0k2SWtocFpHUmxiaUJHYVdWc1pDSXNJblpoYkhWbElqb2lkR2hwY3lCcGN5QnpaV055WlhRaUxDSjJZV3gxWlZSNWNHVWlPaUpUZEhKcGJtY2lMQ0pwYzBocFpHUmxiaUk2ZEhKMVpYMHNJbWx1ZEY5bWFXVnNaQ0k2ZXlKMGFYUnNaU0k2SWtsdWRDQkdhV1ZzWkNJc0luWmhiSFZsSWpveE1qTXNJblpoYkhWbFZIbHdaU0k2SWtsdWRHVm5aWElpZlN3aWMzUnlhVzVuWDJacFpXeGtJanA3SW5ScGRHeGxJam9pVTNSeWFXNW5SbWxsYkdRaUxDSjJZV3gxWlNJNkluTnBibWRzWlNCc2FXNWxJSFJsZUhRaUxDSjJZV3gxWlZSNWNHVWlPaUpUZEhKcGJtY2lmU3dpZEdWNGRGOW1hV1ZzWkNJNmV5SjBhWFJzWlNJNklsUmxlSFFnUm1sbGJHUWlMQ0oyWVd4MVpTSTZJbTExYkhScFhHNXNhVzVsWEc1MFpYaDBJaXdpZG1Gc2RXVlVlWEJsSWpvaVZHVjRkQ0o5ZlN3aWFYTkJhWEpuWVhCVGRYQndiM0owWldRaU9uUnlkV1VzSW1selIybDBUM0J6VTNWd2NHOXlkR1ZrSWpwMGNuVmxMQ0pwYzFOdVlYQnphRzkwVTNWd2NHOXlkR1ZrSWpwMGNuVmxmWDA9IiwiaW5uZXJTaWduYXR1cmUiOiJleUpzYVdObGJuTmxVMmxuYm1GMGRYSmxJam9pYUhneE1XTXZUR1ozUTNoVE5YRmtRWEJGU1hGdVRrMU9NMHBLYTJzNFZHZFhSVVpzVDFKVlJ6UjJjR1YzZEZoV1YzbG1lamRZY0hBd1ExazJZamRyUVRSS2N6TklhR3d3YkZJMFdUQTFMemN2UVVkQ2FEZFZNSGczUkhaTVozUXpVM00wYm5GTFZTdFhXRXBTVHpKWVFVRnZSME4xZFRWR1RGcHJRVWhYY1RSUVFtMXphSFY2Y1ZsdmNucHhlbGhGWVZWVlpFUlVkVXhDTW1nNWFIZ3dXRWhQUmxwUk16bHVkbTlPUjJaT2R5OTRTVmRaZEhSUGRYZHZhMncyTVZsb1JVeFZlRmQxU1ZSRmMwTlVhM2xtTVRNd09IazVSbFJzWlRKeVYyZEVlSEZNYTBSUFNXVXlPRWwzUzJSQkwySXdWVUl5VEZGbVRWcHdWemwyUTNCSkwybHlWek5uYmpaeU5WWjNWMjB2U1dweWJtNDNSelJrVmpadVYzcFRkMGhQUTJSdWEwMTRNRXQ1VVVOa0wxQjFaWEpUYjNSdVEwOXRTMDEzWlRSTGJqaERkMU5YVVRRNGRURkRNbTFpV1VzeGRYTlpOM1YzUFQwaUxDSndkV0pzYVdOTFpYa2lPaUl0TFMwdExVSkZSMGxPSUZCVlFreEpReUJMUlZrdExTMHRMVnh1VFVsSlFrbHFRVTVDWjJ0eGFHdHBSemwzTUVKQlVVVkdRVUZQUTBGUk9FRk5TVWxDUTJkTFEwRlJSVUZ6TkhKdlVIcDFhV1JNZVhOMmIxWTJkemxhTkZ4dVdHRmliME5tWTJNeGFHZFZhQ3N3V1VkS2NFNURSVXhyTjBaTFF5OTJhemR6ZERsR05tY3dUMjlrU0VSbGVYZFJXa2hLZFU1TVpsUnNRbEJHUTJOaU5seHVObTlzVEZOeWNGQTRjbFUzU0d4SGJsRkVSMFJNYVhkS1EyaGtSRGRVVUdSM2FXdHBkMHRGY201aldqaEdaalZsU25vd2RETmlUWFpyVDJaVVluSkJiRnh1WWtGQ1kwbzVNVmxVT1hKdVVXOXFkVWN4UldKUVRqaEZWblI2TWxZNE5IZHViR2Q0TUhCd2JEVjRPSFpOYlhwcE1ISnVibEZVV1VGamJ6WnFhMnBJTTF4dVRuTlVkWE4xUzFkdlJGUjVNWE5yZGtSUk9IbEJZV0ptWTNNME4zWnNRazAwU0RGT1JFNHZSSFJhWWxZdllubDJia0o2YkM4eFZrVnpURmRqWlZWcFRGeHVSWEYxT0VkeWF5dFFVRGQyUkdSd2JFUjNjWFpQV2t4RmRYazNkamhuUm01U09WUlVSV3ByTlVvNWRuWlVTR2RtU25VemVubEVPR2xLWTBSRE5YcHFPVnh1YjFGSlJFRlJRVUpjYmkwdExTMHRSVTVFSUZCVlFreEpReUJMUlZrdExTMHRMVnh1SWl3aWEyVjVVMmxuYm1GMGRYSmxJam9pWlhsS2VtRlhaSFZaV0ZJeFkyMVZhVTlwU2pCUldIQjJXVE5LVms1NmFGaFNSMlJzVVRKb2NtTklXa1ZVVlRsRldqQktXVTFGUmtaVFJFNUZVMGhLYkUxclRUTkxNSEJFVkROR2VGTnROVVJVVlRWVlltMDFiVnBGUm5sWldIQjZaRVJqTVZaSGFFeFBXRUpVVWtacmRrd3diek5aTUZaSlVteFdWRXd5T1VoV1JXeHNWa1ZPTUZSSE1WWlJNR04zVkd4R2JGa3pTblJUUm1zMFZVWk9hMVpWU2pCVU1WbDNZbXQwY0ZSclZuQmpia0poVFZjNWFtSldiSEZaYTNob1UyeHNWV0pGUmtWWGJVWnZWakZLVUZkcWJGSmhXRVp1V2xkb1EyRnVRak5TUjNNd1lWWkpOVTVXVmxkV1ZUVnlUMGhLYjFsVlRYbGhiVGcwVjBkYWVGbHFWbFppYlhoeFpFWkZkMDU1Y3pCaFZsSkpWRVpPTm1WRk1IcGxWWFJ2VFVaR1ZtRXdWVFJSVnpsSFVsaEtVRTFZUmxCU01WcFJVMVJDTmxsV2FIcFdWWEJ0WTBSU2JFMVVRazlPVjNSU1ZucFdUMU5XWTNaU1ZYUkZVMGhzYlU5VmJGaGtNMUl3WTFWc1lXTlhSakJTYTA1RVlVWmtjbUo2VmtSU00wSllUREkxUmsxWVl6SmxWM1JKVlZoQk1sVXhTbEppU0Zwd1VrVXdNRlpFVWt0VU1rWnNVVmQwYzFSV1VrMVVWV055V1RCYVRHSXpaRTlUVm05NVlraE9SR1JzVG5aUmFrWmFaVmRPVGxOVlNteGFiRXB1Wld0U2RVMHhSVGxRVTBselNXMWtjMkl5U21oaVJYUnNaVlZzYTBscWIybFpiVkpzV2xSVk1rNVVXWGRaTWxwcFRrUk9hazlYU1hsUFIwcHRUMVJvYkZsWFRtaGFiVVV5VGtSWmFXWlJQVDBpZlE9PSJ9 +status: {} diff --git a/pkg/tests/renderdir/renderdir_test.go b/pkg/tests/renderdir/renderdir_test.go new file mode 100644 index 0000000000..df0ef77101 --- /dev/null +++ b/pkg/tests/renderdir/renderdir_test.go @@ -0,0 +1,256 @@ +package renderdir + +import ( + "fmt" + "os" + "path/filepath" + "strings" + "testing" + + envsubst "github.com/drone/envsubst/v2" + "github.com/ghodss/yaml" + "github.com/golang/mock/gomock" + cp "github.com/otiai10/copy" + "github.com/replicatedhq/kots/pkg/render" + rendertypes "github.com/replicatedhq/kots/pkg/render/types" + "github.com/replicatedhq/kots/pkg/store" + mock_store "github.com/replicatedhq/kots/pkg/store/mock" + "github.com/replicatedhq/kots/pkg/util" + kotsv1beta1 "github.com/replicatedhq/kotskinds/apis/kots/v1beta1" + "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/require" +) + +type TestCaseSpec struct { + Name string + RenderDirOptions rendertypes.RenderDirOptions + ResultsDir string +} + +type testCase struct { + Name string + RenderDirOptions rendertypes.RenderDirOptions +} + +func TestKotsRenderDir(t *testing.T) { + ctrl := gomock.NewController(t) + defer ctrl.Finish() + + mockStore := mock_store.NewMockStore(ctrl) + store.SetStore(mockStore) + defer store.SetStore(nil) + + mockStore.EXPECT().UpdateAppVersionInstallationSpec(gomock.Any(), gomock.Any(), gomock.Any()).AnyTimes() + + t.Setenv("USE_MOCK_REPORTING", "1") + defer os.Unsetenv("USE_MOCK_REPORTING") + + t.Setenv("KOTSADM_TARGET_NAMESPACE", "app-namespace") + defer os.Unsetenv("KOTSADM_TARGET_NAMESPACE") + + tests := []testCase{} + root := "cases" + + entries, err := os.ReadDir(root) + require.NoError(t, err) + + for _, entry := range entries { + path := filepath.Join(root, entry.Name()) + + if !entry.IsDir() { + continue + } + + testcaseFilepath := filepath.Join(path, "testcase.yaml") + _, err = os.Stat(testcaseFilepath) + if os.IsNotExist(err) { + t.Logf("no testcase.yaml found in directory %s", path) + continue + } else { + require.NoError(t, err, path) + } + + b, err := os.ReadFile(testcaseFilepath) + require.NoError(t, err, path) + + var spec TestCaseSpec + err = yaml.Unmarshal(b, &spec) + require.NoError(t, err, path) + + test := testCase{ + Name: spec.Name, + RenderDirOptions: spec.RenderDirOptions, + } + + tests = append(tests, test) + } + require.NoError(t, err) + + // ensure the tests are actually loaded + if len(tests) == 0 { + fmt.Printf("Kots RenderDir test cases not found") + t.FailNow() + } + + for _, tt := range tests { + t.Run(tt.Name, func(t *testing.T) { + testDir := filepath.Dir(tt.RenderDirOptions.ArchiveDir) + + // copy archiveDir to preserve original test data + resultsDir := filepath.Join(testDir, "results") + os.Mkdir(resultsDir, 0755) + err := cp.Copy(tt.RenderDirOptions.ArchiveDir, resultsDir) + require.NoError(t, err) + tt.RenderDirOptions.ArchiveDir = resultsDir + + // Comment out this line to review the generated results. + // Just be sure to delete the 'results' directory in each test manually when finished! + // defer func() { os.RemoveAll(resultsDir) }() + + fmt.Printf("running test %s\n", tt.Name) + err = render.RenderDir(tt.RenderDirOptions) + require.NoError(t, err) + + wantResultsDir := filepath.Join(testDir, "wantResults") + err = filepath.Walk(wantResultsDir, + func(path string, info os.FileInfo, err error) error { + if err != nil { + return err + } + + if info.IsDir() && info.Name() == "kotsKinds" { + return filepath.SkipDir + } + + if info.IsDir() { + return nil + } + + resultPath := strings.Replace(path, "wantResults", "results", 1) + + if _, err = os.Stat(resultPath); os.IsNotExist(err) { + fmt.Printf("expected file %s not found in results\n", resultPath) + t.FailNow() + } + + return nil + }) + + require.NoError(t, err) + + // compare result files to wanted files + err = filepath.Walk(resultsDir, + func(path string, info os.FileInfo, err error) error { + if err != nil { + return err + } + + if info.IsDir() && info.Name() == "kotsKinds" { + return filepath.SkipDir + } + + if info.IsDir() { + return nil + } + + // exclude installation.yaml as it has a randomly generated encryptionKey + if strings.HasSuffix(path, "upstream/userdata/installation.yaml") || + strings.HasSuffix(path, ".DS_Store") { + return nil + } + + contents, err := os.ReadFile(path) + if err != nil { + return err + } + + wantPath := strings.Replace(path, "results", "wantResults", 1) + + wantContents, err := os.ReadFile(wantPath) + if err != nil { + fmt.Printf("unable to open file %s\n", wantPath) + } + require.NoError(t, err, wantPath) + + contentsString := string(contents) + wantContentsString := string(wantContents) + + if ext := filepath.Ext(wantPath); ext == ".yaml" || ext == ".yml" { + wantContentsString, err = envsubst.Eval(wantContentsString, util.TestGetenv) + require.NoError(t, err, wantPath) + } + + if strings.HasSuffix(wantPath, "pullsecrets.yaml") { + // pull secret patches are not generated in a deterministic order + gotPullSecrets := strings.Split(contentsString, "---\n") + wantPullSecrets := strings.Split(wantContentsString, "---\n") + require.ElementsMatch(t, wantPullSecrets, gotPullSecrets) + return nil + } + + assert.Equal(t, wantContentsString, contentsString, wantPath) + return nil + }) + + require.NoError(t, err) + + // Check that kots kinds match. + installationPath := "" + err = filepath.Walk(filepath.Join(resultsDir, "kotsKinds"), + func(path string, info os.FileInfo, err error) error { + if err != nil { + return err + } + + if info.IsDir() { + return nil + } + + // Skip installation.yaml because known images order will differ on every generation. + if strings.HasSuffix(path, "installation.yaml") { + installationPath = path + return nil + } + + rawContents, err := os.ReadFile(path) + if err != nil { + return err + } + require.NoError(t, err, path) + + wantPath := strings.Replace(path, "results", "wantResults", 1) + rawWantContents, err := os.ReadFile(wantPath) + if err != nil { + fmt.Printf("unable to open file %s\n", wantPath) + } + require.NoError(t, err, wantPath) + + require.Equal(t, string(rawWantContents), string(rawContents), wantPath) + return nil + }) + + require.NoError(t, err) + + wantInstallationPath := strings.Replace(installationPath, "results", "wantResults", 1) + + installationContents, err := os.ReadFile(installationPath) + require.NoError(t, err) + + wantInstallationContents, err := os.ReadFile(wantInstallationPath) + require.NoError(t, err) + + installation := kotsv1beta1.Installation{} + err = yaml.Unmarshal(installationContents, &installation) + require.NoError(t, err) + + wantInstallation := kotsv1beta1.Installation{} + err = yaml.Unmarshal(wantInstallationContents, &wantInstallation) + require.NoError(t, err) + + require.ElementsMatch(t, wantInstallation.Spec.KnownImages, installation.Spec.KnownImages) + wantInstallation.Spec.KnownImages = nil + installation.Spec.KnownImages = nil + require.Equal(t, wantInstallation, installation) + }) + } +} diff --git a/pkg/version/metrics.go b/pkg/version/metrics.go index 1c3af1430d..05c9cda83d 100644 --- a/pkg/version/metrics.go +++ b/pkg/version/metrics.go @@ -15,6 +15,7 @@ import ( "github.com/replicatedhq/kots/pkg/kotsutil" "github.com/replicatedhq/kots/pkg/logger" "github.com/replicatedhq/kots/pkg/render" + rendertypes "github.com/replicatedhq/kots/pkg/render/types" "github.com/replicatedhq/kots/pkg/store" "github.com/replicatedhq/kots/pkg/util" kotsv1beta1 "github.com/replicatedhq/kotskinds/apis/kots/v1beta1" @@ -112,7 +113,15 @@ func GetGraphs(app *types.App, sequence int64, kotsStore store.Store) ([]kotsv1b return graphs, errors.Wrap(err, "failed to marshal kots application") } - renderedKotsApplication, err := render.RenderFile(kotsKinds, registrySettings, app.Slug, sequence, app.IsAirgap, util.PodNamespace, []byte(templatedKotsApplication)) + renderedKotsApplication, err := render.RenderFile(rendertypes.RenderFileOptions{ + KotsKinds: kotsKinds, + RegistrySettings: registrySettings, + AppSlug: app.Slug, + Sequence: sequence, + IsAirgap: app.IsAirgap, + Namespace: util.PodNamespace, + InputContent: []byte(templatedKotsApplication), + }) if err != nil { return graphs, errors.Wrap(err, "failed to render kots application") }