mirror of
https://github.com/kubernetes-sigs/kustomize.git
synced 2026-05-17 18:25:26 +00:00
Merge pull request #5682 from kozjan/add-label-include-templates
fix: include label in templates when adding by cli
This commit is contained in:
@@ -39,6 +39,7 @@ type addMetadataOptions struct {
|
||||
mapValidator func(map[string]string) error
|
||||
kind kindOfAdd
|
||||
labelsWithoutSelector bool
|
||||
includeTemplates bool
|
||||
}
|
||||
|
||||
// newCmdAddAnnotation adds one or more commonAnnotations to the kustomization file.
|
||||
@@ -83,6 +84,9 @@ func newCmdAddLabel(fSys filesys.FileSystem, v func(map[string]string) error) *c
|
||||
cmd.Flags().BoolVar(&o.labelsWithoutSelector, "without-selector", false,
|
||||
"using add labels without selector option",
|
||||
)
|
||||
cmd.Flags().BoolVar(&o.includeTemplates, "include-templates", false,
|
||||
"include labels in templates (requires --without-selector)",
|
||||
)
|
||||
return cmd
|
||||
}
|
||||
|
||||
@@ -112,6 +116,9 @@ func (o *addMetadataOptions) validateAndParse(args []string) error {
|
||||
if len(args) < 1 {
|
||||
return fmt.Errorf("must specify %s", o.kind)
|
||||
}
|
||||
if !o.labelsWithoutSelector && o.includeTemplates {
|
||||
return fmt.Errorf("--without-selector flag must be specified for --include-templates to work")
|
||||
}
|
||||
m, err := util.ConvertSliceToMap(args, o.kind.String())
|
||||
if err != nil {
|
||||
return err
|
||||
@@ -132,7 +139,11 @@ func (o *addMetadataOptions) addAnnotations(m *types.Kustomization) error {
|
||||
|
||||
func (o *addMetadataOptions) addLabels(m *types.Kustomization) error {
|
||||
if o.labelsWithoutSelector {
|
||||
m.Labels = append(m.Labels, types.Label{Pairs: make(map[string]string), IncludeSelectors: false})
|
||||
m.Labels = append(m.Labels, types.Label{
|
||||
Pairs: make(map[string]string),
|
||||
IncludeSelectors: false,
|
||||
IncludeTemplates: o.includeTemplates,
|
||||
})
|
||||
return o.writeToMap(m.Labels[len(m.Labels)-1].Pairs, label)
|
||||
}
|
||||
if m.CommonLabels == nil {
|
||||
|
||||
@@ -284,6 +284,29 @@ func TestAddLabelWithoutSelector(t *testing.T) {
|
||||
assert.Equal(t, m.Labels[0], types.Label{Pairs: map[string]string{"new": "label"}})
|
||||
}
|
||||
|
||||
func TestAddLabelWithoutSelectorIncludeTemplates(t *testing.T) {
|
||||
var o addMetadataOptions
|
||||
o.labelsWithoutSelector = true
|
||||
m := makeKustomization(t)
|
||||
o.metadata = map[string]string{"new": "label"}
|
||||
o.includeTemplates = true
|
||||
require.NoError(t, o.addLabels(m))
|
||||
assert.Equal(t, m.Labels[0], types.Label{Pairs: map[string]string{"new": "label"}, IncludeTemplates: true})
|
||||
}
|
||||
|
||||
func TestAddLabelIncludeTemplatesWithoutRequiredFlag(t *testing.T) {
|
||||
fSys := filesys.MakeFsInMemory()
|
||||
v := valtest_test.MakeHappyMapValidator(t)
|
||||
cmd := newCmdAddLabel(fSys, v.Validator)
|
||||
args := []string{"new:label"}
|
||||
_ = cmd.Flag("include-templates").Value.Set("true")
|
||||
_ = cmd.Flag("without-selector").Value.Set("false")
|
||||
err := cmd.RunE(cmd, args)
|
||||
v.VerifyNoCall()
|
||||
require.Error(t, err)
|
||||
require.Containsf(t, err.Error(), "--without-selector flag must be specified for --include-templates to work", "incorrect error: %s", err.Error())
|
||||
}
|
||||
|
||||
func TestAddLabelWithoutSelectorAddLabel(t *testing.T) {
|
||||
var o addMetadataOptions
|
||||
o.metadata = map[string]string{"owls": "cute", "otters": "adorable"}
|
||||
|
||||
Reference in New Issue
Block a user