docker_cli_events_test.go 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. package main
  2. import (
  3. "fmt"
  4. "os/exec"
  5. "regexp"
  6. "strconv"
  7. "strings"
  8. "testing"
  9. "time"
  10. )
  11. func TestEventsUntag(t *testing.T) {
  12. image := "busybox"
  13. dockerCmd(t, "tag", image, "utest:tag1")
  14. dockerCmd(t, "tag", image, "utest:tag2")
  15. dockerCmd(t, "rmi", "utest:tag1")
  16. dockerCmd(t, "rmi", "utest:tag2")
  17. eventsCmd := exec.Command("timeout", "0.2", dockerBinary, "events", "--since=1")
  18. out, _, _ := runCommandWithOutput(eventsCmd)
  19. events := strings.Split(out, "\n")
  20. nEvents := len(events)
  21. // The last element after the split above will be an empty string, so we
  22. // get the two elements before the last, which are the untags we're
  23. // looking for.
  24. for _, v := range events[nEvents-3 : nEvents-1] {
  25. if !strings.Contains(v, "untag") {
  26. t.Fatalf("event should be untag, not %#v", v)
  27. }
  28. }
  29. logDone("events - untags are logged")
  30. }
  31. func TestEventsContainerFailStartDie(t *testing.T) {
  32. defer deleteAllContainers()
  33. out, _, _ := dockerCmd(t, "images", "-q")
  34. image := strings.Split(out, "\n")[0]
  35. eventsCmd := exec.Command(dockerBinary, "run", "-d", "--name", "testeventdie", image, "blerg")
  36. _, _, err := runCommandWithOutput(eventsCmd)
  37. if err == nil {
  38. t.Fatalf("Container run with command blerg should have failed, but it did not")
  39. }
  40. eventsCmd = exec.Command(dockerBinary, "events", "--since=0", fmt.Sprintf("--until=%d", time.Now().Unix()))
  41. out, _, _ = runCommandWithOutput(eventsCmd)
  42. events := strings.Split(out, "\n")
  43. if len(events) <= 1 {
  44. t.Fatalf("Missing expected event")
  45. }
  46. startEvent := strings.Fields(events[len(events)-3])
  47. dieEvent := strings.Fields(events[len(events)-2])
  48. if startEvent[len(startEvent)-1] != "start" {
  49. t.Fatalf("event should be start, not %#v", startEvent)
  50. }
  51. if dieEvent[len(dieEvent)-1] != "die" {
  52. t.Fatalf("event should be die, not %#v", dieEvent)
  53. }
  54. logDone("events - container unwilling to start logs die")
  55. }
  56. func TestEventsLimit(t *testing.T) {
  57. defer deleteAllContainers()
  58. for i := 0; i < 30; i++ {
  59. dockerCmd(t, "run", "busybox", "echo", strconv.Itoa(i))
  60. }
  61. eventsCmd := exec.Command(dockerBinary, "events", "--since=0", fmt.Sprintf("--until=%d", time.Now().Unix()))
  62. out, _, _ := runCommandWithOutput(eventsCmd)
  63. events := strings.Split(out, "\n")
  64. nEvents := len(events) - 1
  65. if nEvents != 64 {
  66. t.Fatalf("events should be limited to 64, but received %d", nEvents)
  67. }
  68. logDone("events - limited to 64 entries")
  69. }
  70. func TestEventsContainerEvents(t *testing.T) {
  71. dockerCmd(t, "run", "--rm", "busybox", "true")
  72. eventsCmd := exec.Command(dockerBinary, "events", "--since=0", fmt.Sprintf("--until=%d", time.Now().Unix()))
  73. out, exitCode, err := runCommandWithOutput(eventsCmd)
  74. if exitCode != 0 || err != nil {
  75. t.Fatalf("Failed to get events with exit code %d: %s", exitCode, err)
  76. }
  77. events := strings.Split(out, "\n")
  78. events = events[:len(events)-1]
  79. if len(events) < 4 {
  80. t.Fatalf("Missing expected event")
  81. }
  82. createEvent := strings.Fields(events[len(events)-4])
  83. startEvent := strings.Fields(events[len(events)-3])
  84. dieEvent := strings.Fields(events[len(events)-2])
  85. destroyEvent := strings.Fields(events[len(events)-1])
  86. if createEvent[len(createEvent)-1] != "create" {
  87. t.Fatalf("event should be create, not %#v", createEvent)
  88. }
  89. if startEvent[len(startEvent)-1] != "start" {
  90. t.Fatalf("event should be start, not %#v", startEvent)
  91. }
  92. if dieEvent[len(dieEvent)-1] != "die" {
  93. t.Fatalf("event should be die, not %#v", dieEvent)
  94. }
  95. if destroyEvent[len(destroyEvent)-1] != "destroy" {
  96. t.Fatalf("event should be destroy, not %#v", destroyEvent)
  97. }
  98. logDone("events - container create, start, die, destroy is logged")
  99. }
  100. func TestEventsImageUntagDelete(t *testing.T) {
  101. name := "testimageevents"
  102. defer deleteImages(name)
  103. _, err := buildImage(name,
  104. `FROM scratch
  105. MAINTAINER "docker"`,
  106. true)
  107. if err != nil {
  108. t.Fatal(err)
  109. }
  110. if err := deleteImages(name); err != nil {
  111. t.Fatal(err)
  112. }
  113. eventsCmd := exec.Command(dockerBinary, "events", "--since=0", fmt.Sprintf("--until=%d", time.Now().Unix()))
  114. out, exitCode, err := runCommandWithOutput(eventsCmd)
  115. if exitCode != 0 || err != nil {
  116. t.Fatalf("Failed to get events with exit code %d: %s", exitCode, err)
  117. }
  118. events := strings.Split(out, "\n")
  119. events = events[:len(events)-1]
  120. if len(events) < 2 {
  121. t.Fatalf("Missing expected event")
  122. }
  123. untagEvent := strings.Fields(events[len(events)-2])
  124. deleteEvent := strings.Fields(events[len(events)-1])
  125. if untagEvent[len(untagEvent)-1] != "untag" {
  126. t.Fatalf("untag should be untag, not %#v", untagEvent)
  127. }
  128. if deleteEvent[len(deleteEvent)-1] != "delete" {
  129. t.Fatalf("delete should be delete, not %#v", deleteEvent)
  130. }
  131. logDone("events - image untag, delete is logged")
  132. }
  133. func TestEventsImagePull(t *testing.T) {
  134. since := time.Now().Unix()
  135. defer deleteImages("hello-world")
  136. pullCmd := exec.Command(dockerBinary, "pull", "hello-world")
  137. if out, _, err := runCommandWithOutput(pullCmd); err != nil {
  138. t.Fatalf("pulling the hello-world image from has failed: %s, %v", out, err)
  139. }
  140. eventsCmd := exec.Command(dockerBinary, "events",
  141. fmt.Sprintf("--since=%d", since),
  142. fmt.Sprintf("--until=%d", time.Now().Unix()))
  143. out, _, _ := runCommandWithOutput(eventsCmd)
  144. events := strings.Split(strings.TrimSpace(out), "\n")
  145. event := strings.TrimSpace(events[len(events)-1])
  146. if !strings.HasSuffix(event, "hello-world:latest: pull") {
  147. t.Fatalf("Missing pull event - got:%q", event)
  148. }
  149. logDone("events - image pull is logged")
  150. }
  151. func TestEventsImageImport(t *testing.T) {
  152. defer deleteAllContainers()
  153. since := time.Now().Unix()
  154. runCmd := exec.Command(dockerBinary, "run", "-d", "busybox", "true")
  155. out, _, err := runCommandWithOutput(runCmd)
  156. if err != nil {
  157. t.Fatal("failed to create a container", out, err)
  158. }
  159. cleanedContainerID := stripTrailingCharacters(out)
  160. out, _, err = runCommandPipelineWithOutput(
  161. exec.Command(dockerBinary, "export", cleanedContainerID),
  162. exec.Command(dockerBinary, "import", "-"),
  163. )
  164. if err != nil {
  165. t.Errorf("import failed with errors: %v, output: %q", err, out)
  166. }
  167. eventsCmd := exec.Command(dockerBinary, "events",
  168. fmt.Sprintf("--since=%d", since),
  169. fmt.Sprintf("--until=%d", time.Now().Unix()))
  170. out, _, _ = runCommandWithOutput(eventsCmd)
  171. events := strings.Split(strings.TrimSpace(out), "\n")
  172. event := strings.TrimSpace(events[len(events)-1])
  173. if !strings.HasSuffix(event, ": import") {
  174. t.Fatalf("Missing pull event - got:%q", event)
  175. }
  176. logDone("events - image import is logged")
  177. }
  178. func TestEventsFilters(t *testing.T) {
  179. parseEvents := func(out, match string) {
  180. events := strings.Split(out, "\n")
  181. events = events[:len(events)-1]
  182. for _, event := range events {
  183. eventFields := strings.Fields(event)
  184. eventName := eventFields[len(eventFields)-1]
  185. if ok, err := regexp.MatchString(match, eventName); err != nil || !ok {
  186. t.Fatalf("event should match %s, got %#v, err: %v", match, eventFields, err)
  187. }
  188. }
  189. }
  190. since := time.Now().Unix()
  191. out, _, err := runCommandWithOutput(exec.Command(dockerBinary, "run", "--rm", "busybox", "true"))
  192. if err != nil {
  193. t.Fatal(out, err)
  194. }
  195. out, _, err = runCommandWithOutput(exec.Command(dockerBinary, "run", "--rm", "busybox", "true"))
  196. if err != nil {
  197. t.Fatal(out, err)
  198. }
  199. out, _, err = runCommandWithOutput(exec.Command(dockerBinary, "events", fmt.Sprintf("--since=%d", since), fmt.Sprintf("--until=%d", time.Now().Unix()), "--filter", "event=die"))
  200. if err != nil {
  201. t.Fatalf("Failed to get events: %s", err)
  202. }
  203. parseEvents(out, "die")
  204. out, _, err = runCommandWithOutput(exec.Command(dockerBinary, "events", fmt.Sprintf("--since=%d", since), fmt.Sprintf("--until=%d", time.Now().Unix()), "--filter", "event=die", "--filter", "event=start"))
  205. if err != nil {
  206. t.Fatalf("Failed to get events: %s", err)
  207. }
  208. parseEvents(out, "((die)|(start))")
  209. // make sure we at least got 2 start events
  210. count := strings.Count(out, "start")
  211. if count != 2 {
  212. t.Fatalf("should have had 2 start events but had %d, out: %s", count, out)
  213. }
  214. logDone("events - filters")
  215. }