Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(136)

Side by Side Diff: runtime/observatory/tests/service/developer_extension_test.dart

Issue 1299493007: Rework service extensions to be safe (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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=--error_on_bad_type --error_on_bad_override 4 // VMOptions=--error_on_bad_type --error_on_bad_override
5 5
6 import 'dart:async'; 6 import 'dart:async';
7 import 'dart:convert'; 7 import 'dart:convert';
8 import 'dart:developer'; 8 import 'dart:developer';
9 import 'package:observatory/service_io.dart'; 9 import 'package:observatory/service_io.dart';
10 import 'package:observatory/cpu_profile.dart'; 10 import 'package:observatory/cpu_profile.dart';
(...skipping 29 matching lines...) Expand all
40 'method': method, 40 'method': method,
41 'parameters': paremeters, 41 'parameters': paremeters,
42 }))); 42 })));
43 case '__null': 43 case '__null':
44 return null; 44 return null;
45 case '__nullFuture': 45 case '__nullFuture':
46 return new Future.value(null); 46 return new Future.value(null);
47 } 47 }
48 } 48 }
49 49
50 Future<ServiceExtensionResponse> LanguageErrorHandler(String method,
51 Map paremeters) {
52 klajsdlkjfad
Ivan Posva 2015/08/26 04:46:59 Please add a comment that you did not just fat-fin
Cutch 2015/08/26 14:28:00 Done.
53 }
54
50 void test() { 55 void test() {
51 registerExtension('__delay', Handler); 56 registerExtension('__delay', Handler);
52 registerExtension('__error', Handler); 57 registerExtension('__error', Handler);
53 registerExtension('__exception', Handler); 58 registerExtension('__exception', Handler);
54 registerExtension('__null', Handler); 59 registerExtension('__null', Handler);
55 registerExtension('__nullFuture', Handler); 60 registerExtension('__nullFuture', Handler);
56 registerExtension('__success', Handler); 61 registerExtension('__success', Handler);
57 bool exceptionThrown = false; 62 bool exceptionThrown = false;
58 try { 63 try {
59 registerExtension('__delay', Handler); 64 registerExtension('__delay', Handler);
60 } catch (e) { 65 } catch (e) {
61 exceptionThrown = true; 66 exceptionThrown = true;
62 } 67 }
63 expect(exceptionThrown, isTrue); 68 expect(exceptionThrown, isTrue);
69 registerExtension('__languageError', LanguageErrorHandler);
64 } 70 }
65 71
66 var tests = [ 72 var tests = [
67 // Initial. 73 // Initial.
68 (Isolate isolate) async { 74 (Isolate isolate) async {
69 var result; 75 var result;
70 76
71 result = await isolate.invokeRpcNoUpgrade('__delay', {}); 77 result = await isolate.invokeRpcNoUpgrade('__delay', {});
72 expect(result['type'], equals('_delayedType')); 78 expect(result['type'], equals('_delayedType'));
73 expect(result['method'], equals('__delay')); 79 expect(result['method'], equals('__delay'));
(...skipping 28 matching lines...) Expand all
102 } 108 }
103 109
104 result = await isolate.invokeRpcNoUpgrade('__success', 110 result = await isolate.invokeRpcNoUpgrade('__success',
105 {'apple': 'banana'}); 111 {'apple': 'banana'});
106 expect(result['type'], equals('_extensionType')); 112 expect(result['type'], equals('_extensionType'));
107 expect(result['method'], equals('__success')); 113 expect(result['method'], equals('__success'));
108 expect(result['parameters']['isolateId'], isNotNull); 114 expect(result['parameters']['isolateId'], isNotNull);
109 expect(result['parameters']['apple'], equals('banana')); 115 expect(result['parameters']['apple'], equals('banana'));
110 116
111 117
118 try {
119 result = await isolate.invokeRpcNoUpgrade('__languageError', {});
120 } on ServerRpcException catch (e, st) {
121 expect(e.code, equals(ServiceExtensionResponse.kExtensionError));
122 expect(e.message, stringContainsInOrder([
123 'Error in extension `__languageError`:',
124 'developer_extension_test.dart',
125 'semicolon expected']));
126 }
127
112 }, 128 },
113 ]; 129 ];
114 130
115 main(args) async => runIsolateTests(args, tests, testeeBefore:test); 131 main(args) async => runIsolateTests(args, tests, testeeBefore:test);
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698