mirror of
				https://github.com/tc39/test262.git
				synced 2025-11-03 21:24:30 +01:00 
			
		
		
		
	sourceRevisionAtLastExport: 33f2fb0e53d135f0ee17cfccd9d993eb2a6f47de targetRevisionAtLastExport: 31340cbd9add103f586d501b0c3354b7b182abc0
		
			
				
	
	
		
			24 lines
		
	
	
		
			894 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			24 lines
		
	
	
		
			894 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
// Copyright 2017 the V8 project authors. All rights reserved.
 | 
						|
// Use of this source code is governed by a BSD-style license that can be
 | 
						|
// found in the LICENSE file.
 | 
						|
 | 
						|
// Flags: --allow-natives-syntax
 | 
						|
 | 
						|
for (let i = 0; i < 100; i++) {
 | 
						|
  // - length > 2 to trigger sorting.
 | 
						|
  // - key > kRequiresSlowElementsLimit required to set the according bit on the
 | 
						|
  //   dictionary elements store.
 | 
						|
  let key = 1073741800 + i;
 | 
						|
  var a = { length: 12, 1: 0xFA, [key]: 0xFB };
 | 
						|
  %HeapObjectVerify(a);
 | 
						|
  assertEquals(["1", ""+key, "length"], Object.keys(a));
 | 
						|
  // Sort, everything > length is ignored.
 | 
						|
  Array.prototype.sort.call(a);
 | 
						|
  %HeapObjectVerify(a);
 | 
						|
  assertEquals(["0", ""+key, "length"], Object.keys(a));
 | 
						|
  // Sorting again to trigger bug caused by not setting requires_slow_elements
 | 
						|
  Array.prototype.sort.call(a);
 | 
						|
  %HeapObjectVerify(a);
 | 
						|
  assertEquals(["0", ""+key, "length"], Object.keys(a));
 | 
						|
}
 |