import 'package:omemo_dart/protobuf/schema.pb.dart'; import 'package:omemo_dart/src/protobuf/omemo_authenticated_message.dart'; import 'package:omemo_dart/src/protobuf/omemo_key_exchange.dart'; import 'package:omemo_dart/src/protobuf/omemo_message.dart'; import 'package:omemo_dart/src/protobuf/protobuf.dart'; import 'package:test/test.dart'; void main() { group('Base 128 Varints', () { test('Test simple parsing of Varints', () { expect( decodeVarint([1], 0).n, 1, ); expect( decodeVarint([1], 0).length, 1, ); expect( decodeVarint([0x96, 0x01, 0x00], 0).n, 150, ); expect( decodeVarint([0x96, 0x01, 0x00], 0).length, 2, ); expect( decodeVarint([172, 2, 0x8], 0).n, 300, ); expect( decodeVarint([172, 2, 0x8], 0).length, 2, ); }); test('Test encoding Varints', () { expect( encodeVarint(1), [1], ); expect( encodeVarint(150), [0x96, 0x01], ); expect( encodeVarint(300), [172, 2], ); }); }); group('OMEMOMessage', () { test('Decode a OMEMOMessage', () { final pbMessage = OMEMOMessage() ..n = 1 ..pn = 5 ..dhPub = [1, 2, 3] ..ciphertext = [4, 5, 6]; final serial = pbMessage.writeToBuffer(); final msg = OmemoMessage.fromBuffer(serial); expect(msg.n, 1); expect(msg.pn, 5); expect(msg.dhPub, [1, 2, 3]); expect(msg.ciphertext, [4, 5, 6]); }); test('Decode a OMEMOMessage without ciphertext', () { final pbMessage = OMEMOMessage() ..n = 1 ..pn = 5 ..dhPub = [1, 2, 3]; final serial = pbMessage.writeToBuffer(); final msg = OmemoMessage.fromBuffer(serial); expect(msg.n, 1); expect(msg.pn, 5); expect(msg.dhPub, [1, 2, 3]); expect(msg.ciphertext, null); }); test('Encode a OMEMOMessage', () { const m = OmemoMessage( 1, 5, [1, 2, 3], [4, 5, 6], ); final serial = m.writeToBuffer(); final msg = OMEMOMessage.fromBuffer(serial); expect(msg.n, 1); expect(msg.pn, 5); expect(msg.dhPub, [1, 2, 3]); expect(msg.ciphertext, [4, 5, 6]); }); test('Encode a OMEMOMessage without ciphertext', () { const m = OmemoMessage( 1, 5, [1, 2, 3], null, ); final serial = m.writeToBuffer(); final msg = OMEMOMessage.fromBuffer(serial); expect(msg.n, 1); expect(msg.pn, 5); expect(msg.dhPub, [1, 2, 3]); expect(msg.ciphertext, []); }); }); group('OMEMOAuthenticatedMessage', () { test('Test encoding a message', () { const msg = OmemoAuthenticatedMessage([1, 2, 3], [4, 5, 6]); final decoded = OMEMOAuthenticatedMessage.fromBuffer(msg.writeToBuffer()); expect(decoded.mac, [1, 2, 3]); expect(decoded.message, [4, 5, 6]); }); test('Test decoding a message', () { final msg = OMEMOAuthenticatedMessage() ..mac = [1, 2, 3] ..message = [4, 5, 6]; final bytes = msg.writeToBuffer(); final decoded = OmemoAuthenticatedMessage.fromBuffer(bytes); expect(decoded.mac, [1, 2, 3]); expect(decoded.message, [4, 5, 6]); }); }); group('OMEMOKeyExchange', () { test('Test encoding a message', () { const message = OmemoKeyExchange( 698, 245, [1, 4, 6], [4, 6, 7, 80], OmemoAuthenticatedMessage( [5, 6, 8, 0], [4, 5, 7, 3, 2], ), ); final kex = OMEMOKeyExchange.fromBuffer(message.writeToBuffer()); expect(kex.pkId, 698); expect(kex.spkId, 245); expect(kex.ik, [1, 4, 6]); expect(kex.ek, [4, 6, 7, 80]); expect(kex.message.mac, [5, 6, 8, 0]); expect(kex.message.message, [4, 5, 7, 3, 2]); }); test('Test decoding a message', () { final message = OMEMOAuthenticatedMessage() ..mac = [5, 6, 8, 0] ..message = [4, 5, 7, 3, 2]; final kex = OMEMOKeyExchange() ..pkId = 698 ..spkId = 245 ..ik = [1, 4, 6] ..ek = [4, 6, 7, 80] ..message = message; final decoded = OmemoKeyExchange.fromBuffer(kex.writeToBuffer()); expect(decoded.pkId, 698); expect(decoded.spkId, 245); expect(decoded.ik, [1, 4, 6]); expect(decoded.ek, [4 ,6 ,7 , 80]); expect(decoded.message.mac, [5, 6, 8, 0]); expect(decoded.message.message, [4, 5, 7, 3, 2]); }); }); }