frame_test.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. package gocql
  2. import (
  3. "bytes"
  4. "os"
  5. "testing"
  6. )
  7. func TestFuzzBugs(t *testing.T) {
  8. // these inputs are found using go-fuzz (https://github.com/dvyukov/go-fuzz)
  9. // and should cause a panic unless fixed.
  10. tests := [][]byte{
  11. []byte("00000\xa0000"),
  12. []byte("\x8000\x0e\x00\x00\x00\x000"),
  13. []byte("\x8000\x00\x00\x00\x00\t0000000000"),
  14. []byte("\xa0\xff\x01\xae\xefqE\xf2\x1a"),
  15. []byte("\x8200\b\x00\x00\x00c\x00\x00\x00\x02000\x01\x00\x00\x00\x03" +
  16. "\x00\n0000000000\x00\x14000000" +
  17. "00000000000000\x00\x020000" +
  18. "\x00\a000000000\x00\x050000000" +
  19. "\xff0000000000000000000" +
  20. "0000000"),
  21. []byte("\x82\xe600\x00\x00\x00\x000"),
  22. []byte("\x8200\b\x00\x00\x00\b0\x00\x00\x00\x040000"),
  23. []byte("\x8200\x00\x00\x00\x00\x100\x00\x00\x12\x00\x00\x0000000" +
  24. "00000"),
  25. []byte("\x83000\b\x00\x00\x00\x14\x00\x00\x00\x020000000" +
  26. "000000000"),
  27. []byte("\x83000\b\x00\x00\x000\x00\x00\x00\x04\x00\x1000000" +
  28. "00000000000000e00000" +
  29. "000\x800000000000000000" +
  30. "0000000000000"),
  31. }
  32. for i, test := range tests {
  33. t.Logf("test %d input: %q", i, test)
  34. var bw bytes.Buffer
  35. r := bytes.NewReader(test)
  36. head, err := readHeader(r, make([]byte, 9))
  37. if err != nil {
  38. continue
  39. }
  40. framer := newFramer(r, &bw, nil, byte(head.version))
  41. err = framer.readFrame(&head)
  42. if err != nil {
  43. continue
  44. }
  45. frame, err := framer.parseFrame()
  46. if err != nil {
  47. continue
  48. }
  49. t.Errorf("(%d) expected to fail for input % X", i, test)
  50. t.Errorf("(%d) frame=%+#v", i, frame)
  51. }
  52. }
  53. func TestFrameWriteTooLong(t *testing.T) {
  54. if os.Getenv("TRAVIS") == "true" {
  55. t.Skip("skipping test in travis due to memory pressure with the race detecor")
  56. }
  57. w := &bytes.Buffer{}
  58. framer := newFramer(nil, w, nil, 2)
  59. framer.writeHeader(0, opStartup, 1)
  60. framer.writeBytes(make([]byte, maxFrameSize+1))
  61. err := framer.finishWrite()
  62. if err != ErrFrameTooBig {
  63. t.Fatalf("expected to get %v got %v", ErrFrameTooBig, err)
  64. }
  65. }
  66. func TestFrameReadTooLong(t *testing.T) {
  67. if os.Getenv("TRAVIS") == "true" {
  68. t.Skip("skipping test in travis due to memory pressure with the race detecor")
  69. }
  70. r := &bytes.Buffer{}
  71. r.Write(make([]byte, maxFrameSize+1))
  72. // write a new header right after this frame to verify that we can read it
  73. r.Write([]byte{0x02, 0x00, 0x00, byte(opReady), 0x00, 0x00, 0x00, 0x00})
  74. framer := newFramer(r, nil, nil, 2)
  75. head := frameHeader{
  76. version: 2,
  77. op: opReady,
  78. length: r.Len() - 8,
  79. }
  80. err := framer.readFrame(&head)
  81. if err != ErrFrameTooBig {
  82. t.Fatalf("expected to get %v got %v", ErrFrameTooBig, err)
  83. }
  84. head, err = readHeader(r, make([]byte, 8))
  85. if err != nil {
  86. t.Fatal(err)
  87. }
  88. if head.op != opReady {
  89. t.Fatalf("expected to get header %v got %v", opReady, head.op)
  90. }
  91. }