Skip to content

Commit 27067a9

Browse files
committed
Deprecate process -v/--value in favor of -p/--param
1 parent b1ab6a1 commit 27067a9

File tree

10 files changed

+66
-43
lines changed

10 files changed

+66
-43
lines changed

contrib/completions/bash/oc

+3-3
Original file line numberDiff line numberDiff line change
@@ -11493,16 +11493,16 @@ _oc_process()
1149311493
local_nonpersistent_flags+=("--output=")
1149411494
flags+=("--output-version=")
1149511495
local_nonpersistent_flags+=("--output-version=")
11496+
flags+=("--param=")
11497+
two_word_flags+=("-p")
11498+
local_nonpersistent_flags+=("--param=")
1149611499
flags+=("--parameters")
1149711500
local_nonpersistent_flags+=("--parameters")
1149811501
flags+=("--raw")
1149911502
local_nonpersistent_flags+=("--raw")
1150011503
flags+=("--template=")
1150111504
two_word_flags+=("-t")
1150211505
local_nonpersistent_flags+=("--template=")
11503-
flags+=("--value=")
11504-
two_word_flags+=("-v")
11505-
local_nonpersistent_flags+=("--value=")
1150611506
flags+=("--as=")
1150711507
flags+=("--certificate-authority=")
1150811508
flags_with_completion+=("--certificate-authority")

contrib/completions/bash/openshift

+3-3
Original file line numberDiff line numberDiff line change
@@ -16139,16 +16139,16 @@ _openshift_cli_process()
1613916139
local_nonpersistent_flags+=("--output=")
1614016140
flags+=("--output-version=")
1614116141
local_nonpersistent_flags+=("--output-version=")
16142+
flags+=("--param=")
16143+
two_word_flags+=("-p")
16144+
local_nonpersistent_flags+=("--param=")
1614216145
flags+=("--parameters")
1614316146
local_nonpersistent_flags+=("--parameters")
1614416147
flags+=("--raw")
1614516148
local_nonpersistent_flags+=("--raw")
1614616149
flags+=("--template=")
1614716150
two_word_flags+=("-t")
1614816151
local_nonpersistent_flags+=("--template=")
16149-
flags+=("--value=")
16150-
two_word_flags+=("-v")
16151-
local_nonpersistent_flags+=("--value=")
1615216152
flags+=("--as=")
1615316153
flags+=("--certificate-authority=")
1615416154
flags_with_completion+=("--certificate-authority")

contrib/completions/zsh/oc

+3-3
Original file line numberDiff line numberDiff line change
@@ -11654,16 +11654,16 @@ _oc_process()
1165411654
local_nonpersistent_flags+=("--output=")
1165511655
flags+=("--output-version=")
1165611656
local_nonpersistent_flags+=("--output-version=")
11657+
flags+=("--param=")
11658+
two_word_flags+=("-p")
11659+
local_nonpersistent_flags+=("--param=")
1165711660
flags+=("--parameters")
1165811661
local_nonpersistent_flags+=("--parameters")
1165911662
flags+=("--raw")
1166011663
local_nonpersistent_flags+=("--raw")
1166111664
flags+=("--template=")
1166211665
two_word_flags+=("-t")
1166311666
local_nonpersistent_flags+=("--template=")
11664-
flags+=("--value=")
11665-
two_word_flags+=("-v")
11666-
local_nonpersistent_flags+=("--value=")
1166711667
flags+=("--as=")
1166811668
flags+=("--certificate-authority=")
1166911669
flags_with_completion+=("--certificate-authority")

contrib/completions/zsh/openshift

+3-3
Original file line numberDiff line numberDiff line change
@@ -16300,16 +16300,16 @@ _openshift_cli_process()
1630016300
local_nonpersistent_flags+=("--output=")
1630116301
flags+=("--output-version=")
1630216302
local_nonpersistent_flags+=("--output-version=")
16303+
flags+=("--param=")
16304+
two_word_flags+=("-p")
16305+
local_nonpersistent_flags+=("--param=")
1630316306
flags+=("--parameters")
1630416307
local_nonpersistent_flags+=("--parameters")
1630516308
flags+=("--raw")
1630616309
local_nonpersistent_flags+=("--raw")
1630716310
flags+=("--template=")
1630816311
two_word_flags+=("-t")
1630916312
local_nonpersistent_flags+=("--template=")
16310-
flags+=("--value=")
16311-
two_word_flags+=("-v")
16312-
local_nonpersistent_flags+=("--value=")
1631316313
flags+=("--as=")
1631416314
flags+=("--certificate-authority=")
1631516315
flags_with_completion+=("--certificate-authority")

