diff --git a/pkg/plugins/common/kustomize/v2-alpha/scaffolds/api.go b/pkg/plugins/common/kustomize/v2-alpha/scaffolds/api.go index 768fb42fe32..68250c473e2 100644 --- a/pkg/plugins/common/kustomize/v2-alpha/scaffolds/api.go +++ b/pkg/plugins/common/kustomize/v2-alpha/scaffolds/api.go @@ -69,23 +69,10 @@ func (s *apiScaffolder) Scaffold() error { machinery.WithResource(&s.resource), ) - rs, err := s.config.GetResources() - if err != nil { - return err - } - - crdManifests := []string{} - for _, r := range rs { - crdManifests = append(crdManifests, s.generateManifestsPath(r)) - } - - crdManifests = append(crdManifests, s.generateManifestsPath(s.resource)) - // Keep track of these values before the update if s.resource.HasAPI() { if err := scaffold.Execute( &samples.CRDSample{Force: s.force}, - &samples.Kustomization{CRDManifests: crdManifests}, &rbac.CRDEditorRole{}, &rbac.CRDViewerRole{}, &patches.EnableWebhookPatch{}, @@ -95,6 +82,13 @@ func (s *apiScaffolder) Scaffold() error { ); err != nil { return fmt.Errorf("error scaffolding kustomize API manifests: %v", err) } + + // If the gvk is non-empty + if s.resource.Group != "" || s.resource.Version != "" || s.resource.Kind != "" { + if err := scaffold.Execute(&samples.Kustomization{}); err != nil { + return fmt.Errorf("error scaffolding manifests: %v", err) + } + } } return nil diff --git a/pkg/plugins/common/kustomize/v2-alpha/scaffolds/internal/templates/config/samples/kustomization.go b/pkg/plugins/common/kustomize/v2-alpha/scaffolds/internal/templates/config/samples/kustomization.go index 1a33feef3c3..fa5e8791290 100644 --- a/pkg/plugins/common/kustomize/v2-alpha/scaffolds/internal/templates/config/samples/kustomization.go +++ b/pkg/plugins/common/kustomize/v2-alpha/scaffolds/internal/templates/config/samples/kustomization.go @@ -17,54 +17,60 @@ limitations under the License. package samples import ( - "bytes" "fmt" "path/filepath" - "text/template" - "sigs.k8s.io/kubebuilder/v3/pkg/machinery" ) -var _ machinery.Template = &Kustomization{} +var ( + _ machinery.Template = &Kustomization{} + _ machinery.Inserter = &Kustomization{} +) -// Kustomization scaffolds a file that defines the kustomization scheme for the prometheus folder +// Kustomization scaffolds a kustomization.yaml for the manifests overlay folder. type Kustomization struct { machinery.TemplateMixin - - CRDManifests []string + machinery.ResourceMixin } -// SetTemplateDefaults implements file.Template +// SetTemplateDefaults implements machinery.Template func (f *Kustomization) SetTemplateDefaults() error { if f.Path == "" { f.Path = filepath.Join("config", "samples", "kustomization.yaml") } + f.Path = f.Resource.Replacer().Replace(f.Path) - defaultTemplate, err := f.createTemplate() - if err != nil { - return err - } - - f.TemplateBody = defaultTemplate - - f.IfExistsAction = machinery.OverwriteFile + f.TemplateBody = fmt.Sprintf(kustomizationTemplate, machinery.NewMarkerFor(f.Path, samplesMarker)) return nil } -func (f *Kustomization) createTemplate() (string, error) { - t := template.Must(template.New("customResourcesConfig").Parse(kustomizationTemplate)) +const ( + samplesMarker = "manifestskustomizesamples" +) - outputTmpl := &bytes.Buffer{} - if err := t.Execute(outputTmpl, f.CRDManifests); err != nil { - return "", fmt.Errorf("error when generating sample kustomization manifest: %w", err) - } +// GetMarkers implements file.Inserter +func (f *Kustomization) GetMarkers() []machinery.Marker { + return []machinery.Marker{machinery.NewMarkerFor(f.Path, samplesMarker)} +} + +const samplesCodeFragment = `- %s +` - return outputTmpl.String(), nil +// makeCRFileName returns a Custom Resource example file name in the same format +// as kubebuilder's CreateAPI plugin for a gvk. +func (f Kustomization) makeCRFileName() string { + return f.Resource.Replacer().Replace("%[group]_%[version]_%[kind].yaml") +} +// GetCodeFragments implements file.Inserter +func (f *Kustomization) GetCodeFragments() machinery.CodeFragmentsMap { + return machinery.CodeFragmentsMap{ + machinery.NewMarkerFor(f.Path, samplesMarker): []string{fmt.Sprintf(samplesCodeFragment, f.makeCRFileName())}, + } } -const kustomizationTemplate = `--- -resources:{{ range $i ,$e := . }} - - {{ . }}{{end}} +const kustomizationTemplate = `## Append samples of your project ## +resources: +%s ` diff --git a/testdata/project-v4-config/config/samples/kustomization.yaml b/testdata/project-v4-config/config/samples/kustomization.yaml index d2695576a2f..b5cf9e60f5c 100644 --- a/testdata/project-v4-config/config/samples/kustomization.yaml +++ b/testdata/project-v4-config/config/samples/kustomization.yaml @@ -1,5 +1,6 @@ ---- +## Append samples of your project ## resources: - - crew_v1_captain.yaml - - crew_v1_firstmate.yaml - - crew_v1_admiral.yaml +- crew_v1_captain.yaml +- crew_v1_firstmate.yaml +- crew_v1_admiral.yaml +#+kubebuilder:scaffold:manifestskustomizesamples diff --git a/testdata/project-v4-declarative-v1/config/samples/kustomization.yaml b/testdata/project-v4-declarative-v1/config/samples/kustomization.yaml index d2695576a2f..b5cf9e60f5c 100644 --- a/testdata/project-v4-declarative-v1/config/samples/kustomization.yaml +++ b/testdata/project-v4-declarative-v1/config/samples/kustomization.yaml @@ -1,5 +1,6 @@ ---- +## Append samples of your project ## resources: - - crew_v1_captain.yaml - - crew_v1_firstmate.yaml - - crew_v1_admiral.yaml +- crew_v1_captain.yaml +- crew_v1_firstmate.yaml +- crew_v1_admiral.yaml +#+kubebuilder:scaffold:manifestskustomizesamples diff --git a/testdata/project-v4-multigroup/config/samples/kustomization.yaml b/testdata/project-v4-multigroup/config/samples/kustomization.yaml index e3ee1201d7f..a74ed904341 100644 --- a/testdata/project-v4-multigroup/config/samples/kustomization.yaml +++ b/testdata/project-v4-multigroup/config/samples/kustomization.yaml @@ -1,13 +1,13 @@ ---- +## Append samples of your project ## resources: - - crew_v1_captain.yaml - - ship_v1beta1_frigate.yaml - - ship_v1_destroyer.yaml - - ship_v2alpha1_cruiser.yaml - - sea-creatures_v1beta1_kraken.yaml - - sea-creatures_v1beta2_leviathan.yaml - - foo.policy_v1_healthcheckpolicy.yaml - - apps_v1_deployment.yaml - - foo_v1_bar.yaml - - fiz_v1_bar.yaml - - _v1_lakers.yaml +- crew_v1_captain.yaml +- ship_v1beta1_frigate.yaml +- ship_v1_destroyer.yaml +- ship_v2alpha1_cruiser.yaml +- sea-creatures_v1beta1_kraken.yaml +- sea-creatures_v1beta2_leviathan.yaml +- foo.policy_v1_healthcheckpolicy.yaml +- foo_v1_bar.yaml +- fiz_v1_bar.yaml +- _v1_lakers.yaml +#+kubebuilder:scaffold:manifestskustomizesamples diff --git a/testdata/project-v4/config/samples/kustomization.yaml b/testdata/project-v4/config/samples/kustomization.yaml index d2695576a2f..b5cf9e60f5c 100644 --- a/testdata/project-v4/config/samples/kustomization.yaml +++ b/testdata/project-v4/config/samples/kustomization.yaml @@ -1,5 +1,6 @@ ---- +## Append samples of your project ## resources: - - crew_v1_captain.yaml - - crew_v1_firstmate.yaml - - crew_v1_admiral.yaml +- crew_v1_captain.yaml +- crew_v1_firstmate.yaml +- crew_v1_admiral.yaml +#+kubebuilder:scaffold:manifestskustomizesamples