OLD | NEW |
(Empty) | |
| 1 <!DOCTYPE html> |
| 2 <title>Overflow menu updates properly.</title> |
| 3 <script src="../resources/testharness.js"></script> |
| 4 <script src="../resources/testharnessreport.js"></script> |
| 5 <script src="media-controls.js"></script> |
| 6 <script src="media-file.js"></script> |
| 7 <script src="overflow-menu.js"></script> |
| 8 |
| 9 <!--Padding ensures the overflow menu is visible for the tests. --> |
| 10 <body style="padding-top: 200px; padding-left: 100px"> |
| 11 <video controls></video> |
| 12 <script> |
| 13 async_test(function(t) { |
| 14 // Set up video |
| 15 var video = document.querySelector("video"); |
| 16 video.src = findMediaFile("video", "content/test"); |
| 17 video.setAttribute("width", "60"); |
| 18 // Add captions |
| 19 var trackElement = document.createElement("track"); |
| 20 video.appendChild(trackElement); |
| 21 // Pretend we have a cast device |
| 22 internals.mediaPlayerRemoteRouteAvailabilityChanged(video, true); |
| 23 |
| 24 video.onloadeddata = t.step_func_done(function() { |
| 25 var overflowList = getOverflowList(video); |
| 26 |
| 27 // Remove cast device and ensure the overflow menu updates as expected |
| 28 // Cast option in overflow should no longer be visible, but the other |
| 29 // options should all be. |
| 30 var buttonsWithoutCast = overflowButtonsCSS; |
| 31 buttonsWithoutCast[1] = undefined; |
| 32 internals.mediaPlayerRemoteRouteAvailabilityChanged(video, false); |
| 33 |
| 34 var children = overflowList.children; |
| 35 // Ensure that all of the buttons are visible in the right order |
| 36 for (var i = 0; i < children.length; i++) { |
| 37 var child = children[i]; |
| 38 if (buttonsWithoutCast[i]) { |
| 39 assert_not_equals(getComputedStyle(child).display, "none"); |
| 40 } else { |
| 41 assert_equals(getComputedStyle(child).display, "none"); |
| 42 } |
| 43 } |
| 44 internals.mediaPlayerRemoteRouteAvailabilityChanged(video, true); |
| 45 assert_not_equals(getComputedStyle(children[1]).display, "none"); |
| 46 |
| 47 // Removing closed captions hides button in overflow menu |
| 48 assert_not_equals(getComputedStyle(children[2]).display, "none"); |
| 49 video.removeChild(trackElement); |
| 50 assert_equals(getComputedStyle(children[2]).display, "none"); |
| 51 }); |
| 52 }); |
| 53 </script> |
| 54 </body> |
OLD | NEW |