Bugfix for broken protobuf decoding in case of Uint8List views with non-zero offsets
[email protected]
Review URL: https://chromiumcodereview.appspot.com//885223002
diff --git a/test/coded_buffer_reader_test.dart b/test/coded_buffer_reader_test.dart
index 468681a..7a50002 100755
--- a/test/coded_buffer_reader_test.dart
+++ b/test/coded_buffer_reader_test.dart
@@ -5,6 +5,8 @@
library coded_buffer_reader_tests;
+import 'dart:typed_data';
+
import 'package:protobuf/protobuf.dart';
import 'package:unittest/unittest.dart';
@@ -14,7 +16,7 @@
final throwsInvalidProtocolBufferException =
throwsA(new isInstanceOf<InvalidProtocolBufferException>());
- test('testCodedBufferReader', () {
+ group('testCodedBufferReader', () {
List<int> inputBuffer = <int>[
0xb8, 0x06, 0x20, // 103 int32 = 32
0xc0, 0x06, 0x40, // 104 int64 = 64
@@ -36,46 +38,69 @@
0x6e, 0x61, 0x6c, 0x5f, 0x62, 0x79, 0x74,
0x65, 0x73 // 115 bytes 14 optional_bytes
];
- CodedBufferReader cis = new CodedBufferReader(inputBuffer);
- expect(cis.readTag(), makeTag(103, WIRETYPE_VARINT));
- expect(cis.readInt32(), 32);
+ testWithList(List<int> inputBuffer) {
+ CodedBufferReader cis = new CodedBufferReader(inputBuffer);
- expect(cis.readTag(), makeTag(104, WIRETYPE_VARINT));
- expect(cis.readInt64(), expect64(64));
+ expect(cis.readTag(), makeTag(103, WIRETYPE_VARINT));
+ expect(cis.readInt32(), 32);
- expect(cis.readTag(), makeTag(105, WIRETYPE_VARINT));
- expect(cis.readUint32(), 32);
+ expect(cis.readTag(), makeTag(104, WIRETYPE_VARINT));
+ expect(cis.readInt64(), expect64(64));
- expect(cis.readTag(), makeTag(106, WIRETYPE_VARINT));
- expect(cis.readUint64(), expect64(64));
+ expect(cis.readTag(), makeTag(105, WIRETYPE_VARINT));
+ expect(cis.readUint32(), 32);
- expect(cis.readTag(), makeTag(107, WIRETYPE_VARINT));
- expect(cis.readSint32(), 32);
+ expect(cis.readTag(), makeTag(106, WIRETYPE_VARINT));
+ expect(cis.readUint64(), expect64(64));
- expect(cis.readTag(), makeTag(108, WIRETYPE_VARINT));
- expect(cis.readSint64(), expect64(64));
+ expect(cis.readTag(), makeTag(107, WIRETYPE_VARINT));
+ expect(cis.readSint32(), 32);
- expect(cis.readTag(), makeTag(109, WIRETYPE_FIXED32));
- expect(cis.readFixed32(), 32);
+ expect(cis.readTag(), makeTag(108, WIRETYPE_VARINT));
+ expect(cis.readSint64(), expect64(64));
- expect(cis.readTag(), makeTag(110, WIRETYPE_FIXED64));
- expect(cis.readFixed64(), expect64(64));
+ expect(cis.readTag(), makeTag(109, WIRETYPE_FIXED32));
+ expect(cis.readFixed32(), 32);
- expect(cis.readTag(), makeTag(111, WIRETYPE_FIXED32));
- expect(cis.readSfixed32(), 32);
+ expect(cis.readTag(), makeTag(110, WIRETYPE_FIXED64));
+ expect(cis.readFixed64(), expect64(64));
- expect(cis.readTag(), makeTag(112, WIRETYPE_FIXED64));
- expect(cis.readSfixed64(), expect64(64));
+ expect(cis.readTag(), makeTag(111, WIRETYPE_FIXED32));
+ expect(cis.readSfixed32(), 32);
- expect(cis.readTag(), makeTag(113, WIRETYPE_VARINT));
- expect(cis.readBool(), isTrue);
+ expect(cis.readTag(), makeTag(112, WIRETYPE_FIXED64));
+ expect(cis.readSfixed64(), expect64(64));
- expect(cis.readTag(), makeTag(114, WIRETYPE_LENGTH_DELIMITED));
- expect(cis.readString(), 'optional_string');
+ expect(cis.readTag(), makeTag(113, WIRETYPE_VARINT));
+ expect(cis.readBool(), isTrue);
- expect(cis.readTag(), makeTag(115, WIRETYPE_LENGTH_DELIMITED));
- expect(cis.readBytes(), 'optional_bytes'.codeUnits);
+ expect(cis.readTag(), makeTag(114, WIRETYPE_LENGTH_DELIMITED));
+ expect(cis.readString(), 'optional_string');
+
+ expect(cis.readTag(), makeTag(115, WIRETYPE_LENGTH_DELIMITED));
+ expect(cis.readBytes(), 'optional_bytes'.codeUnits);
+ }
+
+ test('normal-list', () {
+ testWithList(inputBuffer);
+ });
+
+ test('uint8-list', () {
+ var uint8List = new Uint8List.fromList(inputBuffer);
+ testWithList(uint8List);
+ });
+
+ test('uint8-list-view', () {
+ var uint8List = new Uint8List(inputBuffer.length + 4);
+ uint8List[0] = 0xc0;
+ uint8List[1] = 0xc8;
+ uint8List.setRange(2, 2 + inputBuffer.length, inputBuffer);
+ uint8List[inputBuffer.length + 2] = 0xe0;
+ uint8List[inputBuffer.length + 3] = 0xed;
+ var view = new Uint8List.view(uint8List.buffer, 2, inputBuffer.length);
+ testWithList(view);
+ });
});
test('testReadMaliciouslyLargeBlob', () {