mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-25 01:33:56 +02: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
		
	
			
		
			
				
	
	
		
			40 lines
		
	
	
		
			986 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			986 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // Copyright (C) 2013 the V8 project authors. All rights reserved.
 | |
| // This code is governed by the BSD license found in the LICENSE file.
 | |
| /*---
 | |
| es6id: 19.1.2.4
 | |
| description: >
 | |
|     Symbol used as property for configurable data property definition
 | |
| features: [Symbol]
 | |
| includes: [propertyHelper.js]
 | |
| ---*/
 | |
| var sym = Symbol();
 | |
| var obj = {};
 | |
| 
 | |
| 
 | |
| Object.defineProperty(obj, sym, {
 | |
|   value: 1,
 | |
|   configurable: true
 | |
| });
 | |
| 
 | |
| assert.sameValue(sym in obj, true, "The result of `sym in obj` is `true`");
 | |
| verifyProperty(obj, sym, {
 | |
|   value: 1,
 | |
|   configurable: true,
 | |
|   writable: false,
 | |
|   enumerable: false,
 | |
| });
 | |
| 
 | |
| assert.sameValue(
 | |
|   Object.prototype.propertyIsEnumerable.call(obj, sym),
 | |
|   false,
 | |
|   "`Object.prototype.propertyIsEnumerable.call(obj, sym)` returns `false`"
 | |
| );
 | |
| 
 | |
| assert.sameValue(delete obj[sym], true, "The result of `delete obj[sym]` is `true`");
 | |
| 
 | |
| assert.sameValue(
 | |
|   Object.getOwnPropertyDescriptor(obj, sym),
 | |
|   undefined,
 | |
|   "`Object.getOwnPropertyDescriptor(obj, sym)` returns `undefined`"
 | |
| );
 |