forked from mirrors/gecko-dev
		
	 d8818577f1
			
		
	
	
		d8818577f1
		
	
	
	
	
		
			
			MozReview-Commit-ID: D2eCfvpXoOJ --HG-- extra : rebase_source : 261287bd96a878ce86778c214363fbb1b77ca5a0
		
			
				
	
	
		
			59 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /* Any copyright is dedicated to the Public Domain.
 | |
|    http://creativecommons.org/publicdomain/zero/1.0/ */
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| /**
 | |
|  * Tests if timing intervals are divided againts seconds when appropriate.
 | |
|  */
 | |
| 
 | |
| add_task(function* () {
 | |
|   let { tab, monitor } = yield initNetMonitor(CUSTOM_GET_URL);
 | |
|   info("Starting test... ");
 | |
| 
 | |
|   let { document, gStore, windowRequire } = monitor.panelWin;
 | |
|   let Actions = windowRequire("devtools/client/netmonitor/actions/index");
 | |
|   let { getSortedRequests } = windowRequire("devtools/client/netmonitor/selectors/index");
 | |
| 
 | |
|   gStore.dispatch(Actions.batchEnable(false));
 | |
| 
 | |
|   let wait = waitForNetworkEvents(monitor, 2);
 | |
|   // Timeout needed for having enough divisions on the time scale.
 | |
|   yield ContentTask.spawn(tab.linkedBrowser, {}, function* () {
 | |
|     content.wrappedJSObject.performRequests(2, null, 3000);
 | |
|   });
 | |
|   yield wait;
 | |
| 
 | |
|   let milDivs = document.querySelectorAll(
 | |
|     ".requests-list-timings-division[data-division-scale=millisecond]");
 | |
|   let secDivs = document.querySelectorAll(
 | |
|     ".requests-list-timings-division[data-division-scale=second]");
 | |
|   let minDivs = document.querySelectorAll(
 | |
|     ".requests-list-timings-division[data-division-scale=minute]");
 | |
| 
 | |
|   info("Number of millisecond divisions: " + milDivs.length);
 | |
|   info("Number of second divisions: " + secDivs.length);
 | |
|   info("Number of minute divisions: " + minDivs.length);
 | |
| 
 | |
|   milDivs.forEach(div => info(`Millisecond division: ${div.textContent}`));
 | |
|   secDivs.forEach(div => info(`Second division: ${div.textContent}`));
 | |
|   minDivs.forEach(div => info(`Minute division: ${div.textContent}`));
 | |
| 
 | |
|   is(gStore.getState().requests.requests.size, 2,
 | |
|      "There should be only two requests made.");
 | |
| 
 | |
|   let firstRequest = getSortedRequests(gStore.getState()).get(0);
 | |
|   let lastRequest = getSortedRequests(gStore.getState()).get(1);
 | |
| 
 | |
|   info("First request happened at: " +
 | |
|        firstRequest.responseHeaders.headers.find(e => e.name == "Date").value);
 | |
|   info("Last request happened at: " +
 | |
|        lastRequest.responseHeaders.headers.find(e => e.name == "Date").value);
 | |
| 
 | |
|   ok(secDivs.length,
 | |
|      "There should be at least one division on the seconds time scale.");
 | |
|   ok(secDivs[0].textContent.match(/\d+\.\d{2}\s\w+/),
 | |
|      "The division on the seconds time scale looks legit.");
 | |
| 
 | |
|   return teardown(monitor);
 | |
| });
 |