mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-04 09:49:50 +00:00
kubectl plugin: Expand environment variables in the command of plugin.yaml
This commit improves kubectl plugins to expand environment variables in the command of plugin.yaml.
This commit is contained in:
parent
c873e4a814
commit
9a36d5567a
@ -18,6 +18,7 @@ package plugins
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"io"
|
"io"
|
||||||
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
@ -47,7 +48,7 @@ type ExecPluginRunner struct{}
|
|||||||
// Run takes a given plugin and runs it in a given context using os/exec, returning
|
// Run takes a given plugin and runs it in a given context using os/exec, returning
|
||||||
// any error found while running.
|
// any error found while running.
|
||||||
func (r *ExecPluginRunner) Run(plugin *Plugin, ctx RunningContext) error {
|
func (r *ExecPluginRunner) Run(plugin *Plugin, ctx RunningContext) error {
|
||||||
command := strings.Split(plugin.Command, " ")
|
command := strings.Split(os.ExpandEnv(plugin.Command), " ")
|
||||||
base := command[0]
|
base := command[0]
|
||||||
args := []string{}
|
args := []string{}
|
||||||
if len(command) > 1 {
|
if len(command) > 1 {
|
||||||
|
@ -18,6 +18,7 @@ package plugins
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -38,8 +39,16 @@ func TestExecRunner(t *testing.T) {
|
|||||||
command: "false",
|
command: "false",
|
||||||
expectedErr: "exit status 1",
|
expectedErr: "exit status 1",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "env",
|
||||||
|
command: "echo $KUBECTL_PLUGINS_TEST",
|
||||||
|
expectedMsg: "ok\n",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
os.Setenv("KUBECTL_PLUGINS_TEST", "ok")
|
||||||
|
defer os.Unsetenv("KUBECTL_PLUGINS_TEST")
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
outBuf := bytes.NewBuffer([]byte{})
|
outBuf := bytes.NewBuffer([]byte{})
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user