| // Copyright 2017 The Chromium 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:async'; |
| import 'package:flutter_tools/src/device.dart'; |
| import 'package:flutter_tools/src/resident_runner.dart'; |
| import 'package:mockito/mockito.dart'; |
| |
| import 'src/common.dart'; |
| import 'src/context.dart'; |
| |
| class TestRunner extends ResidentRunner { |
| TestRunner(List<FlutterDevice> devices) |
| : super(devices); |
| |
| bool hasHelpBeenPrinted = false; |
| String receivedCommand; |
| |
| @override |
| Future<void> cleanupAfterSignal() async { } |
| |
| @override |
| Future<void> cleanupAtFinish() async { } |
| |
| @override |
| Future<void> handleTerminalCommand(String code) async { |
| receivedCommand = code; |
| } |
| |
| @override |
| void printHelp({ bool details }) { |
| hasHelpBeenPrinted = true; |
| } |
| |
| @override |
| Future<int> run({ |
| Completer<DebugConnectionInfo> connectionInfoCompleter, |
| Completer<void> appStartedCompleter, |
| String route, |
| bool shouldBuild = true, |
| }) async => null; |
| |
| @override |
| Future<int> attach({ |
| Completer<DebugConnectionInfo> connectionInfoCompleter, |
| Completer<void> appStartedCompleter, |
| }) async => null; |
| } |
| |
| void main() { |
| TestRunner createTestRunner() { |
| // TODO(jacobr): make these tests run with `trackWidgetCreation: true` as |
| // well as the default flags. |
| return TestRunner( |
| <FlutterDevice>[FlutterDevice(MockDevice(), trackWidgetCreation: false)], |
| ); |
| } |
| |
| group('keyboard input handling', () { |
| testUsingContext('single help character', () async { |
| final TestRunner testRunner = createTestRunner(); |
| expect(testRunner.hasHelpBeenPrinted, isFalse); |
| await testRunner.processTerminalInput('h'); |
| expect(testRunner.hasHelpBeenPrinted, isTrue); |
| }); |
| testUsingContext('help character surrounded with newlines', () async { |
| final TestRunner testRunner = createTestRunner(); |
| expect(testRunner.hasHelpBeenPrinted, isFalse); |
| await testRunner.processTerminalInput('\nh\n'); |
| expect(testRunner.hasHelpBeenPrinted, isTrue); |
| }); |
| testUsingContext('reload character with trailing newline', () async { |
| final TestRunner testRunner = createTestRunner(); |
| expect(testRunner.receivedCommand, isNull); |
| await testRunner.processTerminalInput('r\n'); |
| expect(testRunner.receivedCommand, equals('r')); |
| }); |
| testUsingContext('newlines', () async { |
| final TestRunner testRunner = createTestRunner(); |
| expect(testRunner.receivedCommand, isNull); |
| await testRunner.processTerminalInput('\n\n'); |
| expect(testRunner.receivedCommand, equals('')); |
| }); |
| }); |
| } |
| |
| class MockDevice extends Mock implements Device { |
| MockDevice() { |
| when(isSupported()).thenReturn(true); |
| } |
| } |