mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-26 17:23:54 +01:00 
			
		
		
		
	While we're at it, use assert() instead of assert.sameValue() for brevity,
if we are not specifically testing that the return value of hasOwnProperty
is the value true or false; and add more informative assertion messages to
help with debugging.
In some cases, the Object.hasOwnProperty.call could be replaced with
verifyProperty(), if the property descriptor was also being verified at
the same time.
This fixes some tests that were faulty to begin with: a common mistake was
Object.hasOwnProperty(obj, prop) which is probably going to return false
when that's not what you want.
The only instances left of `Object.hasOwnProperty` are one regression test
in implementation-contributed which I can't tell if it was intentionally
needed to trigger the regression, and a few instances of
`Object.hasOwnProperty('prototype')` which would defeat the purpose to
convert into `Object.prototype.hasOwnProperty.call(Object, 'prototype')`
form.
Closes: #3524
		
	
			
		
			
				
	
	
		
			30 lines
		
	
	
		
			652 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			652 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // Copyright (c) 2012 Ecma International.  All rights reserved.
 | |
| // This code is governed by the BSD license found in the LICENSE file.
 | |
| 
 | |
| /*---
 | |
| es5id: 15.2.3.6-4-116
 | |
| description: >
 | |
|     Object.defineProperty - 'O' is an Array, test the length property
 | |
|     of 'O' is own data property (15.4.5.1 step 1)
 | |
| includes: [propertyHelper.js]
 | |
| ---*/
 | |
| 
 | |
| var arrObj = [0, 1];
 | |
| Object.defineProperty(arrObj, "1", {
 | |
|   value: 1,
 | |
|   configurable: false
 | |
| });
 | |
| 
 | |
| assert.throws(TypeError, function() {
 | |
|   Object.defineProperty(arrObj, "length", {
 | |
|     value: 1
 | |
|   });
 | |
| });
 | |
| 
 | |
| verifyProperty(arrObj, "length", {
 | |
|   value: 2,
 | |
|   writable: true,
 | |
|   configurable: false,
 | |
|   enumerable: false,
 | |
| });
 |