docs/man/man1/oc-process.1

+4-4
Original file line numberDiff line numberDiff line change
@@ -39,6 +39,10 @@ The output of the process command is always a list of one or more resources. You
3939
\fB\-\-output\-version\fP=""
4040
Output the formatted object with the given version (default api\-version).
4141

42+
.PP
43+
\fB\-p\fP, \fB\-\-param\fP=[]
44+
Specify a key\-value pair (eg. \-p FOO=BAR) to set/override a parameter value in the template.
45+
4246
.PP
4347
\fB\-\-parameters\fP=false
4448
Do not process but only print available parameters
@@ -52,10 +56,6 @@ The output of the process command is always a list of one or more resources. You
5256
Template string or path to template file to use when \-o=template or \-o=templatefile. The template format is golang templates [
5357
\[la]http://golang.org/pkg/text/template/#pkg-overview\[ra]]
5458

55-
.PP
56-
\fB\-v\fP, \fB\-\-value\fP=[]
57-
Specify a key\-value pair (eg. \-v FOO=BAR) to set/override a parameter value in the template.
58-
5959

6060
.SH OPTIONS INHERITED FROM PARENT COMMANDS
6161
.PP

docs/man/man1/openshift-cli-process.1

+4-4
Original file line numberDiff line numberDiff line change
@@ -39,6 +39,10 @@ The output of the process command is always a list of one or more resources. You
3939
\fB\-\-output\-version\fP=""
4040
Output the formatted object with the given version (default api\-version).
4141

42+
.PP
43+
\fB\-p\fP, \fB\-\-param\fP=[]
44+
Specify a key\-value pair (eg. \-p FOO=BAR) to set/override a parameter value in the template.
45+
4246
.PP
4347
\fB\-\-parameters\fP=false
4448
Do not process but only print available parameters
@@ -52,10 +56,6 @@ The output of the process command is always a list of one or more resources. You
5256
Template string or path to template file to use when \-o=template or \-o=templatefile. The template format is golang templates [
5357
\[la]http://golang.org/pkg/text/template/#pkg-overview\[ra]]
5458

55-
.PP
56-
\fB\-v\fP, \fB\-\-value\fP=[]
57-
Specify a key\-value pair (eg. \-v FOO=BAR) to set/override a parameter value in the template.
58-
5959

6060
.SH OPTIONS INHERITED FROM PARENT COMMANDS
6161
.PP

pkg/cmd/cli/cmd/process.go

+12-10
Original file line numberDiff line numberDiff line change
@@ -71,7 +71,10 @@ func NewCmdProcess(fullName string, f *clientcmd.Factory, out, errout io.Writer)
7171
}
7272
cmd.Flags().StringP("filename", "f", "", "Filename or URL to file to read a template")
7373
cmd.MarkFlagFilename("filename", "yaml", "yml", "json")
74-
cmd.Flags().StringArrayP("value", "v", nil, "Specify a key-value pair (eg. -v FOO=BAR) to set/override a parameter value in the template.")
74+
params := cmd.Flags().StringArrayP("value", "v", nil, "Specify a key-value pair (eg. -v FOO=BAR) to set/override a parameter value in the template.")
75+
cmd.Flags().MarkDeprecated("value", "Use -p, --param instead.")
76+
cmd.Flags().MarkHidden("value")
77+
cmd.Flags().StringArrayVarP(params, "param", "p", nil, "Specify a key-value pair (eg. -p FOO=BAR) to set/override a parameter value in the template.")
7578
cmd.Flags().BoolP("parameters", "", false, "Do not process but only print available parameters")
7679
cmd.Flags().StringP("labels", "l", "", "Label to set in all resources for this template")
7780

@@ -102,12 +105,11 @@ func RunProcess(f *clientcmd.Factory, out, errout io.Writer, cmd *cobra.Command,
102105
duplicatedKeys := sets.NewString()
103106

104107
var flagValues []string
105-
if cmd.Flag("value").Changed {
106-
flagValues = getFlagStringArray(cmd, "value")
108+
if cmd.Flag("value").Changed || cmd.Flag("param").Changed {
109+
flagValues = getFlagStringArray(cmd, "param")
110+
cmdutil.WarnAboutCommaSeparation(errout, flagValues, "--param")
107111
}
108112

109-
cmdutil.WarnAboutCommaSeparation(errout, flagValues, "--value")
110-
111113
for _, value := range flagValues {
112114
key := strings.Split(value, "=")[0]
113115
if keys.Has(key) {
@@ -134,7 +136,7 @@ func RunProcess(f *clientcmd.Factory, out, errout io.Writer, cmd *cobra.Command,
134136
}
135137

136138
if kcmdutil.GetFlagBool(cmd, "parameters") {
137-
for _, flag := range []string{"value", "labels", "output", "output-version", "raw", "template"} {
139+
for _, flag := range []string{"value", "param", "labels", "output", "output-version", "raw", "template"} {
138140
if f := cmd.Flags().Lookup(flag); f != nil && f.Changed {
139141
return kcmdutil.UsageError(cmd, "The --parameters flag does not process the template, can't be used with --%v", flag)
140142
}
@@ -238,10 +240,10 @@ func RunProcess(f *clientcmd.Factory, out, errout io.Writer, cmd *cobra.Command,
238240
}
239241
}
240242

241-
// Override the values for the current template parameters
242-
// when user specify the --value
243-
if cmd.Flag("value").Changed {
244-
values := getFlagStringArray(cmd, "value")
243+
// Override the parameter values for the current template parameters
244+
// when user specifies --param
245+
if cmd.Flag("value").Changed || cmd.Flag("param").Changed {
246+
values := getFlagStringArray(cmd, "param")
245247
if errs := injectUserVars(values, obj); errs != nil {
246248
return kerrors.NewAggregate(errs)
247249
}

test/cmd/process.sh

+25-4
Original file line numberDiff line numberDiff line change
@@ -17,9 +17,11 @@ os::test::junit::declare_suite_start "cmd/process"
1717
os::cmd::expect_failure_and_text 'oc process name1 name2' 'template name must be specified only once'
1818
# fail to pass a filename or template by name
1919
os::cmd::expect_failure_and_text 'oc process' 'Must pass a filename or name of stored template'
20-
# can't ask for parameters and try process the template
20+
# can't ask for parameters and try process the template (include tests for deprecated -v/--value)
2121
os::cmd::expect_failure_and_text 'oc process template-name --parameters --value=someval' '\-\-parameters flag does not process the template, can.t be used with \-\-value'
2222
os::cmd::expect_failure_and_text 'oc process template-name --parameters -v someval' '\-\-parameters flag does not process the template, can.t be used with \-\-value'
23+
os::cmd::expect_failure_and_text 'oc process template-name --parameters --param=someval' '\-\-parameters flag does not process the template, can.t be used with \-\-param'
24+
os::cmd::expect_failure_and_text 'oc process template-name --parameters -p someval' '\-\-parameters flag does not process the template, can.t be used with \-\-param'
2325
os::cmd::expect_failure_and_text 'oc process template-name --parameters --labels=someval' '\-\-parameters flag does not process the template, can.t be used with \-\-labels'
2426
os::cmd::expect_failure_and_text 'oc process template-name --parameters -l someval' '\-\-parameters flag does not process the template, can.t be used with \-\-labels'
2527
os::cmd::expect_failure_and_text 'oc process template-name --parameters --output=someval' '\-\-parameters flag does not process the template, can.t be used with \-\-output'
@@ -29,11 +31,14 @@ os::cmd::expect_failure_and_text 'oc process template-name --parameters --raw' '
2931
os::cmd::expect_failure_and_text 'oc process template-name --parameters --template=someval' '\-\-parameters flag does not process the template, can.t be used with \-\-template'
3032
os::cmd::expect_failure_and_text 'oc process template-name --parameters -t someval' '\-\-parameters flag does not process the template, can.t be used with \-\-template'
3133

32-
# providing a value more than once should fail
34+
# providing a value more than once should fail (include tests for deprecated -v/--value)
3335
os::cmd::expect_failure_and_text 'oc process template-name key=value key=value' 'provided more than once: key'
3436
os::cmd::expect_failure_and_text 'oc process template-name --value=key=value --value=key=value' 'provided more than once: key'
37+
os::cmd::expect_failure_and_text 'oc process template-name --param=key=value --param=key=value' 'provided more than once: key'
3538
os::cmd::expect_failure_and_text 'oc process template-name key=value --value=key=value' 'provided more than once: key'
39+
os::cmd::expect_failure_and_text 'oc process template-name key=value --param=key=value' 'provided more than once: key'
3640
os::cmd::expect_failure_and_text 'oc process template-name key=value other=foo --value=key=value --value=other=baz' 'provided more than once: key, other'
41+
os::cmd::expect_failure_and_text 'oc process template-name key=value other=foo --param=key=value --param=other=baz' 'provided more than once: key, other'
3742

3843
required_params="${OS_ROOT}/test/testdata/template_required_params.yaml"
3944

@@ -43,29 +48,45 @@ os::cmd::expect_failure_and_text "oc process -f '${OS_ROOT}/test/testdata/basic-
4348
# not providing required parameter should fail
4449
os::cmd::expect_failure_and_text "oc process -f '${required_params}'" 'parameter required_param is required and must be specified'
4550
# not providing an optional param is OK
46-
os::cmd::expect_success "oc process -f '${required_params}' --value=required_param=someval | oc create -f -"
51+
os::cmd::expect_success "oc process -f '${required_params}' --value=required_param=someval"
52+
os::cmd::expect_success "oc process -f '${required_params}' -v required_param=someval"
53+
os::cmd::expect_success "oc process -f '${required_params}' --param=required_param=someval"
54+
os::cmd::expect_success "oc process -f '${required_params}' -p required_param=someval | oc create -f -"
4755
# parameters with multiple equal signs are OK
4856
os::cmd::expect_success "oc process -f '${required_params}' required_param=someval=moreval | oc create -f -"
57+
os::cmd::expect_success "oc process -f '${required_params}' -v required_param=someval=moreval2 | oc create -f -"
58+
os::cmd::expect_success "oc process -f '${required_params}' -p required_param=someval=moreval3 | oc create -f -"
4959
# we should have overwritten the template param
5060
os::cmd::expect_success_and_text 'oc get user someval -o jsonpath={.Name}' 'someval'
61+
os::cmd::expect_success_and_text 'oc get user someval=moreval -o jsonpath={.Name}' 'someval=moreval'
62+
os::cmd::expect_success_and_text 'oc get user someval=moreval2 -o jsonpath={.Name}' 'someval=moreval2'
63+
os::cmd::expect_success_and_text 'oc get user someval=moreval3 -o jsonpath={.Name}' 'someval=moreval3'
5164
# providing a value not in the template should fail
5265
os::cmd::expect_failure_and_text "oc process -f '${required_params}' --value=required_param=someval --value=other_param=otherval" 'unknown parameter name "other_param"'
66+
os::cmd::expect_failure_and_text "oc process -f '${required_params}' --param=required_param=someval --param=other_param=otherval" 'unknown parameter name "other_param"'
5367
# failure on values fails the entire call
5468
os::cmd::expect_failure_and_text "oc process -f '${required_params}' --value=required_param=someval --value=optional_param" 'invalid parameter assignment in'
69+
os::cmd::expect_failure_and_text "oc process -f '${required_params}' --param=required_param=someval --param=optional_param" 'invalid parameter assignment in'
5570
# failure on labels fails the entire call
5671
os::cmd::expect_failure_and_text "oc process -f '${required_params}' --value=required_param=someval --labels======" 'error parsing labels'
72+
os::cmd::expect_failure_and_text "oc process -f '${required_params}' --param=required_param=someval --labels======" 'error parsing labels'
5773

5874
# values are not split on commas, required parameter is not recognized
5975
os::cmd::expect_failure_and_text "oc process -f '${required_params}' --value=optional_param=a,required_param=b" 'parameter required_param is required and must be specified'
60-
# warning is printed iff --value looks like two k-v pairs separated by comma
76+
os::cmd::expect_failure_and_text "oc process -f '${required_params}' --param=optional_param=a,required_param=b" 'parameter required_param is required and must be specified'
77+
# warning is printed iff --value/--param looks like two k-v pairs separated by comma
6178
os::cmd::expect_success_and_text "oc process -f '${required_params}' --value=required_param=a,b=c,d" 'no longer accepts comma-separated list'
6279
os::cmd::expect_success_and_not_text "oc process -f '${required_params}' --value=required_param=a_b_c_d" 'no longer accepts comma-separated list'
6380
os::cmd::expect_success_and_not_text "oc process -f '${required_params}' --value=required_param=a,b,c,d" 'no longer accepts comma-separated list'
81+
os::cmd::expect_success_and_text "oc process -f '${required_params}' --param=required_param=a,b=c,d" 'no longer accepts comma-separated list'
82+
os::cmd::expect_success_and_not_text "oc process -f '${required_params}' --param=required_param=a_b_c_d" 'no longer accepts comma-separated list'
83+
os::cmd::expect_success_and_not_text "oc process -f '${required_params}' --param=required_param=a,b,c,d" 'no longer accepts comma-separated list'
6484
# warning is not printed for template values passed as positional arguments
6585
os::cmd::expect_success_and_not_text "oc process -f '${required_params}' required_param=a,b=c,d" 'no longer accepts comma-separated list'
6686

6787
# set template parameter to contents of file
6888
os::cmd::expect_success_and_text "oc process -f '${required_params}' --value=required_param='`cat ${OS_ROOT}/test/testdata/multiline.txt`'" 'also,with=commas'
89+
os::cmd::expect_success_and_text "oc process -f '${required_params}' --param=required_param='`cat ${OS_ROOT}/test/testdata/multiline.txt`'" 'also,with=commas'
6990

7091

7192
echo "process: ok"

test/cmd/templates.sh

+4-4
Original file line numberDiff line numberDiff line change
@@ -37,17 +37,17 @@ os::test::junit::declare_suite_end
3737

3838
os::test::junit::declare_suite_start "cmd/templates/parameters"
3939
# Individually specified parameter values are honored
40-
os::cmd::expect_success_and_text 'oc process -f test/templates/testdata/guestbook.json -v ADMIN_USERNAME=myuser -v ADMIN_PASSWORD=mypassword' '"myuser"'
41-
os::cmd::expect_success_and_text 'oc process -f test/templates/testdata/guestbook.json -v ADMIN_USERNAME=myuser -v ADMIN_PASSWORD=mypassword' '"mypassword"'
40+
os::cmd::expect_success_and_text 'oc process -f test/templates/testdata/guestbook.json -p ADMIN_USERNAME=myuser -p ADMIN_PASSWORD=mypassword' '"myuser"'
41+
os::cmd::expect_success_and_text 'oc process -f test/templates/testdata/guestbook.json -p ADMIN_USERNAME=myuser -p ADMIN_PASSWORD=mypassword' '"mypassword"'
4242
# Argument values are honored
4343
os::cmd::expect_success_and_text 'oc process ADMIN_USERNAME=myuser ADMIN_PASSWORD=mypassword -f test/templates/testdata/guestbook.json' '"myuser"'
4444
os::cmd::expect_success_and_text 'oc process -f test/templates/testdata/guestbook.json ADMIN_USERNAME=myuser ADMIN_PASSWORD=mypassword' '"mypassword"'
4545
# Argument values with commas are honored
4646
os::cmd::expect_success 'oc create -f examples/sample-app/application-template-stibuild.json'
4747
os::cmd::expect_success_and_text 'oc process ruby-helloworld-sample MYSQL_USER=myself MYSQL_PASSWORD=my,1%pa=s' '"myself"'
4848
os::cmd::expect_success_and_text 'oc process MYSQL_USER=myself MYSQL_PASSWORD=my,1%pa=s ruby-helloworld-sample' '"my,1%pa=s"'
49-
os::cmd::expect_success_and_text 'oc process ruby-helloworld-sample -v MYSQL_USER=myself -v MYSQL_PASSWORD=my,1%pa=s' '"myself"'
50-
os::cmd::expect_success_and_text 'oc process -v MYSQL_USER=myself -v MYSQL_PASSWORD=my,1%pa=s ruby-helloworld-sample' '"my,1%pa=s"'
49+
os::cmd::expect_success_and_text 'oc process ruby-helloworld-sample -p MYSQL_USER=myself -p MYSQL_PASSWORD=my,1%pa=s' '"myself"'
50+
os::cmd::expect_success_and_text 'oc process -p MYSQL_USER=myself -p MYSQL_PASSWORD=my,1%pa=s ruby-helloworld-sample' '"my,1%pa=s"'
5151
os::cmd::expect_success 'oc delete template ruby-helloworld-sample'
5252
echo "template+parameters: ok"
5353
os::test::junit::declare_suite_end

0 commit comments

Comments
 (0)