Title: [231923] trunk
Revision
231923
Author
ryanhad...@apple.com
Date
2018-05-17 15:15:06 -0700 (Thu, 17 May 2018)

Log Message

Unreviewed, rolling out r231899.

Caused flakiness in two existing modern-media-controls tests.

Reverted changeset:

"[modern-media-controls] AirPlaySupport should be disabled by
default"
https://bugs.webkit.org/show_bug.cgi?id=185658
https://trac.webkit.org/changeset/231899

Modified Paths

Removed Paths

Diff

Modified: trunk/LayoutTests/ChangeLog (231922 => 231923)


--- trunk/LayoutTests/ChangeLog	2018-05-17 22:12:32 UTC (rev 231922)
+++ trunk/LayoutTests/ChangeLog	2018-05-17 22:15:06 UTC (rev 231923)
@@ -1,3 +1,16 @@
+2018-05-17  Ryan Haddad  <ryanhad...@apple.com>
+
+        Unreviewed, rolling out r231899.
+
+        Caused flakiness in two existing modern-media-controls tests.
+
+        Reverted changeset:
+
+        "[modern-media-controls] AirPlaySupport should be disabled by
+        default"
+        https://bugs.webkit.org/show_bug.cgi?id=185658
+        https://trac.webkit.org/changeset/231899
+
 2018-05-17  Jer Noble  <jer.no...@apple.com>
 
         CRASH in ImageDecoderAVFObjC::sampleAtIndex()

Deleted: trunk/LayoutTests/media/modern-media-controls/airplay-support/airplay-support-disable-event-listeners-until-play-expected.txt (231922 => 231923)


--- trunk/LayoutTests/media/modern-media-controls/airplay-support/airplay-support-disable-event-listeners-until-play-expected.txt	2018-05-17 22:12:32 UTC (rev 231922)
+++ trunk/LayoutTests/media/modern-media-controls/airplay-support/airplay-support-disable-event-listeners-until-play-expected.txt	2018-05-17 22:15:06 UTC (rev 231923)
@@ -1,23 +0,0 @@
-Testing AirPlaySupport is only enabled once media has started playing.
-
-On success, you will see a series of "PASS" messages, followed by "TEST COMPLETE".
-
-
-Starting test, the media can be played but hasn't started playing.
-
-Making AirPlay routes available.
-
-Airplay routes are available and controls are visible on the screen, but since the media hasn't played yet, AirplaySupport should be disabled.
-PASS controls.airplayButton.uiDelegate is undefined.
-PASS controls.visible is true
-PASS controls.faded is false
-
-We play the media so that the Airplay button can be enabled.
-
-Media played, AirplaySupport should become enabled now.
-PASS !!controls.airplayButton.uiDelegate became true
-
-PASS successfullyParsed is true
-
-TEST COMPLETE
-

Deleted: trunk/LayoutTests/media/modern-media-controls/airplay-support/airplay-support-disable-event-listeners-until-play.html (231922 => 231923)


