3343947273
Previous version: https://chromium-review.googlesource.com/c/v8/v8/+/1292058 BUG=v8:8179 TBR=hpayer@chromium.org, gsathya@chromium.org Change-Id: Ia79b75a0630c5926e59206c29053addc88bfb6fe Reviewed-on: https://chromium-review.googlesource.com/c/1296210 Reviewed-by: Marja Hölttä <marja@chromium.org> Reviewed-by: Hannes Payer <hpayer@chromium.org> Reviewed-by: Sathya Gunasekaran <gsathya@chromium.org> Commit-Queue: Marja Hölttä <marja@chromium.org> Cr-Commit-Position: refs/heads/master@{#56886}
50 lines
1.2 KiB
JavaScript
50 lines
1.2 KiB
JavaScript
// Copyright 2018 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --harmony-weak-refs --expose-gc
|
|
|
|
// Test that WeakCell.prototype.clear() also clears the WeakFactory pointer of
|
|
// WeakCell. The only way to observe this is to assert that the WeakCell no
|
|
// longer keeps its WeakFactory alive after clear() has been called.
|
|
|
|
let weak_cell;
|
|
let weak_cell_pointing_to_factory;
|
|
|
|
let cleanup1_call_count = 0;
|
|
let cleanup2_call_count = 0;
|
|
|
|
let cleanup1 = function() {
|
|
++cleanup1_call_count;
|
|
}
|
|
|
|
let cleanup2 = function() {
|
|
++cleanup2_call_count;
|
|
}
|
|
|
|
let wf1 = new WeakFactory(cleanup1);
|
|
|
|
(function(){
|
|
let wf2 = new WeakFactory(cleanup2);
|
|
|
|
(function() {
|
|
let object = {};
|
|
weak_cell = wf2.makeCell(object);
|
|
// object goes out of scope.
|
|
})();
|
|
|
|
weak_cell_pointing_to_factory = wf1.makeCell(wf2);
|
|
// wf goes out of scope
|
|
})();
|
|
|
|
weak_cell.clear();
|
|
gc();
|
|
|
|
// Assert that weak_cell_pointing_to_factory now got cleared.
|
|
let timeout_func = function() {
|
|
assertEquals(1, cleanup1_call_count);
|
|
assertEquals(0, cleanup2_call_count);
|
|
}
|
|
|
|
setTimeout(timeout_func, 0);
|