Chromium Code Reviews| Index: tests/isolate/issue_21398_parent_isolate2_test.dart |
| =================================================================== |
| --- tests/isolate/issue_21398_parent_isolate2_test.dart (revision 0) |
| +++ tests/isolate/issue_21398_parent_isolate2_test.dart (working copy) |
| @@ -0,0 +1,49 @@ |
| +// Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file |
| +// for details. All rights reserved. Use of this source code is governed by a |
| +// BSD-style license that can be found in the LICENSE file. |
| + |
| +import 'dart:isolate'; |
| +import 'dart:async'; |
| +import "package:expect/expect.dart"; |
| + |
| +import "deferred_loaded_lib.dart" deferred as lib; |
| + |
| +// In this test case we send an object created from a deferred library |
| +// that is loaded in the child isolate but not the parent isolate. The |
| +// parent isolate does not know about the type of this object and throws |
| +// an unhandled exception. |
| +funcChild(args) { |
| + var replyPort = args[0]; |
| + // Deferred load a library, create an object from that library and send |
| + // it over to the parent isolate which has not yet loaded that library. |
| + lib.loadLibrary().then((_) { |
| + replyPort.send(new lib.FromChildIsolate()); |
| + }); |
| +} |
| + |
| +void helperFunction() { |
| + var receivePort = new ReceivePort(); |
| + |
| + // Spawn an isolate using spawnFunction. |
| + Isolate.spawn(funcChild, [receivePort.sendPort]).then( |
| + (isolate) { |
| + receivePort.listen( |
| + (msg) { |
| + // We don't expect to receive any valid messages. |
| + Expect.fail("We don't expect to receive any valid messages"); |
| + receivePort.close(); |
| + }, |
| + onError: (e) { |
| + // We don't expect to receive any error messages, per spec listen |
| + // does not receive an error object. |
| + Expect.fail("We don't expect to receive any error messages"); |
| + receivePort.close(); |
| + } |
| + ); |
| + } |
| + ); |
| +} |
| + |
| +main() { |
| + helperFunction(); /// 01: runtime error |
|
ahe
2017/04/06 15:38:18
Why is this a multi-test?
siva
2017/04/06 18:15:42
It doesn't have to be, I think I did this way so i
ahe
2017/04/07 06:14:17
Which runtime error is expected, the one one line
|
| +} |