mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Merge pull request #10122 from dqminh/execin-wait-cgroup
ExecIn process should wait for the parent signal before forking
This commit is contained in:
commit
5f5e02d22c
1 changed files with 61 additions and 0 deletions
|
@ -2,9 +2,13 @@ package main
|
|||
|
||||
import (
|
||||
"bufio"
|
||||
"fmt"
|
||||
"os"
|
||||
"os/exec"
|
||||
"reflect"
|
||||
"sort"
|
||||
"strings"
|
||||
"sync"
|
||||
"testing"
|
||||
"time"
|
||||
)
|
||||
|
@ -392,3 +396,60 @@ func TestExecStopNotHanging(t *testing.T) {
|
|||
}
|
||||
logDone("exec - container with exec not hanging on stop")
|
||||
}
|
||||
|
||||
func TestExecCgroup(t *testing.T) {
|
||||
defer deleteAllContainers()
|
||||
var cmd *exec.Cmd
|
||||
|
||||
cmd = exec.Command(dockerBinary, "run", "-d", "--name", "testing", "busybox", "top")
|
||||
_, err := runCommand(cmd)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
cmd = exec.Command(dockerBinary, "exec", "testing", "cat", "/proc/1/cgroup")
|
||||
out, _, err := runCommandWithOutput(cmd)
|
||||
if err != nil {
|
||||
t.Fatal(out, err)
|
||||
}
|
||||
containerCgroups := sort.StringSlice(strings.Split(string(out), "\n"))
|
||||
|
||||
var wg sync.WaitGroup
|
||||
var s sync.Mutex
|
||||
execCgroups := []sort.StringSlice{}
|
||||
// exec a few times concurrently to get consistent failure
|
||||
for i := 0; i < 5; i++ {
|
||||
wg.Add(1)
|
||||
go func() {
|
||||
cmd = exec.Command(dockerBinary, "exec", "testing", "cat", "/proc/self/cgroup")
|
||||
out, _, err := runCommandWithOutput(cmd)
|
||||
if err != nil {
|
||||
t.Fatal(out, err)
|
||||
}
|
||||
cg := sort.StringSlice(strings.Split(string(out), "\n"))
|
||||
|
||||
s.Lock()
|
||||
execCgroups = append(execCgroups, cg)
|
||||
s.Unlock()
|
||||
wg.Done()
|
||||
}()
|
||||
}
|
||||
wg.Wait()
|
||||
|
||||
for _, cg := range execCgroups {
|
||||
if !reflect.DeepEqual(cg, containerCgroups) {
|
||||
fmt.Println("exec cgroups:")
|
||||
for _, name := range cg {
|
||||
fmt.Printf(" %s\n", name)
|
||||
}
|
||||
|
||||
fmt.Println("container cgroups:")
|
||||
for _, name := range containerCgroups {
|
||||
fmt.Printf(" %s\n", name)
|
||||
}
|
||||
t.Fatal("cgroups mismatched")
|
||||
}
|
||||
}
|
||||
|
||||
logDone("exec - exec has the container cgroups")
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue