mirror of
https://github.com/tc39/test262.git
synced 2025-07-22 13:34:38 +02:00
Move proxy function proxy tests into own file
Signed-off-by: Rick Waldron <waldron.rick@gmail.com>
This commit is contained in:
parent
ba93cfa52d
commit
72e7cd699f
40
test/built-ins/Object/prototype/toString/proxy-array.js
vendored
Normal file
40
test/built-ins/Object/prototype/toString/proxy-array.js
vendored
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
/*---
|
||||||
|
esid: sec-object.prototype.tostring
|
||||||
|
es6id: 19.1.3.6
|
||||||
|
description: Proxy of an array is treated as an array
|
||||||
|
info: |
|
||||||
|
[...]
|
||||||
|
3. Let O be ToObject(this value).
|
||||||
|
4. Let isArray be ? IsArray(O).
|
||||||
|
5. If isArray is true, let builtinTag be "Array".
|
||||||
|
[...]
|
||||||
|
|
||||||
|
7.2.2 IsArray
|
||||||
|
|
||||||
|
[...]
|
||||||
|
3. If argument is a Proxy exotic object, then
|
||||||
|
a. If the value of the [[ProxyHandler]] internal slot of argument is null,
|
||||||
|
throw a TypeError exception.
|
||||||
|
b. Let target be the value of the [[ProxyTarget]] internal slot of
|
||||||
|
argument.
|
||||||
|
c. Return ? IsArray(target).
|
||||||
|
features: [Proxy]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var objectProxy = new Proxy({}, {});
|
||||||
|
var arrayProxy = new Proxy([], {});
|
||||||
|
var arrayProxyProxy = new Proxy(arrayProxy, {});
|
||||||
|
|
||||||
|
assert.sameValue(
|
||||||
|
Object.prototype.toString.call(objectProxy), '[object Object]'
|
||||||
|
);
|
||||||
|
assert.sameValue(
|
||||||
|
Object.prototype.toString.call(arrayProxy), '[object Array]', 'array proxy'
|
||||||
|
);
|
||||||
|
assert.sameValue(
|
||||||
|
Object.prototype.toString.call(arrayProxyProxy),
|
||||||
|
'[object Array]',
|
||||||
|
'proxy for array proxy'
|
||||||
|
);
|
@ -1,26 +1,11 @@
|
|||||||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
|
||||||
// Copyright (C) 2016 the Apple Inc. All rights reserved.
|
// Copyright (C) 2016 the Apple Inc. All rights reserved.
|
||||||
// This code is governed by the BSD license found in the LICENSE file.
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
/*---
|
/*---
|
||||||
esid: sec-object.prototype.tostring
|
esid: sec-object.prototype.tostring
|
||||||
es6id: 19.1.3.6
|
es6id: 19.1.3.6
|
||||||
description: Proxy of an array/function is treated as an array/function
|
description: Proxy of an function is treated as an function
|
||||||
info: |
|
info: |
|
||||||
[...]
|
[...]
|
||||||
3. Let O be ToObject(this value).
|
|
||||||
4. Let isArray be ? IsArray(O).
|
|
||||||
5. If isArray is true, let builtinTag be "Array".
|
|
||||||
[...]
|
|
||||||
|
|
||||||
7.2.2 IsArray
|
|
||||||
|
|
||||||
[...]
|
|
||||||
3. If argument is a Proxy exotic object, then
|
|
||||||
a. If the value of the [[ProxyHandler]] internal slot of argument is null,
|
|
||||||
throw a TypeError exception.
|
|
||||||
b. Let target be the value of the [[ProxyTarget]] internal slot of
|
|
||||||
argument.
|
|
||||||
c. Return ? IsArray(target).
|
|
||||||
|
|
||||||
9.5.14 ProxyCreate(target, handler)
|
9.5.14 ProxyCreate(target, handler)
|
||||||
|
|
||||||
@ -32,23 +17,7 @@ info: |
|
|||||||
features: [Proxy]
|
features: [Proxy]
|
||||||
---*/
|
---*/
|
||||||
|
|
||||||
var objectProxy = new Proxy({}, {});
|
var functionProxy = new Proxy(function() {}, {});
|
||||||
var arrayProxy = new Proxy([], {});
|
|
||||||
var arrayProxyProxy = new Proxy(arrayProxy, {});
|
|
||||||
|
|
||||||
assert.sameValue(
|
|
||||||
Object.prototype.toString.call(objectProxy), '[object Object]'
|
|
||||||
);
|
|
||||||
assert.sameValue(
|
|
||||||
Object.prototype.toString.call(arrayProxy), '[object Array]', 'array proxy'
|
|
||||||
);
|
|
||||||
assert.sameValue(
|
|
||||||
Object.prototype.toString.call(arrayProxyProxy),
|
|
||||||
'[object Array]',
|
|
||||||
'proxy for array proxy'
|
|
||||||
);
|
|
||||||
|
|
||||||
var functionProxy = new Proxy(function() { }, {});
|
|
||||||
var functionProxyProxy = new Proxy(functionProxy, {});
|
var functionProxyProxy = new Proxy(functionProxy, {});
|
||||||
|
|
||||||
assert.sameValue(
|
assert.sameValue(
|
||||||
@ -60,7 +29,7 @@ assert.sameValue(
|
|||||||
'proxy for function proxy'
|
'proxy for function proxy'
|
||||||
);
|
);
|
||||||
|
|
||||||
var arrowProxy = new Proxy(() => { }, {});
|
var arrowProxy = new Proxy(() => {}, {});
|
||||||
var arrowProxyProxy = new Proxy(arrowProxy, {});
|
var arrowProxyProxy = new Proxy(arrowProxy, {});
|
||||||
|
|
||||||
assert.sameValue(
|
assert.sameValue(
|
||||||
@ -72,7 +41,7 @@ assert.sameValue(
|
|||||||
'proxy for arrow function proxy'
|
'proxy for arrow function proxy'
|
||||||
);
|
);
|
||||||
|
|
||||||
var generatorProxy = new Proxy(function*() { }, {});
|
var generatorProxy = new Proxy(function*() {}, {});
|
||||||
var generatorProxyProxy = new Proxy(generatorProxy, {});
|
var generatorProxyProxy = new Proxy(generatorProxy, {});
|
||||||
|
|
||||||
assert.sameValue(
|
assert.sameValue(
|
||||||
@ -84,7 +53,7 @@ assert.sameValue(
|
|||||||
'proxy for generator function proxy'
|
'proxy for generator function proxy'
|
||||||
);
|
);
|
||||||
|
|
||||||
delete generatorProxy.__proto__[Symbol.toStringTag];
|
delete generatorProxy.constructor.prototype[Symbol.toStringTag];
|
||||||
|
|
||||||
assert.sameValue(
|
assert.sameValue(
|
||||||
Object.prototype.toString.call(generatorProxy), '[object Function]', 'generator function proxy without Symbol.toStringTag'
|
Object.prototype.toString.call(generatorProxy), '[object Function]', 'generator function proxy without Symbol.toStringTag'
|
Loading…
x
Reference in New Issue
Block a user