blob: 38ca1f6bca139fad01791c1db539f73004d77cd6 [file] [log] [blame]
// Copyright (c) 2016, 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.
// @dart = 2.9
/// @assertion Future<Isolate> spawn(void entryPoint(message), message,
/// {bool paused: false, bool errorsAreFatal, SendPort onExit, SendPort onError})
///
/// The argument entryPoint specifies the entry point of the spawned isolate.
/// It must be a top-level function or a static method that takes one argument -
/// that is, one-parameter functions that can be compile-time constant function
/// values. It is not allowed to pass the value of function expressions or
/// an instance method extracted from an object.
///
/// The entry-point function is invoked with the initial message. Usually
/// the initial message contains a SendPort so that the spawner and spawnee can
/// communicate with each other.
/// ...
/// Returns a future that will complete with an Isolate instance if
/// the spawning succeeded. It will complete with an error otherwise.
///
/// @description Checks that if entryPoint is some integer value, then type error
/// is arisen in checked mode or returned Future instance completes with error
/// otherwise
/// @author a.semenov@unipro.ru
import "dart:isolate";
import "../../../Utils/expect.dart";
main() {
asyncStart();
try {
Isolate.spawn(1, "hello").then( /// compile error
// ^
// [analyzer] unspecified
// [cfe] unspecified
(v) {
Expect.fail("1, 'hello') is expected to fail");
},
onError: (e) {
Expect.fail("Future completed with error: $e");
asyncEnd();
}
);
} catch (e) {
print("Caught an error: $e");
asyncEnd();
}
}