compression_test.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package websocket
  2. import (
  3. "bytes"
  4. "fmt"
  5. "io"
  6. "io/ioutil"
  7. "testing"
  8. )
  9. type nopCloser struct{ io.Writer }
  10. func (nopCloser) Close() error { return nil }
  11. func TestTruncWriter(t *testing.T) {
  12. const data = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijlkmnopqrstuvwxyz987654321"
  13. for n := 1; n <= 10; n++ {
  14. var b bytes.Buffer
  15. w := &truncWriter{w: nopCloser{&b}}
  16. p := []byte(data)
  17. for len(p) > 0 {
  18. m := len(p)
  19. if m > n {
  20. m = n
  21. }
  22. w.Write(p[:m])
  23. p = p[m:]
  24. }
  25. if b.String() != data[:len(data)-len(w.p)] {
  26. t.Errorf("%d: %q", n, b.String())
  27. }
  28. }
  29. }
  30. func textMessages(num int) [][]byte {
  31. messages := make([][]byte, num)
  32. for i := 0; i < num; i++ {
  33. msg := fmt.Sprintf("planet: %d, country: %d, city: %d, street: %d", i, i, i, i)
  34. messages[i] = []byte(msg)
  35. }
  36. return messages
  37. }
  38. func TestCompressNoContextTakeover(t *testing.T) {
  39. for level := minCompressionLevel; level <= maxCompressionLevel; level++ {
  40. message := textMessages(1)[0]
  41. c := fakeNetConn{Reader: nil, Writer: ioutil.Discard}
  42. f := compressNoContextTakeover(c, level)
  43. n, err := f.Write(message)
  44. if err != nil {
  45. t.Errorf("Error writing using compressNoContextTakeover on level %d: %v", level, err)
  46. return
  47. }
  48. if n != len(message) {
  49. t.Errorf("Error writing using compressNoContextTakeover on level %d: not enough bytes written", level)
  50. return
  51. }
  52. err = f.Close()
  53. if err != nil {
  54. t.Errorf("Error closing writer on level %d: %v", level, err)
  55. return
  56. }
  57. }
  58. }
  59. func BenchmarkWriteNoCompression(b *testing.B) {
  60. w := ioutil.Discard
  61. c := newConn(fakeNetConn{Reader: nil, Writer: w}, false, 1024, 1024)
  62. messages := textMessages(100)
  63. b.ResetTimer()
  64. for i := 0; i < b.N; i++ {
  65. c.WriteMessage(TextMessage, messages[i%len(messages)])
  66. }
  67. b.ReportAllocs()
  68. }
  69. func BenchmarkWriteWithCompression(b *testing.B) {
  70. w := ioutil.Discard
  71. c := newConn(fakeNetConn{Reader: nil, Writer: w}, false, 1024, 1024)
  72. messages := textMessages(100)
  73. c.enableWriteCompression = true
  74. c.newCompressionWriter = compressNoContextTakeover
  75. b.ResetTimer()
  76. for i := 0; i < b.N; i++ {
  77. c.WriteMessage(TextMessage, messages[i%len(messages)])
  78. }
  79. b.ReportAllocs()
  80. }
  81. func TestValidCompressionLevel(t *testing.T) {
  82. c := newConn(fakeNetConn{}, false, 1024, 1024)
  83. for _, level := range []int{minCompressionLevel - 1, maxCompressionLevel + 1} {
  84. if err := c.SetCompressionLevel(level); err == nil {
  85. t.Errorf("no error for level %d", level)
  86. }
  87. }
  88. for _, level := range []int{minCompressionLevel, maxCompressionLevel} {
  89. if err := c.SetCompressionLevel(level); err != nil {
  90. t.Errorf("error for level %d", level)
  91. }
  92. }
  93. }