OLD | NEW |
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2014, 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=--error_on_bad_type --error_on_bad_override | 4 // VMOptions=--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 'test_helper.dart'; | 7 import 'test_helper.dart'; |
8 | 8 |
9 import 'dart:async'; | 9 import 'dart:async'; |
10 | 10 |
11 void script() { | 11 void script() { |
12 var grow; | 12 var grow; |
13 grow = (int iterations, int size, Duration duration) { | 13 grow = (int iterations, int size, Duration duration) { |
14 if (iterations <= 0) { | 14 if (iterations <= 0) { |
15 return; | 15 return; |
16 } | 16 } |
17 new List<int>(size); | 17 new List<int>(size); |
18 new Timer(duration, () => grow(iterations - 1, size, duration)); | 18 new Timer(duration, () => grow(iterations - 1, size, duration)); |
19 }; | 19 }; |
20 grow(100, 1 << 24, new Duration(seconds: 1)); | 20 grow(100, 1 << 24, new Duration(seconds: 1)); |
21 } | 21 } |
22 | 22 |
23 var tests = [ | 23 var tests = [ |
24 | 24 (Isolate isolate) { |
25 (Isolate isolate) { | 25 Completer completer = new Completer(); |
26 Completer completer = new Completer(); | 26 // Expect at least this many GC events. |
27 // Expect at least this many GC events. | 27 int gcCountdown = 3; |
28 int gcCountdown = 3; | 28 isolate.vm.getEventStream(VM.kGCStream).then((stream) { |
29 isolate.vm.getEventStream(VM.kGCStream).then((stream) { | 29 var subscription; |
30 var subscription; | 30 subscription = stream.listen((ServiceEvent event) { |
31 subscription = stream.listen((ServiceEvent event) { | 31 assert(event.kind == ServiceEvent.kGC); |
32 assert(event.kind == ServiceEvent.kGC); | 32 print('Received GC event'); |
33 print('Received GC event'); | 33 if (--gcCountdown == 0) { |
34 if (--gcCountdown == 0) { | 34 subscription.cancel(); |
35 subscription.cancel(); | 35 completer.complete(); |
36 completer.complete(); | 36 } |
37 } | 37 }); |
38 }); | 38 }); |
39 }); | 39 return completer.future; |
40 return completer.future; | 40 }, |
41 }, | |
42 | |
43 ]; | 41 ]; |
44 | 42 |
45 main(args) => runIsolateTests(args, tests, testeeConcurrent: script); | 43 main(args) => runIsolateTests(args, tests, testeeConcurrent: script); |
OLD | NEW |