server_unit_test.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package server
  2. import (
  3. "testing"
  4. "time"
  5. "github.com/dotcloud/docker/utils"
  6. )
  7. func TestPools(t *testing.T) {
  8. srv := &Server{
  9. pullingPool: make(map[string]chan struct{}),
  10. pushingPool: make(map[string]chan struct{}),
  11. }
  12. if _, err := srv.poolAdd("pull", "test1"); err != nil {
  13. t.Fatal(err)
  14. }
  15. if _, err := srv.poolAdd("pull", "test2"); err != nil {
  16. t.Fatal(err)
  17. }
  18. if _, err := srv.poolAdd("push", "test1"); err == nil || err.Error() != "pull test1 is already in progress" {
  19. t.Fatalf("Expected `pull test1 is already in progress`")
  20. }
  21. if _, err := srv.poolAdd("pull", "test1"); err == nil || err.Error() != "pull test1 is already in progress" {
  22. t.Fatalf("Expected `pull test1 is already in progress`")
  23. }
  24. if _, err := srv.poolAdd("wait", "test3"); err == nil || err.Error() != "Unknown pool type" {
  25. t.Fatalf("Expected `Unknown pool type`")
  26. }
  27. if err := srv.poolRemove("pull", "test2"); err != nil {
  28. t.Fatal(err)
  29. }
  30. if err := srv.poolRemove("pull", "test2"); err != nil {
  31. t.Fatal(err)
  32. }
  33. if err := srv.poolRemove("pull", "test1"); err != nil {
  34. t.Fatal(err)
  35. }
  36. if err := srv.poolRemove("push", "test1"); err != nil {
  37. t.Fatal(err)
  38. }
  39. if err := srv.poolRemove("wait", "test3"); err == nil || err.Error() != "Unknown pool type" {
  40. t.Fatalf("Expected `Unknown pool type`")
  41. }
  42. }
  43. func TestLogEvent(t *testing.T) {
  44. srv := &Server{
  45. events: make([]utils.JSONMessage, 0, 64),
  46. listeners: make(map[int64]chan utils.JSONMessage),
  47. }
  48. srv.LogEvent("fakeaction", "fakeid", "fakeimage")
  49. listener := make(chan utils.JSONMessage)
  50. srv.Lock()
  51. srv.listeners[1337] = listener
  52. srv.Unlock()
  53. srv.LogEvent("fakeaction2", "fakeid", "fakeimage")
  54. numEvents := len(srv.GetEvents())
  55. if numEvents != 2 {
  56. t.Fatalf("Expected 2 events, found %d", numEvents)
  57. }
  58. go func() {
  59. time.Sleep(200 * time.Millisecond)
  60. srv.LogEvent("fakeaction3", "fakeid", "fakeimage")
  61. time.Sleep(200 * time.Millisecond)
  62. srv.LogEvent("fakeaction4", "fakeid", "fakeimage")
  63. }()
  64. setTimeout(t, "Listening for events timed out", 2*time.Second, func() {
  65. for i := 2; i < 4; i++ {
  66. event := <-listener
  67. if event != srv.GetEvents()[i] {
  68. t.Fatalf("Event received it different than expected")
  69. }
  70. }
  71. })
  72. }
  73. // FIXME: this is duplicated from integration/commands_test.go
  74. func setTimeout(t *testing.T, msg string, d time.Duration, f func()) {
  75. c := make(chan bool)
  76. // Make sure we are not too long
  77. go func() {
  78. time.Sleep(d)
  79. c <- true
  80. }()
  81. go func() {
  82. f()
  83. c <- false
  84. }()
  85. if <-c && msg != "" {
  86. t.Fatal(msg)
  87. }
  88. }