forked from mirrors/gecko-dev
		
	 2f68e50e6c
			
		
	
	
		2f68e50e6c
		
	
	
	
	
		
			
			MozReview-Commit-ID: DceweCXElI4 --HG-- extra : rebase_source : c900d38b4e6ffb7bf8a6aa16e9f3b6106f63f6c9
		
			
				
	
	
		
			105 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /* 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 { document, gStore, windowRequire, NetMonitorController } = monitor.panelWin;
 | |
|   let Actions = windowRequire("devtools/client/netmonitor/actions/index");
 | |
|   let { ACTIVITY_TYPE, EVENTS } = windowRequire("devtools/client/netmonitor/constants");
 | |
|   let {
 | |
|     getDisplayedRequests,
 | |
|     getSortedRequests,
 | |
|   } = windowRequire("devtools/client/netmonitor/selectors/index");
 | |
|   let toolboxDoc = monitor.toolbox.doc;
 | |
| 
 | |
|   gStore.dispatch(Actions.batchEnable(false));
 | |
| 
 | |
|   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(toolboxDoc,
 | |
|     document.querySelectorAll(".request-list-item")[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(monitor.toolbox.doc,
 | |
|     document.querySelectorAll(".request-list-item")[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(toolboxDoc,
 | |
|     document.querySelectorAll(".request-list-item")[1]);
 | |
| 
 | |
|   info("Checking if the image thumbnail is hidden when mouse leaves the menu widget");
 | |
|   let requestsListContents = document.querySelector(".requests-list-contents");
 | |
|   EventUtils.synthesizeMouse(requestsListContents, 0, 0, { type: "mouseout" }, monitor.panelWin);
 | |
|   yield waitUntil(() => !toolboxDoc.querySelector(".tooltip-container.tooltip-visible"));
 | |
| 
 | |
|   yield teardown(monitor);
 | |
| 
 | |
|   function performRequests() {
 | |
|     return ContentTask.spawn(tab.linkedBrowser, {}, function* () {
 | |
|       content.wrappedJSObject.performRequests();
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Show a tooltip on the {target} and verify that it was displayed
 | |
|    * with the expected content.
 | |
|    */
 | |
|   function* showTooltipAndVerify(toolboxDoc, target) {
 | |
|     let anchor = target.querySelector(".requests-list-file");
 | |
|     yield showTooltipOn(toolboxDoc, anchor);
 | |
| 
 | |
|     info("Tooltip was successfully opened for the image request.");
 | |
|     is(toolboxDoc.querySelector(".tooltip-panel 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(toolboxDoc, element) {
 | |
|     let win = element.ownerDocument.defaultView;
 | |
|     EventUtils.synthesizeMouseAtCenter(element, { type: "mousemove" }, win);
 | |
|     yield waitUntil(() => toolboxDoc.querySelector(".tooltip-panel img"));
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Hide a tooltip on the {target} and verify that it was closed.
 | |
|    */
 | |
|   function* hideTooltipAndVerify(toolboxDoc, target) {
 | |
|     // Hovering over the "method" column hides the tooltip.
 | |
|     let anchor = target.querySelector(".requests-list-method");
 | |
|     let win = anchor.ownerDocument.defaultView;
 | |
|     EventUtils.synthesizeMouseAtCenter(anchor, { type: "mousemove" }, win);
 | |
| 
 | |
|     yield waitUntil(() => !toolboxDoc.querySelector(".tooltip-container.tooltip-visible"));
 | |
|     info("Tooltip was successfully closed.");
 | |
|   }
 | |
| });
 |