b839ed4f24
These tests rely on dropping references to objects either explicitly ("o = null;") or implicitly ("o goes out of scope") and then doing gc. It's essential that we haven't already marked the WeakCell pointing to o and marked it alive before dropping the reference. BUG=v8:8179 Change-Id: Ie0b73f05c4baa937cf6f28325454ff9087a71a2c Reviewed-on: https://chromium-review.googlesource.com/c/1306437 Reviewed-by: Ulan Degenbaev <ulan@chromium.org> Commit-Queue: Marja Hölttä <marja@chromium.org> Cr-Commit-Position: refs/heads/master@{#57115}
47 lines
1.3 KiB
JavaScript
47 lines
1.3 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 --noincremental-marking
|
|
|
|
let cleanup_call_count = 0;
|
|
let cleanup_weak_cell_count = 0;
|
|
let cleanup = function(iter) {
|
|
for (wc of iter) {
|
|
assertSame(wc, weak_cell);
|
|
++cleanup_weak_cell_count;
|
|
}
|
|
++cleanup_call_count;
|
|
}
|
|
|
|
let wf = new WeakFactory(cleanup);
|
|
// Create an object and a WeakCell pointing to it. The object needs to be inside
|
|
// a closure so that we can reliably kill them!
|
|
let weak_cell;
|
|
|
|
(function() {
|
|
let object = {};
|
|
weak_cell = wf.makeCell(object);
|
|
|
|
// object goes out of scope.
|
|
})();
|
|
|
|
// This GC will discover dirty WeakCells and schedule cleanup.
|
|
gc();
|
|
assertEquals(0, cleanup_call_count);
|
|
|
|
// Assert that the cleanup function was called and iterated the WeakCell.
|
|
let timeout_func = function() {
|
|
assertEquals(1, cleanup_call_count);
|
|
assertEquals(1, cleanup_weak_cell_count);
|
|
|
|
// Clear an already iterated over WeakCell.
|
|
weak_cell.clear();
|
|
|
|
// Assert that it didn't do anything.
|
|
setTimeout(() => { assertEquals(1, cleanup_call_count); }, 0);
|
|
setTimeout(() => { assertEquals(1, cleanup_weak_cell_count); }, 0);
|
|
}
|
|
|
|
setTimeout(timeout_func, 0);
|