Index: runtime/observatory/tests/service/debugging_test.dart |
diff --git a/runtime/observatory/tests/service/debugging_test.dart b/runtime/observatory/tests/service/debugging_test.dart |
index e99c60b418d69337317c6d9d0d2e2fb4273291d3..a98702169656303aa3aea2a4d29b09a9e907a7f0 100644 |
--- a/runtime/observatory/tests/service/debugging_test.dart |
+++ b/runtime/observatory/tests/service/debugging_test.dart |
@@ -8,23 +8,25 @@ import 'package:unittest/unittest.dart'; |
import 'test_helper.dart'; |
import 'dart:async'; |
-void helper(i) { |
- print(i); |
+int counter = 0; |
+ |
+void periodicTask(_) { |
+ counter++; |
+ counter++; // Line 15. We set our breakpoint here. |
+ counter++; |
+ if (counter % 300 == 0) { |
+ print('counter = $counter'); |
+ } |
} |
-void testFunction() { |
- int i = 0; |
- while (true) { |
- if (++i % 100000000 == 0) { |
- helper(i); // line 18 |
- } |
- } |
+void startTimer() { |
+ new Timer.periodic(const Duration(milliseconds:10), periodicTask); |
} |
var tests = [ |
// Pause |
-(Isolate isolate) { |
+(Isolate isolate) async { |
Completer completer = new Completer(); |
var subscription; |
subscription = isolate.vm.events.stream.listen((ServiceEvent event) { |
@@ -34,11 +36,11 @@ var tests = [ |
} |
}); |
isolate.pause(); |
- return completer.future; |
+ await completer.future; |
}, |
// Resume |
-(Isolate isolate) { |
+(Isolate isolate) async { |
Completer completer = new Completer(); |
var subscription; |
subscription = isolate.vm.events.stream.listen((ServiceEvent event) { |
@@ -48,49 +50,52 @@ var tests = [ |
} |
}); |
isolate.resume(); |
- return completer.future; |
+ await completer.future; |
}, |
// Add breakpoint |
-(Isolate isolate) { |
- return isolate.rootLib.load().then((_) { |
- // Set up a listener to wait for breakpoint events. |
- Completer completer = new Completer(); |
- var subscription; |
- subscription = isolate.vm.events.stream.listen((ServiceEvent event) { |
- if (event.eventType == ServiceEvent.kPauseBreakpoint) { |
- print('Breakpoint reached'); |
- subscription.cancel(); |
- completer.complete(); |
- } |
- }); |
- |
- // Add the breakpoint. |
- var script = isolate.rootLib.scripts[0]; |
- return isolate.addBreakpoint(script, 18).then((result) { |
- expect(result is Breakpoint, isTrue); |
- Breakpoint bpt = result; |
- expect(bpt.type, equals('Breakpoint')); |
- expect(bpt.script.id, equals(script.id)); |
- expect(bpt.tokenPos, equals(58)); |
- expect(isolate.breakpoints.length, equals(1)); |
- return completer.future; // Wait for breakpoint events. |
- }); |
- }); |
-}, |
+(Isolate isolate) async { |
+ await isolate.rootLib.load(); |
-// Get the stack trace |
-(Isolate isolate) { |
- return isolate.getStack().then((ServiceMap stack) { |
- expect(stack.type, equals('Stack')); |
- expect(stack['frames'].length, greaterThanOrEqualTo(1)); |
- expect(stack['frames'][0]['function'].name, equals('testFunction')); |
- expect(stack['frames'][0]['tokenPos'], equals(58)); |
+ // Set up a listener to wait for breakpoint events. |
+ Completer completer = new Completer(); |
+ var subscription; |
+ subscription = isolate.vm.events.stream.listen((ServiceEvent event) { |
+ if (event.eventType == ServiceEvent.kPauseBreakpoint) { |
+ print('Breakpoint reached'); |
+ subscription.cancel(); |
+ completer.complete(); |
+ } |
}); |
+ |
+ var script = isolate.rootLib.scripts[0]; |
+ await script.load(); |
+ |
+ // Add the breakpoint. |
+ var result = await isolate.addBreakpoint(script, 15); |
+ expect(result is Breakpoint, isTrue); |
+ Breakpoint bpt = result; |
+ expect(bpt.type, equals('Breakpoint')); |
+ expect(bpt.script.id, equals(script.id)); |
+ expect(bpt.script.tokenToLine(bpt.tokenPos), equals(15)); |
+ expect(isolate.breakpoints.length, equals(1)); |
+ |
+ await completer.future; // Wait for breakpoint events. |
+}, |
+ |
+// We are at the breakpoint on line 15. |
+(Isolate isolate) async { |
+ ServiceMap stack = await isolate.getStack(); |
+ expect(stack.type, equals('Stack')); |
+ expect(stack['frames'].length, greaterThanOrEqualTo(1)); |
+ |
+ Script script = stack['frames'][0]['script']; |
+ expect(script.name,endsWith('debugging_test.dart')); |
+ expect(script.tokenToLine(stack['frames'][0]['tokenPos']), equals(15)); |
}, |
// Stepping |
-(Isolate isolate) { |
+(Isolate isolate) async { |
// Set up a listener to wait for breakpoint events. |
Completer completer = new Completer(); |
var subscription; |
@@ -102,23 +107,23 @@ var tests = [ |
} |
}); |
- return isolate.stepInto().then((isolate) { |
- return completer.future; // Wait for breakpoint events. |
- }); |
+ await isolate.stepOver(); |
+ await completer.future; // Wait for breakpoint events. |
}, |
-// Get the stack trace again. Our position has updated. |
-(Isolate isolate) { |
- return isolate.getStack().then((ServiceMap stack) { |
- expect(stack.type, equals('Stack')); |
- expect(stack['frames'].length, greaterThanOrEqualTo(2)); |
- expect(stack['frames'][0]['function'].name, equals('testFunction')); |
- expect(stack['frames'][0]['tokenPos'], equals(60)); |
- }); |
+// We are now at line 16. |
+(Isolate isolate) async { |
+ ServiceMap stack = await isolate.getStack(); |
+ expect(stack.type, equals('Stack')); |
+ expect(stack['frames'].length, greaterThanOrEqualTo(1)); |
+ |
+ Script script = stack['frames'][0]['script']; |
+ expect(script.name,endsWith('debugging_test.dart')); |
+ expect(script.tokenToLine(stack['frames'][0]['tokenPos']), equals(16)); |
}, |
// Remove breakpoint |
-(Isolate isolate) { |
+(Isolate isolate) async { |
// Set up a listener to wait for breakpoint events. |
Completer completer = new Completer(); |
var subscription; |
@@ -133,13 +138,12 @@ var tests = [ |
expect(isolate.breakpoints.length, equals(1)); |
var bpt = isolate.breakpoints.values.first; |
- return isolate.removeBreakpoint(bpt).then((_) { |
- return completer.future; |
- }); |
+ await isolate.removeBreakpoint(bpt); |
+ await completer.future; |
}, |
// Resume |
-(Isolate isolate) { |
+(Isolate isolate) async { |
Completer completer = new Completer(); |
var subscription; |
subscription = isolate.vm.events.stream.listen((ServiceEvent event) { |
@@ -149,11 +153,11 @@ var tests = [ |
} |
}); |
isolate.resume(); |
- return completer.future; |
+ await completer.future; |
}, |
// Add breakpoint at function entry |
-(Isolate isolate) { |
+(Isolate isolate) async { |
// Set up a listener to wait for breakpoint events. |
Completer completer = new Completer(); |
var subscription; |
@@ -167,21 +171,32 @@ var tests = [ |
// Find a specific function. |
ServiceFunction function = isolate.rootLib.functions.firstWhere( |
- (f) => f.name == 'helper'); |
+ (f) => f.name == 'periodicTask'); |
expect(function, isNotNull); |
// Add the breakpoint at function entry |
- return isolate.addBreakpointAtEntry(function).then((result) { |
- expect(result is Breakpoint, isTrue); |
- Breakpoint bpt = result; |
- expect(bpt.type, equals('Breakpoint')); |
- expect(bpt.script.name, equals('debugging_test.dart')); |
- expect(bpt.tokenPos, equals(29)); |
- expect(isolate.breakpoints.length, equals(1)); |
- return completer.future; // Wait for breakpoint events. |
- }); |
+ var result = await isolate.addBreakpointAtEntry(function); |
+ expect(result is Breakpoint, isTrue); |
+ Breakpoint bpt = result; |
+ expect(bpt.type, equals('Breakpoint')); |
+ expect(bpt.script.name, equals('debugging_test.dart')); |
+ expect(bpt.script.tokenToLine(bpt.tokenPos), equals(14)); |
+ expect(isolate.breakpoints.length, equals(1)); |
+ |
+ await completer.future; // Wait for breakpoint events. |
+}, |
+ |
+// We are now at line 14. |
+(Isolate isolate) async { |
+ ServiceMap stack = await isolate.getStack(); |
+ expect(stack.type, equals('Stack')); |
+ expect(stack['frames'].length, greaterThanOrEqualTo(1)); |
+ |
+ Script script = stack['frames'][0]['script']; |
+ expect(script.name,endsWith('debugging_test.dart')); |
+ expect(script.tokenToLine(stack['frames'][0]['tokenPos']), equals(14)); |
}, |
]; |
-main(args) => runIsolateTests(args, tests, testeeConcurrent: testFunction); |
+main(args) => runIsolateTests(args, tests, testeeBefore: startTimer); |