Chromium Code Reviews| Index: runtime/observatory/tests/service/capture_stdio_test.dart |
| diff --git a/runtime/observatory/tests/service/capture_stdio_test.dart b/runtime/observatory/tests/service/capture_stdio_test.dart |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..a097ec15c37256a01740104917eaa3df1c5dc2df |
| --- /dev/null |
| +++ b/runtime/observatory/tests/service/capture_stdio_test.dart |
| @@ -0,0 +1,89 @@ |
| +// Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file |
| +// for details. All rights reserved. Use of this source code is governed by a |
| +// BSD-style license that can be found in the LICENSE file. |
| +// VMOptions=--compile-all --error_on_bad_type --error_on_bad_override |
| + |
| +import 'package:observatory/service_io.dart'; |
| +import 'package:unittest/unittest.dart'; |
| +import 'test_helper.dart'; |
| +import 'dart:async'; |
|
Cutch
2015/07/13 16:24:54
sort imports
turnidge
2015/07/13 22:50:36
Done.
|
| +import 'dart:developer'; |
| +import 'dart:io'; |
| + |
| +void test() { |
| + debugger(); |
| + stdout.write('stdout'); |
| + |
| + debugger(); |
| + print('print'); |
| + |
| + debugger(); |
| + stderr.write('stderr'); |
| +} |
| + |
| +var tests = [ |
| + hasStoppedAtBreakpoint, |
| + |
| + (Isolate isolate) async { |
| + Completer completer = new Completer(); |
| + var stdoutSub; |
| + stdoutSub = await isolate.vm.listenEventStream( |
| + VM.kStdoutStream, |
| + (ServiceEvent event) { |
| + expect(event.kind, equals('WriteEvent')); |
| + expect(event.bytesAsString, equals('stdout')); |
| + cancelFutureSubscription(stdoutSub).then((_) { |
| + completer.complete(); |
| + }); |
| + }); |
| + await isolate.resume(); |
| + await completer.future; |
| + }, |
| + |
| + hasStoppedAtBreakpoint, |
| + |
| + (Isolate isolate) async { |
| + Completer completer = new Completer(); |
| + var stdoutSub; |
| + int eventNumber = 1; |
| + stdoutSub = await isolate.vm.listenEventStream( |
| + VM.kStdoutStream, |
| + (ServiceEvent event) { |
| + expect(event.kind, equals('WriteEvent')); |
| + if (eventNumber == 1) { |
| + expect(event.bytesAsString, equals('print')); |
| + } else if (eventNumber == 2) { |
| + expect(event.bytesAsString, equals('\n')); |
| + cancelFutureSubscription(stdoutSub).then((_) { |
| + completer.complete(); |
| + }); |
| + } else { |
| + expect(true, false); |
| + } |
| + eventNumber++; |
| + }); |
| + await isolate.resume(); |
| + await completer.future; |
| + }, |
| + |
| + hasStoppedAtBreakpoint, |
| + |
| + (Isolate isolate) async { |
| + Completer completer = new Completer(); |
| + var stderrSub; |
| + stderrSub = await isolate.vm.listenEventStream( |
| + VM.kStderrStream, |
| + (ServiceEvent event) { |
| + expect(event.kind, equals('WriteEvent')); |
| + expect(event.bytesAsString, equals('stderr')); |
| + cancelFutureSubscription(stderrSub).then((_) { |
| + completer.complete(); |
| + }); |
| + }); |
| + await isolate.resume(); |
| + await completer.future; |
| + }, |
| +]; |
| + |
| + |
| +main(args) => runIsolateTests(args, tests, testeeConcurrent: test); |