| // Copyright 2018 The Fuchsia Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| import 'dart:convert'; |
| import 'dart:typed_data'; |
| |
| import 'package:lib.app.dart/logging.dart'; |
| import 'package:mockito/mockito.dart'; |
| import 'package:test/test.dart'; |
| import 'package:zircon/zircon.dart'; |
| |
| import 'socket_validate.dart'; |
| |
| class MockSocket extends Mock implements Socket {} |
| |
| void main() { |
| test('_testlogToSocket', _testlogToSocket); |
| } |
| |
| void _testlogToSocket() { |
| MockSocket mockSocket = MockSocket(); |
| setupLogger( |
| name: 'TEST', |
| forceShowCodeLocation: false, |
| logSocket: mockSocket, |
| ); |
| log.info('foo'); |
| |
| ByteData byteData = verify(mockSocket.write(captureAny)).captured.single; |
| List<int> logged = byteData.buffer.asInt8List(0, byteData.lengthInBytes); |
| validateFixedBlock(logged, 0); |
| expect(logged[32], equals(4)); |
| expect(utf8.decode(logged.sublist(33, 37)), equals('TEST')); |
| expect(utf8.decode(logged.sublist(38, 41)), equals('foo')); |
| expect(logged[41], equals(0)); |
| // Length should be 33 + 5 (TEST) + 4 (foo) |
| expect(logged.length, equals(42)); |
| |
| mockSocket.close(); |
| } |