зеркало из https://github.com/microsoft/docker.git
102 строки
3.2 KiB
Go
102 строки
3.2 KiB
Go
package main
|
|
|
|
import (
|
|
"os/exec"
|
|
"strings"
|
|
|
|
"github.com/go-check/check"
|
|
)
|
|
|
|
func (s *DockerSuite) TestTopMultipleArgs(c *check.C) {
|
|
runCmd := exec.Command(dockerBinary, "run", "-i", "-d", "busybox", "top")
|
|
out, _, err := runCommandWithOutput(runCmd)
|
|
if err != nil {
|
|
c.Fatalf("failed to start the container: %s, %v", out, err)
|
|
}
|
|
|
|
cleanedContainerID := strings.TrimSpace(out)
|
|
|
|
topCmd := exec.Command(dockerBinary, "top", cleanedContainerID, "-o", "pid")
|
|
out, _, err = runCommandWithOutput(topCmd)
|
|
if err != nil {
|
|
c.Fatalf("failed to run top: %s, %v", out, err)
|
|
}
|
|
|
|
if !strings.Contains(out, "PID") {
|
|
c.Fatalf("did not see PID after top -o pid: %s", out)
|
|
}
|
|
|
|
}
|
|
|
|
func (s *DockerSuite) TestTopNonPrivileged(c *check.C) {
|
|
runCmd := exec.Command(dockerBinary, "run", "-i", "-d", "busybox", "top")
|
|
out, _, err := runCommandWithOutput(runCmd)
|
|
if err != nil {
|
|
c.Fatalf("failed to start the container: %s, %v", out, err)
|
|
}
|
|
|
|
cleanedContainerID := strings.TrimSpace(out)
|
|
|
|
topCmd := exec.Command(dockerBinary, "top", cleanedContainerID)
|
|
out1, _, err := runCommandWithOutput(topCmd)
|
|
if err != nil {
|
|
c.Fatalf("failed to run top: %s, %v", out1, err)
|
|
}
|
|
|
|
topCmd = exec.Command(dockerBinary, "top", cleanedContainerID)
|
|
out2, _, err := runCommandWithOutput(topCmd)
|
|
if err != nil {
|
|
c.Fatalf("failed to run top: %s, %v", out2, err)
|
|
}
|
|
|
|
killCmd := exec.Command(dockerBinary, "kill", cleanedContainerID)
|
|
if out, _, err = runCommandWithOutput(killCmd); err != nil {
|
|
c.Fatalf("failed to kill container: %s, %v", out, err)
|
|
}
|
|
|
|
if !strings.Contains(out1, "top") && !strings.Contains(out2, "top") {
|
|
c.Fatal("top should've listed `top` in the process list, but failed twice")
|
|
} else if !strings.Contains(out1, "top") {
|
|
c.Fatal("top should've listed `top` in the process list, but failed the first time")
|
|
} else if !strings.Contains(out2, "top") {
|
|
c.Fatal("top should've listed `top` in the process list, but failed the second itime")
|
|
}
|
|
|
|
}
|
|
|
|
func (s *DockerSuite) TestTopPrivileged(c *check.C) {
|
|
runCmd := exec.Command(dockerBinary, "run", "--privileged", "-i", "-d", "busybox", "top")
|
|
out, _, err := runCommandWithOutput(runCmd)
|
|
if err != nil {
|
|
c.Fatalf("failed to start the container: %s, %v", out, err)
|
|
}
|
|
|
|
cleanedContainerID := strings.TrimSpace(out)
|
|
|
|
topCmd := exec.Command(dockerBinary, "top", cleanedContainerID)
|
|
out1, _, err := runCommandWithOutput(topCmd)
|
|
if err != nil {
|
|
c.Fatalf("failed to run top: %s, %v", out1, err)
|
|
}
|
|
|
|
topCmd = exec.Command(dockerBinary, "top", cleanedContainerID)
|
|
out2, _, err := runCommandWithOutput(topCmd)
|
|
if err != nil {
|
|
c.Fatalf("failed to run top: %s, %v", out2, err)
|
|
}
|
|
|
|
killCmd := exec.Command(dockerBinary, "kill", cleanedContainerID)
|
|
if out, _, err = runCommandWithOutput(killCmd); err != nil {
|
|
c.Fatalf("failed to kill container: %s, %v", out, err)
|
|
}
|
|
|
|
if !strings.Contains(out1, "top") && !strings.Contains(out2, "top") {
|
|
c.Fatal("top should've listed `top` in the process list, but failed twice")
|
|
} else if !strings.Contains(out1, "top") {
|
|
c.Fatal("top should've listed `top` in the process list, but failed the first time")
|
|
} else if !strings.Contains(out2, "top") {
|
|
c.Fatal("top should've listed `top` in the process list, but failed the second itime")
|
|
}
|
|
|
|
}
|