mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
b9843e0358
- Bug 1167459 - Skip rendering function name nodes if there's no name available (e.g. for C++ pseudoframes), r=jsantell (4a69ed224)
- missing bits Bug 1102219 - Part 4: Replace String.prototype.contains with `String.prototype.includes` in chrome code. r=till (73cd2d2b1)
- Bug 1165045 - Don't create nodes with empty text in the call tree, r=jsantell (b013aa82d)
- Bug 1166122 - Fix regression in the call tree caused by bug 1165045, r=jsantell (ee3f16901)
- Bug 1167975 - CallView._displaySelf sets this.document just because other functions use it; it should pass it as an argument instead, r=jsantell (5ef560c4f)
- Bug 1122662 - Resize graphs when window resizes;r=vporof (25c108e4e)
- Bug 1164784 - Eliminate CSS duplication with perf tool record button r=jsantell (43c9bb999)
- Bug 1150761 - Rename the performance tool's details view names to better describe the data visualizations. r=vp (04ceb6a37)
- Bug 1144424 - Rename '{self,total} allocations' to '{self,total} sampled allocations' in the performance tool. r=jsantell (ae79ad54f)
- Bug 1069910 - Add tooltips explaining what each column in the profiler's tree view represents; r=jsantell (8756f88b6)
- Bug 1107849 - Define a min/max width for the performance panel sidebar. r=vporof (e1769e831)
- Bug 11663354 - A locked recording button should appear disabled in the performance tool. r=vp (4a359d39e)
- Bug 1023546 - DevTools - Support HDPI resolutions for Windows. r=bgrins (ef1a3ecb8)
- Bug 1168125 - Cleanup performance xul and css, r=jsantell (8ec794e46)
- Bug 1168125 - Replace the waterfall view with a tree, r=jsantell (ea76514fe)
- Bug 1168125 - Add marker folding logic, r=jsantell (1d3748d2a)
- Bug 862341 Part 1: Move the network request storage from the console frontend to the console client so the netmonitor can reuse it. r=vporof (d29fb2b73)
- remove gre from resource path (126b00df1)
- Bug 943306 - Allow persisting console input history between sessions;r=past (146ebb486)
- Bug 1134845 - Add clearHistory jsterm helper to remove persisted console input history. r=past (22237e95b)
- Bug 1143497 - Offer a way to extend WebConsole commands. r=bgrins (84e2d2957)
- Bug 1125205 - Display console API messages from shared or service workers to the web console, r=past (b4b701a2c)
- Bug 1169342 - Remove nsIDOMDeviceStorage. Cleanup nsDOMDeviceStorage event wrappers. r=dhylands (41338e16f)
- Bug 1151610 - Manage the case where two extensions fight over the same command. r=bgrins (63f9d2064)
- Bug 862341 Part 2: Display cached network requests in the web console. r=vporof (83c0e7263)
- Bug 1144211 - Improve code coverage of camera mochitests. r=mikeh (ba9f3de89)
- Bug 1152500 - Fix how stop recording may be handled out-of-order. r=dhylands (d8bdd379c)
- Bug 862341 Part 3: Display cached network requests in the network panel. r=vporof (a1a6f151d)
- Bug 862341 Part 4: Start recording network requests when the toolbox opens. r=vporof (7a2bdf847)
- Bug 1151499 - Correct the FM playable state. r=baku (8af26fff2)
- Bug 1180347 - Split media.useAudioChannelService to support turning the service on without turning the Firefox OS specific APIs on; r=baku (3fa29291a)
- Bug 862341 Part 5: Tests. r=vporof (82fb944c6)
215 lines
6.4 KiB
JavaScript
215 lines
6.4 KiB
JavaScript
/* vim:set ts=2 sw=2 sts=2 et: */
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/
|
|
*
|
|
* Contributor(s):
|
|
* Julian Viereck <jviereck@mozilla.com>
|
|
* Patrick Walton <pcwalton@mozilla.com>
|
|
* Mihai Șucan <mihai.sucan@gmail.com>
|
|
*
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
// Tests that network log messages bring up the network panel.
|
|
|
|
const TEST_URI = "data:text/html;charset=utf-8,Web Console network logging tests";
|
|
|
|
const TEST_NETWORK_REQUEST_URI = "http://example.com/browser/browser/devtools/webconsole/test/test-network-request.html";
|
|
|
|
const TEST_IMG = "http://example.com/browser/browser/devtools/webconsole/test/test-image.png";
|
|
|
|
const TEST_DATA_JSON_CONTENT =
|
|
'{ id: "test JSON data", myArray: [ "foo", "bar", "baz", "biff" ] }';
|
|
|
|
let lastRequest = null;
|
|
let requestCallback = null;
|
|
let browser, hud;
|
|
|
|
function test()
|
|
{
|
|
loadTab(TEST_URI).then((tab) => {
|
|
browser = tab.browser;
|
|
|
|
openConsole().then((aHud) => {
|
|
hud = aHud;
|
|
|
|
HUDService.lastFinishedRequest.callback = requestCallbackWrapper;
|
|
|
|
executeSoon(testPageLoad);
|
|
});
|
|
});
|
|
}
|
|
|
|
function requestCallbackWrapper(aRequest)
|
|
{
|
|
lastRequest = aRequest;
|
|
|
|
hud.ui.webConsoleClient.getResponseContent(lastRequest.actor,
|
|
function(aResponse) {
|
|
lastRequest.response.content = aResponse.content;
|
|
lastRequest.discardResponseBody = aResponse.contentDiscarded;
|
|
|
|
hud.ui.webConsoleClient.getRequestPostData(lastRequest.actor,
|
|
function(aResponse) {
|
|
lastRequest.request.postData = aResponse.postData;
|
|
lastRequest.discardRequestBody = aResponse.postDataDiscarded;
|
|
|
|
if (requestCallback) {
|
|
requestCallback();
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
function testPageLoad()
|
|
{
|
|
requestCallback = function() {
|
|
// Check if page load was logged correctly.
|
|
ok(lastRequest, "Page load was logged");
|
|
|
|
is(lastRequest.request.url, TEST_NETWORK_REQUEST_URI,
|
|
"Logged network entry is page load");
|
|
is(lastRequest.request.method, "GET", "Method is correct");
|
|
ok(!lastRequest.request.postData.text, "No request body was stored");
|
|
ok(lastRequest.discardRequestBody, "Request body was discarded");
|
|
ok(!lastRequest.response.content.text, "No response body was stored");
|
|
ok(lastRequest.discardResponseBody || lastRequest.fromCache,
|
|
"Response body was discarded or response came from the cache");
|
|
|
|
lastRequest = null;
|
|
requestCallback = null;
|
|
executeSoon(testPageLoadBody);
|
|
};
|
|
|
|
content.location = TEST_NETWORK_REQUEST_URI;
|
|
}
|
|
|
|
function testPageLoadBody()
|
|
{
|
|
// Turn on logging of request bodies and check again.
|
|
hud.ui.setSaveRequestAndResponseBodies(true).then(() => {
|
|
ok(hud.ui._saveRequestAndResponseBodies,
|
|
"The saveRequestAndResponseBodies property was successfully set.");
|
|
|
|
testPageLoadBodyAfterSettingUpdate();
|
|
});
|
|
}
|
|
|
|
function testPageLoadBodyAfterSettingUpdate()
|
|
{
|
|
let loaded = false;
|
|
let requestCallbackInvoked = false;
|
|
|
|
requestCallback = function() {
|
|
ok(lastRequest, "Page load was logged again");
|
|
ok(!lastRequest.discardResponseBody, "Response body was not discarded");
|
|
is(lastRequest.response.content.text.indexOf("<!DOCTYPE HTML>"), 0,
|
|
"Response body's beginning is okay");
|
|
|
|
lastRequest = null;
|
|
requestCallback = null;
|
|
requestCallbackInvoked = true;
|
|
|
|
if (loaded) {
|
|
executeSoon(testXhrGet);
|
|
}
|
|
};
|
|
|
|
browser.addEventListener("load", function onLoad() {
|
|
browser.removeEventListener("load", onLoad, true);
|
|
loaded = true;
|
|
|
|
if (requestCallbackInvoked) {
|
|
executeSoon(testXhrGet);
|
|
}
|
|
}, true);
|
|
|
|
content.location.reload();
|
|
}
|
|
|
|
function testXhrGet()
|
|
{
|
|
requestCallback = function() {
|
|
ok(lastRequest, "testXhrGet() was logged");
|
|
is(lastRequest.request.method, "GET", "Method is correct");
|
|
ok(!lastRequest.request.postData.text, "No request body was sent");
|
|
ok(!lastRequest.discardRequestBody, "Request body was not discarded");
|
|
is(lastRequest.response.content.text, TEST_DATA_JSON_CONTENT,
|
|
"Response is correct");
|
|
|
|
lastRequest = null;
|
|
requestCallback = null;
|
|
executeSoon(testXhrPost);
|
|
};
|
|
|
|
// Start the XMLHttpRequest() GET test.
|
|
content.wrappedJSObject.testXhrGet();
|
|
}
|
|
|
|
function testXhrPost()
|
|
{
|
|
requestCallback = function() {
|
|
ok(lastRequest, "testXhrPost() was logged");
|
|
is(lastRequest.request.method, "POST", "Method is correct");
|
|
is(lastRequest.request.postData.text, "Hello world!",
|
|
"Request body was logged");
|
|
is(lastRequest.response.content.text, TEST_DATA_JSON_CONTENT,
|
|
"Response is correct");
|
|
|
|
lastRequest = null;
|
|
requestCallback = null;
|
|
executeSoon(testFormSubmission);
|
|
};
|
|
|
|
// Start the XMLHttpRequest() POST test.
|
|
content.wrappedJSObject.testXhrPost();
|
|
}
|
|
|
|
function testFormSubmission()
|
|
{
|
|
// Start the form submission test. As the form is submitted, the page is
|
|
// loaded again. Bind to the load event to catch when this is done.
|
|
requestCallback = function() {
|
|
ok(lastRequest, "testFormSubmission() was logged");
|
|
is(lastRequest.request.method, "POST", "Method is correct");
|
|
isnot(lastRequest.request.postData.text.
|
|
indexOf("Content-Type: application/x-www-form-urlencoded"), -1,
|
|
"Content-Type is correct");
|
|
isnot(lastRequest.request.postData.text.
|
|
indexOf("Content-Length: 20"), -1, "Content-length is correct");
|
|
isnot(lastRequest.request.postData.text.
|
|
indexOf("name=foo+bar&age=144"), -1, "Form data is correct");
|
|
is(lastRequest.response.content.text.indexOf("<!DOCTYPE HTML>"), 0,
|
|
"Response body's beginning is okay");
|
|
|
|
executeSoon(testNetworkPanel);
|
|
};
|
|
|
|
let form = content.document.querySelector("form");
|
|
ok(form, "we have the HTML form");
|
|
form.submit();
|
|
}
|
|
|
|
function testNetworkPanel()
|
|
{
|
|
// Open the NetworkPanel. The functionality of the NetworkPanel is tested
|
|
// within separate test files.
|
|
let networkPanel = hud.ui.openNetworkPanel(hud.ui.filterBox, lastRequest);
|
|
|
|
networkPanel.panel.addEventListener("popupshown", function onPopupShown() {
|
|
networkPanel.panel.removeEventListener("popupshown", onPopupShown, true);
|
|
|
|
is(hud.ui.filterBox._netPanel, networkPanel,
|
|
"Network panel stored on anchor node");
|
|
ok(true, "NetworkPanel was opened");
|
|
|
|
// All tests are done. Shutdown.
|
|
networkPanel.panel.hidePopup();
|
|
lastRequest = null;
|
|
HUDService.lastFinishedRequest.callback = null;
|
|
browser = requestCallback = hud = null;
|
|
executeSoon(finishTest);
|
|
}, true);
|
|
}
|
|
|