mirror of
https://github.com/containers/podman.git
synced 2025-06-21 01:19:15 +08:00
Merge pull request #2769 from ypu/attach_test
Add three test cases for podman attach test
This commit is contained in:
@ -4,6 +4,8 @@ package integration
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"os"
|
"os"
|
||||||
|
"syscall"
|
||||||
|
"time"
|
||||||
|
|
||||||
. "github.com/containers/libpod/test/utils"
|
. "github.com/containers/libpod/test/utils"
|
||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
@ -73,4 +75,44 @@ var _ = Describe("Podman attach", func() {
|
|||||||
results.WaitWithDefaultTimeout()
|
results.WaitWithDefaultTimeout()
|
||||||
Expect(results.ExitCode()).To(Equal(125))
|
Expect(results.ExitCode()).To(Equal(125))
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("podman attach to a running container", func() {
|
||||||
|
session := podmanTest.Podman([]string{"run", "-d", "--name", "test", ALPINE, "/bin/sh", "-c", "while true; do echo test; sleep 1; done"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
|
||||||
|
results := podmanTest.Podman([]string{"attach", "test"})
|
||||||
|
time.Sleep(2 * time.Second)
|
||||||
|
results.Signal(syscall.SIGTSTP)
|
||||||
|
Expect(results.OutputToString()).To(ContainSubstring("test"))
|
||||||
|
Expect(podmanTest.NumberOfContainersRunning()).To(Equal(1))
|
||||||
|
})
|
||||||
|
It("podman attach to the latest container", func() {
|
||||||
|
session := podmanTest.Podman([]string{"run", "-d", "--name", "test1", ALPINE, "/bin/sh", "-c", "while true; do echo test1; sleep 1; done"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
|
||||||
|
session = podmanTest.Podman([]string{"run", "-d", "--name", "test2", ALPINE, "/bin/sh", "-c", "while true; do echo test2; sleep 1; done"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
|
||||||
|
results := podmanTest.Podman([]string{"attach", "-l"})
|
||||||
|
time.Sleep(2 * time.Second)
|
||||||
|
results.Signal(syscall.SIGTSTP)
|
||||||
|
Expect(results.OutputToString()).To(ContainSubstring("test2"))
|
||||||
|
Expect(podmanTest.NumberOfContainersRunning()).To(Equal(2))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("podman attach to a container with --sig-proxy set to false", func() {
|
||||||
|
session := podmanTest.Podman([]string{"run", "-d", "--name", "test", ALPINE, "/bin/sh", "-c", "while true; do echo test; sleep 1; done"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
|
||||||
|
results := podmanTest.Podman([]string{"attach", "--sig-proxy=false", "test"})
|
||||||
|
time.Sleep(2 * time.Second)
|
||||||
|
results.Signal(syscall.SIGTERM)
|
||||||
|
results.WaitWithDefaultTimeout()
|
||||||
|
Expect(results.OutputToString()).To(ContainSubstring("test"))
|
||||||
|
Expect(podmanTest.NumberOfContainersRunning()).To(Equal(1))
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
Reference in New Issue
Block a user