frame_test.go 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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. }
  27. for i, test := range tests {
  28. t.Logf("test %d input: %q", i, test)
  29. var bw bytes.Buffer
  30. r := bytes.NewReader(test)
  31. head, err := readHeader(r, make([]byte, 9))
  32. if err != nil {
  33. continue
  34. }
  35. framer := newFramer(r, &bw, nil, byte(head.version))
  36. err = framer.readFrame(&head)
  37. if err != nil {
  38. continue
  39. }
  40. _, err = framer.parseFrame()
  41. if err != nil {
  42. continue
  43. }
  44. t.Errorf("(%d) expected to fail for input %q", i, test)
  45. }
  46. }
  47. func TestFrameWriteTooLong(t *testing.T) {
  48. w := &bytes.Buffer{}
  49. framer := newFramer(nil, w, nil, 2)
  50. framer.writeHeader(0, opStartup, 1)
  51. framer.writeBytes(make([]byte, maxFrameSize+1))
  52. err := framer.finishWrite()
  53. if err != ErrFrameTooBig {
  54. t.Fatalf("expected to get %v got %v", ErrFrameTooBig, err)
  55. }
  56. }
  57. func TestFrameReadTooLong(t *testing.T) {
  58. r := &bytes.Buffer{}
  59. r.Write(make([]byte, maxFrameSize+1))
  60. // write a new header right after this frame to verify that we can read it
  61. r.Write([]byte{0x02, 0x00, 0x00, opReady, 0x00, 0x00, 0x00, 0x00})
  62. framer := newFramer(r, nil, nil, 2)
  63. head := frameHeader{
  64. version: 2,
  65. op: opReady,
  66. length: r.Len() - 8,
  67. }
  68. err := framer.readFrame(&head)
  69. if err != ErrFrameTooBig {
  70. t.Fatalf("expected to get %v got %v", ErrFrameTooBig, err)
  71. }
  72. head, err = readHeader(r, make([]byte, 8))
  73. if err != nil {
  74. t.Fatal(err)
  75. }
  76. if head.op != opReady {
  77. t.Fatalf("expected to get header %v got %v", opReady, head.op)
  78. }
  79. }