--- trunk/LayoutTests/media/modern-media-controls/airplay-support/airplay-support-disable-event-listeners-until-play.html	2018-05-17 22:12:32 UTC (rev 231922)
+++ trunk/LayoutTests/media/modern-media-controls/airplay-support/airplay-support-disable-event-listeners-until-play.html	2018-05-17 22:15:06 UTC (rev 231923)
@@ -1,83 +0,0 @@
-<script src=""
-<script src="" type="text/_javascript_"></script>
-<body>
-<video src="" style="width: 320px; height: 240px;" preload controls></video>
-<div id="host"></div>
-<script type="text/_javascript_">
-
-window.jsTestIsAsync = true;
-
-description("Testing <code>AirPlaySupport</code> is only enabled once media has started playing.");
-
-const container = document.querySelector("div#host");
-const media = document.querySelector("video");
-const mediaController = createControls(container, media, null);
-const controls = mediaController.controls;
-
-controls.autoHideController.autoHideDelay = 100;
-
-media.addEventListener("canplay", startTest);
-
-function startTest()
-{
-    debug("Starting test, the media can be played but hasn't started playing.");
-
-    makeAirPlayAvailable();
-}
-
-function makeAirPlayAvailable()
-{
-    debug("");
-    debug("Making AirPlay routes available.");
-    media.addEventListener("webkitplaybacktargetavailabilitychanged", playbackTargetAvailabilityChangedOnce, true);
-    window.internals.setMockMediaPlaybackTargetPickerEnabled(true);
-}
-
-function playbackTargetAvailabilityChangedOnce(event)
-{
-    media.removeEventListener('webkitplaybacktargetavailabilitychanged', playbackTargetAvailabilityChangedOnce, true);
-    media.addEventListener('webkitplaybacktargetavailabilitychanged', playbackTargetAvailabilityChangedAgain, true);
-
-    window.internals.setMockMediaPlaybackTargetPickerState('Sleepy TV', 'DeviceAvailable');
-}
-
-function playbackTargetAvailabilityChangedAgain(event)
-{
-    // setMockMediaPlaybackTargetPickerState happens asynchronously in WK2 and a
-    // "webkitplaybacktargetavailabilitychanged" is always sent when an event listener
-    // is added, so we may get a "not available" event first.
-    if (event.availability == 'not-available')
-        return;
-
-    media.removeEventListener('webkitplaybacktargetavailabilitychanged', playbackTargetAvailabilityChangedAgain, true);
-
-    debug("");
-    debug("Airplay routes are available and controls are visible on the screen, but since the media hasn't played yet, AirplaySupport should be disabled.");
-    shouldBeUndefined("controls.airplayButton.uiDelegate");
-    shouldBeTrue("controls.visible");
-    shouldBeFalse("controls.faded");
-
-    debug("");
-    debug("We play the media so that the Airplay button can be enabled.");
-    media.addEventListener("play", mediaDidPlay);
-    media.play();
-}
-
-function mediaDidPlay()
-{
-    debug("");
-    debug("Media played, AirplaySupport should become enabled now.");
-    shouldBecomeEqual("!!controls.airplayButton.uiDelegate", "true", finishTest);
-}
-
-function finishTest()
-{
-    debug("");
-    container.remove();
-    media.remove();
-    finishJSTest();
-}
-
-</script>
-<script src=""
-</body>

Modified: trunk/Source/WebCore/ChangeLog (231922 => 231923)


--- trunk/Source/WebCore/ChangeLog	2018-05-17 22:12:32 UTC (rev 231922)
+++ trunk/Source/WebCore/ChangeLog	2018-05-17 22:15:06 UTC (rev 231923)
@@ -1,3 +1,16 @@
+2018-05-17  Ryan Haddad  <ryanhad...@apple.com>
+
+        Unreviewed, rolling out r231899.
+
+        Caused flakiness in two existing modern-media-controls tests.
+
+        Reverted changeset:
+
+        "[modern-media-controls] AirPlaySupport should be disabled by
+        default"
+        https://bugs.webkit.org/show_bug.cgi?id=185658
+        https://trac.webkit.org/changeset/231899
+
 2018-05-17  Eric Carlson  <eric.carl...@apple.com>
 
         [iOS] Update AirPlay route monitoring

Modified: trunk/Source/WebCore/Modules/modern-media-controls/media/airplay-support.js (231922 => 231923)


--- trunk/Source/WebCore/Modules/modern-media-controls/media/airplay-support.js	2018-05-17 22:12:32 UTC (rev 231922)
+++ trunk/Source/WebCore/Modules/modern-media-controls/media/airplay-support.js	2018-05-17 22:15:06 UTC (rev 231923)
@@ -38,12 +38,6 @@
         return ["webkitplaybacktargetavailabilitychanged", "webkitcurrentplaybacktargetiswirelesschanged"];
     }
 
-    enable()
-    {
-        if (this._shouldBeEnabled())
-            super.enable();
-    }
-
     buttonWasPressed(control)
     {
         this.mediaController.media.webkitShowPlaybackTargetPicker();
@@ -51,7 +45,8 @@
 
     controlsUserVisibilityDidChange()
     {
-        if (this._shouldBeEnabled())
+        const controls = this.mediaController.controls;
+        if (controls.visible && !controls.faded)
             this.enable();
         else
             this.disable();
@@ -72,15 +67,4 @@
         this.mediaController.controls.muteButton.enabled = !this.control.on;
     }
 
-    // Private
-
-    _shouldBeEnabled()
-    {
-        if (!this.mediaController.hasPlayed)
-            return false;
-
-        const controls = this.mediaController.controls;
-        return controls.visible && !controls.faded;
-    }
-
 }
_______________________________________________
webkit-changes mailing list
webkit-changes@lists.webkit.org
https://lists.webkit.org/mailman/listinfo/webkit-changes

Reply via email to