WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
180323
Add test demonstrating leaks that happen when we create reference cycles with DOM objects
https://bugs.webkit.org/show_bug.cgi?id=180323
Summary
Add test demonstrating leaks that happen when we create reference cycles with...
Darin Adler
Reported
2017-12-02 16:56:15 PST
Add test demonstrating leaks that happen when we create reference cycles with DOM Objects
Attachments
Patch
(8.27 KB, patch)
2017-12-02 16:56 PST
,
Darin Adler
no flags
Details
Formatted Diff
Diff
Archive of layout-test-results from ews101 for mac-elcapitan
(2.18 MB, application/zip)
2017-12-02 17:52 PST
,
EWS Watchlist
no flags
Details
Archive of layout-test-results from ews105 for mac-elcapitan-wk2
(2.50 MB, application/zip)
2017-12-02 18:03 PST
,
EWS Watchlist
no flags
Details
Patch
(8.69 KB, patch)
2017-12-09 15:41 PST
,
Darin Adler
no flags
Details
Formatted Diff
Diff
Show Obsolete
(3)
View All
Add attachment
proposed patch, testcase, etc.
Darin Adler
Comment 1
2017-12-02 16:56:34 PST
Comment hidden (obsolete)
Created
attachment 328266
[details]
Patch
EWS Watchlist
Comment 2
2017-12-02 17:52:32 PST
Comment hidden (obsolete)
Comment on
attachment 328266
[details]
Patch
Attachment 328266
[details]
did not pass mac-ews (mac): Output:
http://webkit-queues.webkit.org/results/5471032
New failing tests: fast/dom/reference-cycle-leaks.html
EWS Watchlist
Comment 3
2017-12-02 17:52:34 PST
Comment hidden (obsolete)
Created
attachment 328270
[details]
Archive of layout-test-results from ews101 for mac-elcapitan The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: ews101 Port: mac-elcapitan Platform: Mac OS X 10.11.6
EWS Watchlist
Comment 4
2017-12-02 18:03:05 PST
Comment hidden (obsolete)
Comment on
attachment 328266
[details]
Patch
Attachment 328266
[details]
did not pass mac-wk2-ews (mac-wk2): Output:
http://webkit-queues.webkit.org/results/5471049
New failing tests: fast/dom/reference-cycle-leaks.html
EWS Watchlist
Comment 5
2017-12-02 18:03:07 PST
Comment hidden (obsolete)
Created
attachment 328271
[details]
Archive of layout-test-results from ews105 for mac-elcapitan-wk2 The attached test failures were seen while running run-webkit-tests on the mac-wk2-ews. Bot: ews105 Port: mac-elcapitan-wk2 Platform: Mac OS X 10.11.6
Darin Adler
Comment 6
2017-12-03 11:44:55 PST
I guessed that maybe the test failures were due to the builds being Release instead of Debug, so I made a local release build. But I could not reproduce those failures; works consistently here. Another difference is that I am testing on High Sierra, not El Capitan, two major macOS releases newer. I can think of two options right away if I can’t figure out why the EWS tests are failing: 1) I could decide that this testing strategy is intrinsically too flaky to add these tests. So just not add these. 2) I could remove or at least temporarily disable the tests that are behaving inconsistently: createTreeWalkerNodeCycle, createTreeWalkerFilterCycle, and createPromiseCycle. Any other ideas?
Geoffrey Garen
Comment 7
2017-12-04 10:28:39 PST
You might be able to make the test more reliable by making the action -> GC link async. That way, the GC happens on a clean stack, reducing the chances of floating garbage caused by conservative GC. A complimentary option is to expose JSC::sanitizeStackForVM() explicitly through window.internals, and incorporate it into an async GC chain: action -> sanitize -> GC. Another option is to allocate lots of objects and allow a small number of survivors to count as a pass. This option is preferable to just removing tests because it still catches deterministic leaks.
Filip Pizlo
Comment 8
2017-12-04 10:38:37 PST
If I want to prove that the GC is capable of freeing a kind of object, I like to allocate ~10000 of them and say that the test passes if *any* of them got freed. This side steps the problem that the GC may keep any object alive with some small probability. It may keep one of them alive but it won’t keep all of them alive in that case.
Darin Adler
Comment 9
2017-12-05 16:54:10 PST
(In reply to Filip Pizlo from
comment #8
)
> If I want to prove that the GC is capable of freeing a kind of object, I > like to allocate ~10000 of them and say that the test passes if *any* of > them got freed.
I’ll try changing this to use that technique to see what happens.
Darin Adler
Comment 10
2017-12-09 15:09:42 PST
I see now that this was Geoff’s suggestion #3 too. Hope I don’t need something more serious like #1 or #2.
Darin Adler
Comment 11
2017-12-09 15:41:08 PST
Created
attachment 328919
[details]
Patch
WebKit Commit Bot
Comment 12
2017-12-09 18:53:33 PST
Comment on
attachment 328919
[details]
Patch Clearing flags on attachment: 328919 Committed
r225729
: <
https://trac.webkit.org/changeset/225729
>
WebKit Commit Bot
Comment 13
2017-12-09 18:53:35 PST
All reviewed patches have been landed. Closing bug.
Radar WebKit Bug Importer
Comment 14
2017-12-09 18:54:29 PST
<
rdar://problem/35954395
>
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug