summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/Proxy/set/trap-is-undefined-target-is-proxy.js
blob: ac2f7a8497b5ad683461f41600a3154c29cc1f6c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
// Copyright (C) 2020 Alexey Shvayka. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.

/*---
esid: sec-proxy-object-internal-methods-and-internal-slots-set-p-v-receiver
description: >
  If "set" trap is null or undefined, [[Set]] call is properly
  forwarded to [[ProxyTarget]] (which is also a Proxy object).
info: |
  [[Set]] ( P, V, Receiver )

  [...]
  5. Let target be O.[[ProxyTarget]].
  6. Let trap be ? GetMethod(handler, "set").
  7. If trap is undefined, then
    a. Return ? target.[[Set]](P, V, Receiver).
features: [Proxy, Reflect]
---*/

var func = function() {};
var funcTarget = new Proxy(func, {});
var funcProxy = new Proxy(funcTarget, {
  set: undefined,
});

assert(Reflect.set(funcProxy, "prototype", null));
assert.sameValue(func.prototype, null);

assert(!Reflect.set(funcProxy, "length", 2));
assert.throws(TypeError, function() {
  "use strict";
  funcProxy.name = "foo";
});


var trapCalls = 0;
var target = new Proxy({}, {
  set: function(_target, key) {
    trapCalls++;
    return key === "foo";
  },
});

var proxy = new Proxy(target, {
  set: undefined,
});

assert(Reflect.set(Object.create(proxy), "foo", 1));
assert.sameValue(trapCalls, 1);

assert(!Reflect.set(proxy, "bar", 2));
assert.sameValue(trapCalls, 2);

reportCompare(0, 0);