2014-02-25 11:17:48 -05:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os/exec"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestKillContainer(t *testing.T) {
|
|
|
|
runCmd := exec.Command(dockerBinary, "run", "-d", "busybox", "sh", "-c", "sleep 10")
|
|
|
|
out, _, err := runCommandWithOutput(runCmd)
|
2014-10-14 15:44:29 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(out, err)
|
|
|
|
}
|
2014-02-25 11:17:48 -05:00
|
|
|
|
|
|
|
cleanedContainerID := stripTrailingCharacters(out)
|
|
|
|
|
|
|
|
inspectCmd := exec.Command(dockerBinary, "inspect", cleanedContainerID)
|
2014-10-14 15:44:29 -04:00
|
|
|
if out, _, err = runCommandWithOutput(inspectCmd); err != nil {
|
|
|
|
t.Fatalf("out should've been a container id: %s, %v", out, err)
|
|
|
|
}
|
2014-02-25 11:17:48 -05:00
|
|
|
|
|
|
|
killCmd := exec.Command(dockerBinary, "kill", cleanedContainerID)
|
2014-10-14 15:44:29 -04:00
|
|
|
if out, _, err = runCommandWithOutput(killCmd); err != nil {
|
|
|
|
t.Fatalf("failed to kill container: %s, %v", out, err)
|
|
|
|
}
|
2014-02-25 11:17:48 -05:00
|
|
|
|
|
|
|
listRunningContainersCmd := exec.Command(dockerBinary, "ps", "-q")
|
|
|
|
out, _, err = runCommandWithOutput(listRunningContainersCmd)
|
2014-10-14 15:44:29 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to list running containers: %s, %v", out, err)
|
|
|
|
}
|
2014-02-25 11:17:48 -05:00
|
|
|
|
|
|
|
if strings.Contains(out, cleanedContainerID) {
|
|
|
|
t.Fatal("killed container is still running")
|
|
|
|
}
|
|
|
|
|
2014-04-03 20:22:32 -04:00
|
|
|
deleteContainer(cleanedContainerID)
|
2014-02-25 11:17:48 -05:00
|
|
|
|
|
|
|
logDone("kill - kill container running sleep 10")
|
|
|
|
}
|
2014-08-27 19:34:37 -04:00
|
|
|
|
|
|
|
func TestKillDifferentUserContainer(t *testing.T) {
|
|
|
|
runCmd := exec.Command(dockerBinary, "run", "-u", "daemon", "-d", "busybox", "sh", "-c", "sleep 10")
|
|
|
|
out, _, err := runCommandWithOutput(runCmd)
|
2014-10-14 15:44:29 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(out, err)
|
|
|
|
}
|
2014-08-27 19:34:37 -04:00
|
|
|
|
|
|
|
cleanedContainerID := stripTrailingCharacters(out)
|
|
|
|
|
|
|
|
inspectCmd := exec.Command(dockerBinary, "inspect", cleanedContainerID)
|
2014-10-14 15:44:29 -04:00
|
|
|
if out, _, err = runCommandWithOutput(inspectCmd); err != nil {
|
|
|
|
t.Fatalf("out should've been a container id: %s, %v", out, err)
|
|
|
|
}
|
2014-08-27 19:34:37 -04:00
|
|
|
|
|
|
|
killCmd := exec.Command(dockerBinary, "kill", cleanedContainerID)
|
2014-10-14 15:44:29 -04:00
|
|
|
if out, _, err = runCommandWithOutput(killCmd); err != nil {
|
|
|
|
t.Fatalf("failed to kill container: %s, %v", out, err)
|
|
|
|
}
|
2014-08-27 19:34:37 -04:00
|
|
|
|
|
|
|
listRunningContainersCmd := exec.Command(dockerBinary, "ps", "-q")
|
|
|
|
out, _, err = runCommandWithOutput(listRunningContainersCmd)
|
2014-10-14 15:44:29 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to list running containers: %s, %v", out, err)
|
|
|
|
}
|
2014-08-27 19:34:37 -04:00
|
|
|
|
|
|
|
if strings.Contains(out, cleanedContainerID) {
|
|
|
|
t.Fatal("killed container is still running")
|
|
|
|
}
|
|
|
|
|
|
|
|
deleteContainer(cleanedContainerID)
|
|
|
|
|
|
|
|
logDone("kill - kill container running sleep 10 from a different user")
|
|
|
|
}
|