utils_test.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. package docker
  2. import (
  3. "bytes"
  4. "errors"
  5. "io"
  6. "io/ioutil"
  7. "testing"
  8. )
  9. func TestBufReader(t *testing.T) {
  10. reader, writer := io.Pipe()
  11. bufreader := newBufReader(reader)
  12. // Write everything down to a Pipe
  13. // Usually, a pipe should block but because of the buffered reader,
  14. // the writes will go through
  15. done := make(chan bool)
  16. go func() {
  17. writer.Write([]byte("hello world"))
  18. writer.Close()
  19. done <- true
  20. }()
  21. // Drain the reader *after* everything has been written, just to verify
  22. // it is indeed buffering
  23. <-done
  24. output, err := ioutil.ReadAll(bufreader)
  25. if err != nil {
  26. t.Fatal(err)
  27. }
  28. if !bytes.Equal(output, []byte("hello world")) {
  29. t.Error(string(output))
  30. }
  31. }
  32. type dummyWriter struct {
  33. buffer bytes.Buffer
  34. failOnWrite bool
  35. }
  36. func (dw *dummyWriter) Write(p []byte) (n int, err error) {
  37. if dw.failOnWrite {
  38. return 0, errors.New("Fake fail")
  39. }
  40. return dw.buffer.Write(p)
  41. }
  42. func (dw *dummyWriter) String() string {
  43. return dw.buffer.String()
  44. }
  45. func (dw *dummyWriter) Close() error {
  46. return nil
  47. }
  48. func TestWriteBroadcaster(t *testing.T) {
  49. writer := newWriteBroadcaster()
  50. // Test 1: Both bufferA and bufferB should contain "foo"
  51. bufferA := &dummyWriter{}
  52. writer.AddWriter(bufferA)
  53. bufferB := &dummyWriter{}
  54. writer.AddWriter(bufferB)
  55. writer.Write([]byte("foo"))
  56. if bufferA.String() != "foo" {
  57. t.Errorf("Buffer contains %v", bufferA.String())
  58. }
  59. if bufferB.String() != "foo" {
  60. t.Errorf("Buffer contains %v", bufferB.String())
  61. }
  62. // Test2: bufferA and bufferB should contain "foobar",
  63. // while bufferC should only contain "bar"
  64. bufferC := &dummyWriter{}
  65. writer.AddWriter(bufferC)
  66. writer.Write([]byte("bar"))
  67. if bufferA.String() != "foobar" {
  68. t.Errorf("Buffer contains %v", bufferA.String())
  69. }
  70. if bufferB.String() != "foobar" {
  71. t.Errorf("Buffer contains %v", bufferB.String())
  72. }
  73. if bufferC.String() != "bar" {
  74. t.Errorf("Buffer contains %v", bufferC.String())
  75. }
  76. // Test3: Test removal
  77. writer.RemoveWriter(bufferB)
  78. writer.Write([]byte("42"))
  79. if bufferA.String() != "foobar42" {
  80. t.Errorf("Buffer contains %v", bufferA.String())
  81. }
  82. if bufferB.String() != "foobar" {
  83. t.Errorf("Buffer contains %v", bufferB.String())
  84. }
  85. if bufferC.String() != "bar42" {
  86. t.Errorf("Buffer contains %v", bufferC.String())
  87. }
  88. // Test4: Test eviction on failure
  89. bufferA.failOnWrite = true
  90. writer.Write([]byte("fail"))
  91. if bufferA.String() != "foobar42" {
  92. t.Errorf("Buffer contains %v", bufferA.String())
  93. }
  94. if bufferC.String() != "bar42fail" {
  95. t.Errorf("Buffer contains %v", bufferC.String())
  96. }
  97. // Even though we reset the flag, no more writes should go in there
  98. bufferA.failOnWrite = false
  99. writer.Write([]byte("test"))
  100. if bufferA.String() != "foobar42" {
  101. t.Errorf("Buffer contains %v", bufferA.String())
  102. }
  103. if bufferC.String() != "bar42failtest" {
  104. t.Errorf("Buffer contains %v", bufferC.String())
  105. }
  106. writer.Close()
  107. }