|
@@ -16,101 +16,6 @@ import (
|
|
"time"
|
|
"time"
|
|
)
|
|
)
|
|
|
|
|
|
-func TestMultipleAttachRestart(t *testing.T) {
|
|
|
|
- daemon := mkDaemon(t)
|
|
|
|
- defer nuke(daemon)
|
|
|
|
- container, _, _ := mkContainer(
|
|
|
|
- daemon,
|
|
|
|
- []string{"_", "/bin/sh", "-c", "i=1; while [ $i -le 5 ]; do i=`expr $i + 1`; echo hello; done"},
|
|
|
|
- t,
|
|
|
|
- )
|
|
|
|
- defer daemon.Destroy(container)
|
|
|
|
-
|
|
|
|
- // Simulate 3 client attaching to the container and stop/restart
|
|
|
|
-
|
|
|
|
- stdout1, err := container.StdoutPipe()
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- stdout2, err := container.StdoutPipe()
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- stdout3, err := container.StdoutPipe()
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if err := container.Start(); err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- l1, err := bufio.NewReader(stdout1).ReadString('\n')
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if strings.Trim(l1, " \r\n") != "hello" {
|
|
|
|
- t.Fatalf("Unexpected output. Expected [%s], received [%s]", "hello", l1)
|
|
|
|
- }
|
|
|
|
- l2, err := bufio.NewReader(stdout2).ReadString('\n')
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if strings.Trim(l2, " \r\n") != "hello" {
|
|
|
|
- t.Fatalf("Unexpected output. Expected [%s], received [%s]", "hello", l2)
|
|
|
|
- }
|
|
|
|
- l3, err := bufio.NewReader(stdout3).ReadString('\n')
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if strings.Trim(l3, " \r\n") != "hello" {
|
|
|
|
- t.Fatalf("Unexpected output. Expected [%s], received [%s]", "hello", l3)
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if err := container.Stop(10); err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- stdout1, err = container.StdoutPipe()
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- stdout2, err = container.StdoutPipe()
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- stdout3, err = container.StdoutPipe()
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if err := container.Start(); err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- setTimeout(t, "Timeout reading from the process", 3*time.Second, func() {
|
|
|
|
- l1, err = bufio.NewReader(stdout1).ReadString('\n')
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if strings.Trim(l1, " \r\n") != "hello" {
|
|
|
|
- t.Fatalf("Unexpected output. Expected [%s], received [%s]", "hello", l1)
|
|
|
|
- }
|
|
|
|
- l2, err = bufio.NewReader(stdout2).ReadString('\n')
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if strings.Trim(l2, " \r\n") != "hello" {
|
|
|
|
- t.Fatalf("Unexpected output. Expected [%s], received [%s]", "hello", l2)
|
|
|
|
- }
|
|
|
|
- l3, err = bufio.NewReader(stdout3).ReadString('\n')
|
|
|
|
- if err != nil {
|
|
|
|
- t.Fatal(err)
|
|
|
|
- }
|
|
|
|
- if strings.Trim(l3, " \r\n") != "hello" {
|
|
|
|
- t.Fatalf("Unexpected output. Expected [%s], received [%s]", "hello", l3)
|
|
|
|
- }
|
|
|
|
- })
|
|
|
|
- container.Wait()
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
func TestDiff(t *testing.T) {
|
|
func TestDiff(t *testing.T) {
|
|
eng := NewTestEngine(t)
|
|
eng := NewTestEngine(t)
|
|
daemon := mkDaemonFromEngine(eng, t)
|
|
daemon := mkDaemonFromEngine(eng, t)
|