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=--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 '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 |
25 (Isolate isolate) { | 25 (Isolate isolate) { |
26 Completer completer = new Completer(); | 26 Completer completer = new Completer(); |
27 // Expect at least this many GC events. | 27 // Expect at least this many GC events. |
28 int gcCountdown = 3; | 28 int gcCountdown = 3; |
29 isolate.vm.events.stream.listen((ServiceEvent event) { | 29 isolate.vm.events.stream.listen((ServiceEvent event) { |
30 if (event.eventType == ServiceEvent.kGC) { | 30 if (event.kind == ServiceEvent.kGC) { |
31 print('Received GC event'); | 31 print('Received GC event'); |
32 if (--gcCountdown == 0) { | 32 if (--gcCountdown == 0) { |
33 completer.complete(); | 33 completer.complete(); |
34 } | 34 } |
35 } | 35 } |
36 }); | 36 }); |
37 return completer.future; | 37 return completer.future; |
38 }, | 38 }, |
39 | 39 |
40 ]; | 40 ]; |
41 | 41 |
42 main(args) => runIsolateTests(args, tests, testeeConcurrent: script); | 42 main(args) => runIsolateTests(args, tests, testeeConcurrent: script); |
OLD | NEW |