blob: 6ad04b96206d56930d493abe8f2bf2e992c7f815 [file] [log] [blame]
// Copyright (c) 2011, 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.
/// @assertion Future then(dynamic onValue(T value), {Function onError})
/// Register callbacks to be called when this future completes.
/// When this future completes with a value, the onValue callback will be
/// called with that value. If this future is already completed, the callback
/// will not be called immediately, but will be scheduled in a later microtask.
/// . . .
/// Returns a new Future which is completed with the result of the call to
/// onValue (if this future completes with a value) or to onError (if this
/// future completes with an error).
/// @description Checks that [onValue] is called when a future is complete.
/// @author msyabro
import "dart:async";
import "../../../Utils/expect.dart";
void check(Object value) {
Completer completer = new Completer();
Future f = completer.future;
asyncStart();
f.then((_) {
Expect.isTrue(completer.isCompleted);
asyncEnd();
});
completer.complete(value);
}
main() {
check(0);
check('');
check(false);
check([]);
check(new Object());
check(new Exception());
}