/* Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/ */ "use strict"; const IMAGE_TOOLTIP_URL = EXAMPLE_URL + "html_image-tooltip-test-page.html"; const IMAGE_TOOLTIP_REQUESTS = 1; /** * Tests if image responses show a popup in the requests menu when hovered. */ add_task(function* test() { let { tab, monitor } = yield initNetMonitor(IMAGE_TOOLTIP_URL); info("Starting test... "); let { $, EVENTS, ACTIVITY_TYPE, NetMonitorView, NetMonitorController } = monitor.panelWin; let { RequestsMenu } = NetMonitorView; RequestsMenu.lazyUpdate = true; let onEvents = waitForNetworkEvents(monitor, IMAGE_TOOLTIP_REQUESTS); let onThumbnail = monitor.panelWin.once(EVENTS.RESPONSE_IMAGE_THUMBNAIL_DISPLAYED); yield performRequests(); yield onEvents; yield onThumbnail; info("Checking the image thumbnail after a few requests were made..."); yield showTooltipAndVerify(RequestsMenu.tooltip, RequestsMenu.items[0]); // Hide tooltip before next test, to avoid the situation that tooltip covers // the icon for the request of the next test. info("Checking the image thumbnail gets hidden..."); yield hideTooltipAndVerify(RequestsMenu.tooltip, RequestsMenu.items[0]); // +1 extra document reload onEvents = waitForNetworkEvents(monitor, IMAGE_TOOLTIP_REQUESTS + 1); onThumbnail = monitor.panelWin.once(EVENTS.RESPONSE_IMAGE_THUMBNAIL_DISPLAYED); info("Reloading the debuggee and performing all requests again..."); yield NetMonitorController.triggerActivity(ACTIVITY_TYPE.RELOAD.WITH_CACHE_ENABLED); yield performRequests(); yield onEvents; yield onThumbnail; info("Checking the image thumbnail after a reload."); yield showTooltipAndVerify(RequestsMenu.tooltip, RequestsMenu.items[1]); info("Checking if the image thumbnail is hidden when mouse leaves the menu widget"); let requestsMenuEl = $("#requests-menu-contents"); let onHidden = RequestsMenu.tooltip.once("hidden"); EventUtils.synthesizeMouse(requestsMenuEl, 0, 0, {type: "mouseout"}, monitor.panelWin); yield onHidden; yield teardown(monitor); function performRequests() { return ContentTask.spawn(tab.linkedBrowser, {}, function* () { content.wrappedJSObject.performRequests(); }); } /** * Show a tooltip on the {requestItem} and verify that it was displayed * with the expected content. */ function* showTooltipAndVerify(tooltip, requestItem) { let anchor = $(".requests-menu-file", requestItem.target); yield showTooltipOn(tooltip, anchor); info("Tooltip was successfully opened for the image request."); is(tooltip.panel.querySelector("img").src, TEST_IMAGE_DATA_URI, "The tooltip's image content is displayed correctly."); } /** * Trigger a tooltip over an element by sending mousemove event. * @return a promise that resolves when the tooltip is shown */ function showTooltipOn(tooltip, element) { let onShown = tooltip.once("shown"); let win = element.ownerDocument.defaultView; EventUtils.synthesizeMouseAtCenter(element, {type: "mousemove"}, win); return onShown; } /** * Hide a tooltip on the {requestItem} and verify that it was closed. */ function* hideTooltipAndVerify(tooltip, requestItem) { // Hovering method hides tooltip. let anchor = $(".requests-menu-method", requestItem.target); let onHidden = tooltip.once("hidden"); let win = anchor.ownerDocument.defaultView; EventUtils.synthesizeMouseAtCenter(anchor, {type: "mousemove"}, win); yield onHidden; info("Tooltip was successfully closed."); } });