From ff3724fd4348542625d9b896b0a1aaffb117e434 Mon Sep 17 00:00:00 2001 From: Leonardo Balter <leonardo.balter@gmail.com> Date: Mon, 11 Jan 2016 17:25:22 -0500 Subject: [PATCH] Add tests for Subclassing the built-in WeakMap Objects --- .../WeakMap/regular-subclassing.js | 28 ++++++++++++++++ .../WeakMap/super-must-be-called.js | 33 +++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 100644 test/language/subclassing/WeakMap/regular-subclassing.js create mode 100644 test/language/subclassing/WeakMap/super-must-be-called.js diff --git a/test/language/subclassing/WeakMap/regular-subclassing.js b/test/language/subclassing/WeakMap/regular-subclassing.js new file mode 100644 index 0000000000..3cc6a9b23f --- /dev/null +++ b/test/language/subclassing/WeakMap/regular-subclassing.js @@ -0,0 +1,28 @@ +// Copyright (C) 2016 the V8 project authors. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +es6id: 23.3.1 +description: Subclassing the WeakMap object +info: > + 23.3.1 The WeakMap Constructor + + ... + + The WeakMap constructor is designed to be subclassable. It may be used as the + value in an extends clause of a class definition. Subclass constructors that + intend to inherit the specified WeakMap behaviour must include a super call to + the WeakMap constructor to create and initialize the subclass instance with + the internal state necessary to support the WeakMap.prototype built-in + methods. +---*/ + +class WM extends WeakMap {} + +var map = new WM(); +var obj = {}; + +assert.sameValue(map.has(obj), false); + +map.set(obj, 42); +assert.sameValue(map.has(obj), true); +assert.sameValue(map.get(obj), 42); diff --git a/test/language/subclassing/WeakMap/super-must-be-called.js b/test/language/subclassing/WeakMap/super-must-be-called.js new file mode 100644 index 0000000000..e277ff7d6d --- /dev/null +++ b/test/language/subclassing/WeakMap/super-must-be-called.js @@ -0,0 +1,33 @@ +// Copyright (C) 2016 the V8 project authors. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +es6id: 23.3.1 +description: Super need to be called to initialize internals +info: > + 23.3.1 The WeakMap Constructor + + ... + + The WeakMap constructor is designed to be subclassable. It may be used as the + value in an extends clause of a class definition. Subclass constructors that + intend to inherit the specified WeakMap behaviour must include a super call to + the WeakMap constructor to create and initialize the subclass instance with + the internal state necessary to support the WeakMap.prototype built-in + methods. +---*/ + +class M1 extends WeakMap { + constructor() {} +} + +assert.throws(ReferenceError, function() { + new M1(); +}); + +class M2 extends WeakMap { + constructor() { + super(); + } +} + +new M2(); -- GitLab