From 56cbc61e42761d5b4867d75b70241e04b276a5cf Mon Sep 17 00:00:00 2001 From: Alexey Shvayka Date: Thu, 23 Apr 2020 14:39:34 +0300 Subject: [PATCH] Add Object.getOwnPropertyDescriptors test --- .../proxy-no-ownkeys-returned-keys-order.js | 51 +++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 test/built-ins/Object/getOwnPropertyDescriptors/proxy-no-ownkeys-returned-keys-order.js diff --git a/test/built-ins/Object/getOwnPropertyDescriptors/proxy-no-ownkeys-returned-keys-order.js b/test/built-ins/Object/getOwnPropertyDescriptors/proxy-no-ownkeys-returned-keys-order.js new file mode 100644 index 0000000000..c067ca5c47 --- /dev/null +++ b/test/built-ins/Object/getOwnPropertyDescriptors/proxy-no-ownkeys-returned-keys-order.js @@ -0,0 +1,51 @@ +// Copyright (C) 2020 Alexey Shvayka. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-object.getownpropertydescriptors +description: > + If Proxy "ownKeys" trap is missing, keys are sorted by type in ascending + chronological order. +info: | + Object.getOwnPropertyDescriptors ( O ) + + [...] + 2. Let ownKeys be ? obj.[[OwnPropertyKeys]](). + [...] + 4. For each element key of ownKeys in List order, do + a. Let desc be ? obj.[[GetOwnProperty]](key). + + [[OwnPropertyKeys]] ( ) + + [...] + 6. If trap is undefined, then + a. Return ? target.[[OwnPropertyKeys]](). + + OrdinaryOwnPropertyKeys ( O ) + + [...] + 3. For each own property key P of O such that Type(P) is String and P is + not an array index, in ascending chronological order of property creation, do + a. Add P as the last element of keys. + 4. For each own property key P of O such that Type(P) is Symbol, + in ascending chronological order of property creation, do + a. Add P as the last element of keys. + 5. Return keys. +features: [Proxy, Symbol] +includes: [compareArray.js] +---*/ + +var target = {}; +var sym = Symbol(); +target[sym] = 1; +target.foo = 2; +target[0] = 3; + +var getOwnKeys = []; +var proxy = new Proxy(target, { + getOwnPropertyDescriptor: function(_target, key) { + getOwnKeys.push(key); + }, +}); + +Object.getOwnPropertyDescriptors(proxy); +assert.compareArray(getOwnKeys, ["0", "foo", sym]);