mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-26 09:13:54 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // 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).
 | |
| flags: [async]
 | |
| ---*/
 | |
| 
 | |
| var returnValue = null;
 | |
| var nonThenable = {
 | |
|   then: null
 | |
| };
 | |
| var promise = new Promise(function(resolve) {
 | |
|   returnValue = resolve(nonThenable);
 | |
| });
 | |
| 
 | |
| assert.sameValue(returnValue, undefined, '"resolve" return value');
 | |
| 
 | |
| 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.');
 | |
| });
 |