2015-12-30 20:15:01 +01:00
|
|
|
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
|
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
/*---
|
|
|
|
description: >
|
|
|
|
Resolving with a non-thenable object value from within the executor function
|
|
|
|
es6id: 25.4.3.1
|
|
|
|
info: >
|
|
|
|
[...]
|
|
|
|
8. Let resolvingFunctions be CreateResolvingFunctions(promise).
|
|
|
|
9. Let completion be Call(executor, undefined,
|
|
|
|
«resolvingFunctions.[[Resolve]], resolvingFunctions.[[Reject]]»).
|
|
|
|
|
|
|
|
25.4.1.3.2 Promise Resolve Functions
|
|
|
|
[...]
|
|
|
|
8. Let then be Get(resolution, "then").
|
|
|
|
9. If then is an abrupt completion, then
|
|
|
|
[...]
|
|
|
|
10. Let thenAction be then.[[value]].
|
|
|
|
11. If IsCallable(thenAction) is false, then
|
|
|
|
a. Return FulfillPromise(promise, resolution).
|
2016-02-12 18:59:51 +01:00
|
|
|
flags: [async]
|
2015-12-30 20:15:01 +01:00
|
|
|
---*/
|
|
|
|
|
2016-06-24 19:04:21 +02:00
|
|
|
var returnValue = null;
|
2015-12-30 20:15:01 +01:00
|
|
|
var nonThenable = { then: null };
|
|
|
|
var promise = new Promise(function(resolve) {
|
2016-06-24 19:04:21 +02:00
|
|
|
returnValue = resolve(nonThenable);
|
2015-12-30 20:15:01 +01:00
|
|
|
});
|
|
|
|
|
2016-06-24 19:04:21 +02:00
|
|
|
assert.sameValue(returnValue, undefined, '"resolve" return value');
|
|
|
|
|
2015-12-30 20:15:01 +01:00
|
|
|
promise.then(function(value) {
|
|
|
|
if (value !== nonThenable) {
|
|
|
|
$DONE('The promise should be fulfilled with the provided value.');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$DONE();
|
|
|
|
}, function() {
|
|
|
|
$DONE('The promise should not be rejected.');
|
|
|
|
});
|