| 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 | 10 |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 57 | 57 |
| 58 var subscription; | 58 var subscription; |
| 59 subscription = isolate.vm.events.stream.listen((ServiceEvent event) { | 59 subscription = isolate.vm.events.stream.listen((ServiceEvent event) { |
| 60 if (event.eventType == ServiceEvent.kPauseBreakpoint) { | 60 if (event.eventType == ServiceEvent.kPauseBreakpoint) { |
| 61 print("Hit breakpoint ${event.breakpoint}"); | 61 print("Hit breakpoint ${event.breakpoint}"); |
| 62 breaksHit++; | 62 breaksHit++; |
| 63 isolate.resume(); | 63 isolate.resume(); |
| 64 } | 64 } |
| 65 }); | 65 }); |
| 66 | 66 |
| 67 valueOfField(String name) { | 67 valueOfField(String name) async { |
| 68 return rootLib.variables.singleWhere((v) => v.name == name).value; | 68 var field = rootLib.variables.singleWhere((v) => v.name == name); |
| 69 await field.load(); |
| 70 return field.staticValue; |
| 71 |
| 69 } | 72 } |
| 70 var r1Ref = valueOfField('r1'); | 73 var r1Ref = await valueOfField('r1'); |
| 71 var r2Ref = valueOfField('r2'); | 74 var r2Ref = await valueOfField('r2'); |
| 72 var r3Ref = valueOfField('r3'); | 75 var r3Ref = await valueOfField('r3'); |
| 73 | 76 |
| 74 var bpt1 = await isolate.addBreakOnActivation(r1Ref); | 77 var bpt1 = await isolate.addBreakOnActivation(r1Ref); |
| 75 print("Added breakpoint $bpt1"); | 78 print("Added breakpoint $bpt1"); |
| 76 expect(bpt1 is Breakpoint, isTrue); | 79 expect(bpt1 is Breakpoint, isTrue); |
| 77 expect(breaksHit, equals(0)); | 80 expect(breaksHit, equals(0)); |
| 78 print("testeeDo()"); | 81 print("testeeDo()"); |
| 79 var res = await rootLib.evaluate("testeeDo()"); | 82 var res = await rootLib.evaluate("testeeDo()"); |
| 80 expect(res is Instance, isTrue); // Not error. | 83 expect(res is Instance, isTrue); // Not error. |
| 81 expect(breaksHit, equals(1)); | 84 expect(breaksHit, equals(1)); |
| 82 | 85 |
| (...skipping 14 matching lines...) Expand all Loading... |
| 97 | 100 |
| 98 var subscription; | 101 var subscription; |
| 99 subscription = isolate.vm.events.stream.listen((ServiceEvent event) { | 102 subscription = isolate.vm.events.stream.listen((ServiceEvent event) { |
| 100 if (event.eventType == ServiceEvent.kPauseBreakpoint) { | 103 if (event.eventType == ServiceEvent.kPauseBreakpoint) { |
| 101 print("Hit breakpoint ${event.breakpoint}"); | 104 print("Hit breakpoint ${event.breakpoint}"); |
| 102 breaksHit++; | 105 breaksHit++; |
| 103 isolate.resume(); | 106 isolate.resume(); |
| 104 } | 107 } |
| 105 }); | 108 }); |
| 106 | 109 |
| 107 valueOfField(String name) { | 110 valueOfField(String name) async { |
| 108 return rootLib.variables.singleWhere((v) => v.name == name).value; | 111 var field = rootLib.variables.singleWhere((v) => v.name == name); |
| 112 await field.load(); |
| 113 return field.staticValue; |
| 109 } | 114 } |
| 110 var r1Ref = valueOfField('r1_named'); | 115 var r1Ref = await valueOfField('r1_named'); |
| 111 var r2Ref = valueOfField('r2_named'); | 116 var r2Ref = await valueOfField('r2_named'); |
| 112 var r3Ref = valueOfField('r3_named'); | 117 var r3Ref = await valueOfField('r3_named'); |
| 113 | 118 |
| 114 var bpt1 = await isolate.addBreakOnActivation(r1Ref); | 119 var bpt1 = await isolate.addBreakOnActivation(r1Ref); |
| 115 print("Added breakpoint $bpt1"); | 120 print("Added breakpoint $bpt1"); |
| 116 expect(bpt1 is Breakpoint, isTrue); | 121 expect(bpt1 is Breakpoint, isTrue); |
| 117 expect(breaksHit, equals(0)); | 122 expect(breaksHit, equals(0)); |
| 118 print("testeeDoNamed()"); | 123 print("testeeDoNamed()"); |
| 119 var res = await rootLib.evaluate("testeeDoNamed()"); | 124 var res = await rootLib.evaluate("testeeDoNamed()"); |
| 120 expect(res is Instance, isTrue); // Not error. | 125 expect(res is Instance, isTrue); // Not error. |
| 121 expect(breaksHit, equals(1)); | 126 expect(breaksHit, equals(1)); |
| 122 | 127 |
| (...skipping 14 matching lines...) Expand all Loading... |
| 137 | 142 |
| 138 var subscription; | 143 var subscription; |
| 139 subscription = isolate.vm.events.stream.listen((ServiceEvent event) { | 144 subscription = isolate.vm.events.stream.listen((ServiceEvent event) { |
| 140 if (event.eventType == ServiceEvent.kPauseBreakpoint) { | 145 if (event.eventType == ServiceEvent.kPauseBreakpoint) { |
| 141 print("Hit breakpoint ${event.breakpoint}"); | 146 print("Hit breakpoint ${event.breakpoint}"); |
| 142 breaksHit++; | 147 breaksHit++; |
| 143 isolate.resume(); | 148 isolate.resume(); |
| 144 } | 149 } |
| 145 }); | 150 }); |
| 146 | 151 |
| 147 valueOfField(String name) { | 152 valueOfField(String name) async { |
| 148 return rootLib.variables.singleWhere((v) => v.name == name).value; | 153 var field = rootLib.variables.singleWhere((v) => v.name == name); |
| 154 await field.load(); |
| 155 return field.staticValue; |
| 149 } | 156 } |
| 150 var r1Ref = valueOfField('r1'); | 157 var r1Ref = await valueOfField('r1'); |
| 151 var r2Ref = valueOfField('r2'); | 158 var r2Ref = await valueOfField('r2'); |
| 152 var r3Ref = valueOfField('r3'); | 159 var r3Ref = await valueOfField('r3'); |
| 153 | 160 |
| 154 var bpt1 = await isolate.addBreakOnActivation(r1Ref); | 161 var bpt1 = await isolate.addBreakOnActivation(r1Ref); |
| 155 print("Added breakpoint $bpt1"); | 162 print("Added breakpoint $bpt1"); |
| 156 expect(bpt1 is Breakpoint, isTrue); | 163 expect(bpt1 is Breakpoint, isTrue); |
| 157 expect(breaksHit, equals(0)); | 164 expect(breaksHit, equals(0)); |
| 158 print("testeeDo()"); | 165 print("testeeDo()"); |
| 159 var res = await rootLib.evaluate("testeeDo()"); | 166 var res = await rootLib.evaluate("testeeDo()"); |
| 160 expect(res is Instance, isTrue); // Not error. | 167 expect(res is Instance, isTrue); // Not error. |
| 161 expect(breaksHit, equals(1)); | 168 expect(breaksHit, equals(1)); |
| 162 | 169 |
| (...skipping 19 matching lines...) Expand all Loading... |
| 182 res = await rootLib.evaluate("testeeDo()"); | 189 res = await rootLib.evaluate("testeeDo()"); |
| 183 expect(res is Instance, isTrue); // Not error. | 190 expect(res is Instance, isTrue); // Not error. |
| 184 expect(breaksHit, equals(4)); | 191 expect(breaksHit, equals(4)); |
| 185 | 192 |
| 186 await subscription.cancel(); | 193 await subscription.cancel(); |
| 187 }, | 194 }, |
| 188 | 195 |
| 189 ]; | 196 ]; |
| 190 | 197 |
| 191 main(args) => runIsolateTests(args, tests, testeeBefore: testeeSetup); | 198 main(args) => runIsolateTests(args, tests, testeeBefore: testeeSetup); |
| OLD | NEW |