OLD | NEW |
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 // VMOptions=--compile-all --error_on_bad_type --error_on_bad_override | 4 // VMOptions=--compile-all --error_on_bad_type --error_on_bad_override |
5 | 5 |
6 import 'package:observatory/service_io.dart'; | 6 import 'package:observatory/service_io.dart'; |
7 import 'package:unittest/unittest.dart'; | 7 import 'package:unittest/unittest.dart'; |
8 import 'test_helper.dart'; | 8 import 'test_helper.dart'; |
9 import 'dart:async'; | 9 import 'dart:async'; |
10 import 'dart:isolate' as isolate; | 10 import 'dart:isolate' as isolate; |
11 import 'dart:debugger' as debugger; | 11 import 'dart:developer' as developer; |
12 | 12 |
13 int counter = 0; | 13 int counter = 0; |
14 const stoppedAtLine = 23; | 14 const stoppedAtLine = 23; |
15 var port = new isolate.RawReceivePort(msgHandler); | 15 var port = new isolate.RawReceivePort(msgHandler); |
16 | 16 |
17 // This name is used in a test below. | 17 // This name is used in a test below. |
18 void msgHandler(_) { } | 18 void msgHandler(_) { } |
19 | 19 |
20 void periodicTask(_) { | 20 void periodicTask(_) { |
21 port.sendPort.send(34); | 21 port.sendPort.send(34); |
22 debugger.Debugger.breakHere(); // We will be at a breakpoint at the next line. | 22 developer.debugger(msg: "foo", when: true); // We will be at the next line. |
23 counter++; | 23 counter++; |
24 if (counter % 300 == 0) { | 24 if (counter % 300 == 0) { |
25 print('counter = $counter'); | 25 print('counter = $counter'); |
26 } | 26 } |
27 } | 27 } |
28 | 28 |
29 void startTimer() { | 29 void startTimer() { |
30 new Timer.periodic(const Duration(milliseconds:10), periodicTask); | 30 new Timer.periodic(const Duration(milliseconds:10), periodicTask); |
31 } | 31 } |
32 | 32 |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
88 expect(msgHandlerObjectId, isNotNull); | 88 expect(msgHandlerObjectId, isNotNull); |
89 | 89 |
90 // Get object. | 90 // Get object. |
91 var object = await isolate.getObject(msgHandlerObjectId); | 91 var object = await isolate.getObject(msgHandlerObjectId); |
92 expect(object.valueAsString, equals('34')); | 92 expect(object.valueAsString, equals('34')); |
93 } | 93 } |
94 | 94 |
95 ]; | 95 ]; |
96 | 96 |
97 main(args) => runIsolateTests(args, tests, testeeBefore: startTimer); | 97 main(args) => runIsolateTests(args, tests, testeeBefore: startTimer); |
OLD | NEW |