buffer_decoder_test.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. /**
  2. * @fileoverview Tests for BufferDecoder.
  3. */
  4. goog.module('protobuf.binary.varintsTest');
  5. const BufferDecoder = goog.require('protobuf.binary.BufferDecoder');
  6. const {CHECK_CRITICAL_BOUNDS, CHECK_STATE} = goog.require('protobuf.internal.checks');
  7. goog.setTestOnly();
  8. /**
  9. * @param {...number} bytes
  10. * @return {!ArrayBuffer}
  11. */
  12. function createArrayBuffer(...bytes) {
  13. return new Uint8Array(bytes).buffer;
  14. }
  15. describe('Skip varint does', () => {
  16. it('skip a varint', () => {
  17. const bufferDecoder =
  18. BufferDecoder.fromArrayBuffer(createArrayBuffer(0x01));
  19. expect(bufferDecoder.skipVarint(0)).toBe(1);
  20. });
  21. it('fail when varint is larger than 10 bytes', () => {
  22. const bufferDecoder = BufferDecoder.fromArrayBuffer(createArrayBuffer(
  23. 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x00));
  24. if (CHECK_CRITICAL_BOUNDS) {
  25. expect(() => bufferDecoder.skipVarint(0)).toThrow();
  26. } else {
  27. // Note in unchecked mode we produce invalid output for invalid inputs.
  28. // This test just documents our behavior in those cases.
  29. // These values might change at any point and are not considered
  30. // what the implementation should be doing here.
  31. expect(bufferDecoder.skipVarint(0)).toBe(11);
  32. }
  33. });
  34. it('fail when varint is beyond end of underlying array', () => {
  35. const bufferDecoder =
  36. BufferDecoder.fromArrayBuffer(createArrayBuffer(0x80, 0x80));
  37. expect(() => bufferDecoder.skipVarint(0)).toThrow();
  38. });
  39. });
  40. describe('readVarint64 does', () => {
  41. it('read zero', () => {
  42. const bufferDecoder =
  43. BufferDecoder.fromArrayBuffer(createArrayBuffer(0x00));
  44. const {dataStart, lowBits, highBits} = bufferDecoder.getVarint(0);
  45. expect(dataStart).toBe(1);
  46. expect(lowBits).toBe(0);
  47. expect(highBits).toBe(0);
  48. });
  49. it('read one', () => {
  50. const bufferDecoder =
  51. BufferDecoder.fromArrayBuffer(createArrayBuffer(0x01));
  52. const {dataStart, lowBits, highBits} = bufferDecoder.getVarint(0);
  53. expect(dataStart).toBe(1);
  54. expect(lowBits).toBe(1);
  55. expect(highBits).toBe(0);
  56. });
  57. it('read max value', () => {
  58. const bufferDecoder = BufferDecoder.fromArrayBuffer(createArrayBuffer(
  59. 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x01));
  60. const {dataStart, lowBits, highBits} = bufferDecoder.getVarint(0);
  61. expect(dataStart).toBe(10);
  62. expect(lowBits).toBe(-1);
  63. expect(highBits).toBe(-1);
  64. });
  65. });
  66. describe('subBufferDecoder does', () => {
  67. it('can create valid sub buffers', () => {
  68. const bufferDecoder =
  69. BufferDecoder.fromArrayBuffer(createArrayBuffer(0x00, 0x01, 0x02));
  70. expect(bufferDecoder.subBufferDecoder(0, 0))
  71. .toEqual(BufferDecoder.fromArrayBuffer(createArrayBuffer()));
  72. expect(bufferDecoder.subBufferDecoder(0, 1))
  73. .toEqual(BufferDecoder.fromArrayBuffer(createArrayBuffer(0x00)));
  74. expect(bufferDecoder.subBufferDecoder(1, 0))
  75. .toEqual(BufferDecoder.fromArrayBuffer(createArrayBuffer()));
  76. expect(bufferDecoder.subBufferDecoder(1, 1))
  77. .toEqual(BufferDecoder.fromArrayBuffer(createArrayBuffer(0x01)));
  78. expect(bufferDecoder.subBufferDecoder(1, 2))
  79. .toEqual(BufferDecoder.fromArrayBuffer(createArrayBuffer(0x01, 0x02)));
  80. });
  81. it('can not create invalid', () => {
  82. const bufferDecoder =
  83. BufferDecoder.fromArrayBuffer(createArrayBuffer(0x00, 0x01, 0x02));
  84. if (CHECK_STATE) {
  85. expect(() => bufferDecoder.subBufferDecoder(-1, 1)).toThrow();
  86. expect(() => bufferDecoder.subBufferDecoder(0, -4)).toThrow();
  87. expect(() => bufferDecoder.subBufferDecoder(0, 4)).toThrow();
  88. }
  89. });
  90. });