frame_test.go 2.6 KB

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