mirror of
				https://github.com/tc39/test262.git
				synced 2025-11-03 21:24:30 +01:00 
			
		
		
		
	For asynchronous tests, the contract between test file and test runner
is implicit: runners are expected to inspect the source code for
references to a global `$DONE` identifier.
Promote a more explicit contract between test file and test runner by
introducing a new frontmatter "tag", `async`. This brings asynchronous
test configuration in-line with other configuration mechanisms and also
provides a more natural means of test filtering.
The modifications to test files was made programatically using the
`grep` and `sed` utilities:
    $ grep "\$DONE" test/ -r --files-with-match --null | \
        xargs -0 sed -i 's/^\(flags:\s*\)\[/\1[async, /g'
    $ grep "\$DONE" test/ -rl --null | \
        xargs -0 grep -E '^flags:' --files-without-match --null | \
        xargs -0 sed -i 's/^---\*\//flags: [async]\n---*\//'
		
	
			
		
			
				
	
	
		
			38 lines
		
	
	
		
			944 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			944 B
		
	
	
	
		
			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: Rejecting through immediate invocation of the provided resolving function
 | 
						|
es6id: 25.4.4.1
 | 
						|
info: >
 | 
						|
    [...]
 | 
						|
    6. Let promiseCapability be NewPromiseCapability(C).
 | 
						|
    [...]
 | 
						|
    11. Let result be PerformPromiseAll(iteratorRecord, promiseCapability, C).
 | 
						|
    [...]
 | 
						|
 | 
						|
    25.4.4.1.1 Runtime Semantics: PerformPromiseAll
 | 
						|
    [...]
 | 
						|
    6. Repeat
 | 
						|
       [...]
 | 
						|
       r. Let result be Invoke(nextPromise, "then", resolveElement,
 | 
						|
          promiseCapability.[[Reject]]»).
 | 
						|
 | 
						|
    25.4.1.3.1 Promise Reject Functions
 | 
						|
    [...]
 | 
						|
    6. Return RejectPromise(promise, reason).
 | 
						|
flags: [async]
 | 
						|
---*/
 | 
						|
 | 
						|
var thenable = {
 | 
						|
  then: function(_, reject) {
 | 
						|
    reject();
 | 
						|
  }
 | 
						|
};
 | 
						|
 | 
						|
Promise.all([thenable])
 | 
						|
  .then(function() {
 | 
						|
    $DONE('The promise should not be fulfilled.');
 | 
						|
  }, function(x) {
 | 
						|
    $DONE();
 | 
						|
  });
 |