https://bugs.webkit.org/show_bug.cgi?id=110623
Reviewed by Eric Seidel.
Source/WebCore:
Test: http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal.html
* html/HTMLAudioElement.h:
(HTMLAudioElement):
* html/HTMLAudioElement.idl:
* html/HTMLMediaElement.cpp:
(WebCore::HTMLMediaElement::hasPendingActivity):
* html/HTMLMediaElement.idl:
LayoutTests:
* http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal-expected.txt: Added.
* http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal.html: Added.
* http/tests/misc/resources/delete-frame-during-readystatechange-frame-with-gc-after-video-removal.html: Added.
git-svn-id: https://svn.webkit.org/repository/webkit/trunk@144859
268f45cc-cd09-0410-ab3c-
d52691b4dbfc
+2013-03-05 Aaron Colwell <acolwell@chromium.org>
+
+ Heap-use-after-free in WebCore::HTMLMediaElement::~HTMLMediaElement
+ https://bugs.webkit.org/show_bug.cgi?id=110623
+
+ Reviewed by Eric Seidel.
+
+ * http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal-expected.txt: Added.
+ * http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal.html: Added.
+ * http/tests/misc/resources/delete-frame-during-readystatechange-frame-with-gc-after-video-removal.html: Added.
+
2013-03-05 Chris Fleizach <cfleizach@apple.com>
AX: Support aria-posinset/setsize
--- /dev/null
+Test deleting a subframe from within its readystatechange event and garbage collecting right after removing the video element from the document. We pass if we don't crash.
--- /dev/null
+<script>
+if (window.testRunner) {
+ testRunner.dumpAsText();
+ testRunner.waitUntilDone();
+}
+
+function r()
+{
+ document.body.removeChild(document.getElementById("f"));
+ setTimeout(function() { testRunner.notifyDone();}, 0);
+}
+</script>
+Test deleting a subframe from within its readystatechange event and garbage collecting right after removing the video element from the document.
+We pass if we don't crash.
+<iframe id="f" src="resources/delete-frame-during-readystatechange-frame-with-gc-after-video-removal.html"></iframe>
--- /dev/null
+<html>
+<head>
+<script>
+i = 0;
+document.addEventListener('readystatechange', function() {
+ if (i == 1)
+ parent.r();
+ i++;
+});
+
+window.addEventListener('DOMContentLoaded', function() {
+ document.getElementById("v").load();
+ document.body.removeChild(document.getElementById("v"));
+ window.gc();
+});
+
+</script>
+</head>
+<body>
+<video id=v src=empty.ogv></video>
+</body>
+</html>
+2013-03-05 Aaron Colwell <acolwell@chromium.org>
+
+ Heap-use-after-free in WebCore::HTMLMediaElement::~HTMLMediaElement
+ https://bugs.webkit.org/show_bug.cgi?id=110623
+
+ Reviewed by Eric Seidel.
+
+ Test: http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal.html
+
+ * html/HTMLAudioElement.h:
+ (HTMLAudioElement):
+ * html/HTMLAudioElement.idl:
+ * html/HTMLMediaElement.cpp:
+ (WebCore::HTMLMediaElement::hasPendingActivity):
+ * html/HTMLMediaElement.idl:
+
2013-03-05 Chris Fleizach <cfleizach@apple.com>
AX: Support aria-posinset/setsize
static PassRefPtr<HTMLAudioElement> create(const QualifiedName&, Document*, bool);
static PassRefPtr<HTMLAudioElement> createForJSConstructor(Document*, const String& src);
- virtual bool hasPendingActivity() const { return isPlaying() || HTMLMediaElement::hasPendingActivity(); }
-
virtual bool isActiveNode() const { return true; }
private:
*/
[
- ActiveDOMObject,
Conditional=VIDEO,
NamedConstructor=Audio(in [Optional=DefaultIsNullString] DOMString src)
] interface HTMLAudioElement : HTMLMediaElement {
bool HTMLMediaElement::hasPendingActivity() const
{
- return m_asyncEventQueue->hasPendingEvents();
+ return (hasAudio() && isPlaying()) || m_asyncEventQueue->hasPendingEvents();
}
void HTMLMediaElement::mediaVolumeDidChange()
[
Conditional=VIDEO,
- JSGenerateToNativeObject
+ JSGenerateToNativeObject,
+ ActiveDOMObject
] interface HTMLMediaElement : HTMLElement {
// error state