Merge pull request #7812 from erikh/fix_top
docker top: fix command when multiple arguments are supplied
This commit is contained in:
commit
388ed88042
2 changed files with 20 additions and 1 deletions
|
@ -29,7 +29,7 @@ func (daemon *Daemon) ContainerTop(job *engine.Job) engine.Status {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return job.Error(err)
|
return job.Error(err)
|
||||||
}
|
}
|
||||||
output, err := exec.Command("ps", psArgs).Output()
|
output, err := exec.Command("ps", strings.Split(psArgs, " ")...).Output()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return job.Errorf("Error running ps: %s", err)
|
return job.Errorf("Error running ps: %s", err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,6 +7,25 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func TestTopMultipleArgs(t *testing.T) {
|
||||||
|
runCmd := exec.Command(dockerBinary, "run", "-i", "-d", "busybox", "sleep", "20")
|
||||||
|
out, _, err := runCommandWithOutput(runCmd)
|
||||||
|
errorOut(err, t, fmt.Sprintf("failed to start the container: %v", err))
|
||||||
|
|
||||||
|
cleanedContainerID := stripTrailingCharacters(out)
|
||||||
|
defer deleteContainer(cleanedContainerID)
|
||||||
|
|
||||||
|
topCmd := exec.Command(dockerBinary, "top", cleanedContainerID, "-o", "pid")
|
||||||
|
out, _, err = runCommandWithOutput(topCmd)
|
||||||
|
errorOut(err, t, fmt.Sprintf("failed to run top: %v %v", out, err))
|
||||||
|
|
||||||
|
if !strings.Contains(out, "PID") {
|
||||||
|
errorOut(nil, t, fmt.Sprintf("did not see PID after top -o pid"))
|
||||||
|
}
|
||||||
|
|
||||||
|
logDone("top - multiple arguments")
|
||||||
|
}
|
||||||
|
|
||||||
func TestTopNonPrivileged(t *testing.T) {
|
func TestTopNonPrivileged(t *testing.T) {
|
||||||
runCmd := exec.Command(dockerBinary, "run", "-i", "-d", "busybox", "sleep", "20")
|
runCmd := exec.Command(dockerBinary, "run", "-i", "-d", "busybox", "sleep", "20")
|
||||||
out, _, err := runCommandWithOutput(runCmd)
|
out, _, err := runCommandWithOutput(runCmd)
|
||||||
|
|
Loading…
Reference in a new issue