docker_api_events_test.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. package main
  2. import (
  3. "bufio"
  4. "bytes"
  5. "encoding/json"
  6. "fmt"
  7. "testing"
  8. "time"
  9. )
  10. func TestGetEventsLineDelim(t *testing.T) {
  11. name := "testimageevents"
  12. defer deleteImages(name)
  13. _, err := buildImage(name,
  14. `FROM scratch
  15. MAINTAINER "docker"`,
  16. true)
  17. if err != nil {
  18. t.Fatal(err)
  19. }
  20. if err := deleteImages(name); err != nil {
  21. t.Fatal(err)
  22. }
  23. endpoint := fmt.Sprintf("/events?since=1&until=%d", time.Now().Unix())
  24. body, err := sockRequest("GET", endpoint)
  25. if err != nil {
  26. t.Fatal(err)
  27. }
  28. linesRead := 0
  29. scanner := bufio.NewScanner(bytes.NewReader(body))
  30. for scanner.Scan() && linesRead < 2 {
  31. line := scanner.Bytes()
  32. if len(line) == 0 {
  33. continue
  34. }
  35. // make sure line delimited json
  36. res := make(map[string]interface{})
  37. if err := json.Unmarshal(line, &res); err != nil {
  38. t.Fatalf("Unmarshaling the line as JSON failed: %v", err)
  39. }
  40. linesRead++
  41. }
  42. if err := scanner.Err(); err != nil {
  43. t.Fatalf("Scanner failed: %v", err)
  44. }
  45. if linesRead < 2 {
  46. t.Fatalf("Only %d lines were read from the stream", linesRead)
  47. }
  48. logDone("events - test the api response is line delimited json")
  49. }