mirror of https://github.com/tc39/test262.git
36 lines
1.2 KiB
JavaScript
36 lines
1.2 KiB
JavaScript
// Copyright (c) 2012 Ecma International. All rights reserved.
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
/*---
|
|
info: >
|
|
Step 4 of defineProperty calls the [[DefineOwnProperty]] internal method
|
|
of O to define the property. For configurable properties, step 9b of
|
|
[[DefineOwnProperty]] permits changing the kind of a property.
|
|
es5id: 15.2.3.6-4-14
|
|
description: >
|
|
Object.defineProperty permits changing data property to accessor
|
|
property for configurable properties
|
|
---*/
|
|
|
|
var o = {};
|
|
|
|
// create a data property. In this case,
|
|
// [[Enumerable]] and [[Configurable]] are true
|
|
o["foo"] = 101;
|
|
|
|
// changing "foo" to be an accessor should succeed, since [[Configurable]]
|
|
// on the original property will be true. Existing values of [[Configurable]]
|
|
// and [[Enumerable]] need to be preserved and the rest need to be set to
|
|
// their default values
|
|
|
|
// dummy getter
|
|
var getter = function () { return 1; }
|
|
var d1 = { get: getter };
|
|
Object.defineProperty(o, "foo", d1);
|
|
|
|
var d2 = Object.getOwnPropertyDescriptor(o, "foo");
|
|
|
|
assert.sameValue(d2.get, getter, 'd2.get');
|
|
assert.sameValue(d2.enumerable, true, 'd2.enumerable');
|
|
assert.sameValue(d2.configurable, true, 'd2.configurable');
|