[tor-commits] [Git][tpo/applications/mullvad-browser][mullvad-browser-115.11.0esr-13.5-1] 2 commits: Revert "Bug 41881: Don't persist custom network requests on private windows"
richard (@richard)
git at gitlab.torproject.org
Mon May 13 20:41:36 UTC 2024
richard pushed to branch mullvad-browser-115.11.0esr-13.5-1 at The Tor Project / Applications / Mullvad Browser
Commits:
bea39ca4 by Pier Angelo Vendrame at 2024-05-13T20:40:44+00:00
Revert "Bug 41881: Don't persist custom network requests on private windows"
This reverts commit 6450a4e62e810832f35ee8732a4630ec2c2ba6f6.
- - - - -
400cba03 by cypherpunks1 at 2024-05-13T20:40:45+00:00
Bug 1892052 - Do not persist custom network requests on PBM. r=devtools-reviewers,bomsy,nchevobbe
Differential Revision: https://phabricator.services.mozilla.com/D207762
- - - - -
3 changed files:
- devtools/client/netmonitor/src/components/new-request/HTTPCustomRequestPanel.js
- devtools/client/netmonitor/test/browser_net_new_request_panel_persisted_content.js
- devtools/client/netmonitor/test/head.js
Changes:
=====================================
devtools/client/netmonitor/src/components/new-request/HTTPCustomRequestPanel.js
=====================================
@@ -4,11 +4,6 @@
"use strict";
-const lazy = {};
-ChromeUtils.defineESModuleGetters(lazy, {
- PrivateBrowsingUtils: "resource://gre/modules/PrivateBrowsingUtils.sys.mjs",
-});
-
const {
Component,
createFactory,
@@ -127,7 +122,7 @@ class HTTPCustomRequestPanel extends Component {
async componentDidMount() {
let { connector, request } = this.props;
- if (!lazy.PrivateBrowsingUtils.isWindowPrivate(window)) {
+ if (!connector.currentTarget?.targetForm?.isPrivate) {
const persistedCustomRequest = await asyncStorage.getItem(
"devtools.netmonitor.customRequest"
);
@@ -198,7 +193,7 @@ class HTTPCustomRequestPanel extends Component {
}
componentWillUnmount() {
- if (!lazy.PrivateBrowsingUtils.isWindowPrivate(window)) {
+ if (!this.props.connector.currentTarget?.targetForm?.isPrivate) {
asyncStorage.setItem("devtools.netmonitor.customRequest", this.state);
}
}
=====================================
devtools/client/netmonitor/test/browser_net_new_request_panel_persisted_content.js
=====================================
@@ -9,30 +9,14 @@ const asyncStorage = require("resource://devtools/shared/async-storage.js");
* Test if content is still persisted after the panel is closed
*/
-add_task(async function () {
- // Turn true the pref
- await pushPref("devtools.netmonitor.features.newEditAndResend", true);
- // Reset the storage for the persisted custom request
- await asyncStorage.removeItem("devtools.netmonitor.customRequest");
-
- const { monitor } = await initNetMonitor(HTTPS_CUSTOM_GET_URL, {
- requestCount: 1,
- });
- info("Starting test... ");
-
- const { document, store, windowRequire } = monitor.panelWin;
-
- // Action should be processed synchronously in tests.
- const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
- store.dispatch(Actions.batchEnable(false));
-
- info("open the left panel");
- let waitForPanels = waitForDOM(
+async function addCustomRequestTestContent(tab, monitor, document) {
+ info("Open the left panel");
+ const waitForPanels = waitForDOM(
document,
".monitor-panel .network-action-bar"
);
- let HTTPCustomRequestButton = document.querySelector(
+ const HTTPCustomRequestButton = document.querySelector(
"#netmonitor-toolbar-container .devtools-http-custom-request-icon"
);
HTTPCustomRequestButton.click();
@@ -59,91 +43,166 @@ add_task(async function () {
"#http-custom-query .map-add-new-inputs .http-custom-input-name"
);
newParameterName.focus();
- EventUtils.sendString("My-param");
+ EventUtils.sendString("My-param", monitor.panelWin);
info("Adding new headers");
const newHeaderName = document.querySelector(
"#http-custom-headers .map-add-new-inputs .http-custom-input-name"
);
newHeaderName.focus();
- EventUtils.sendString("My-header");
+ EventUtils.sendString("My-header", monitor.panelWin);
const newHeaderValue = Array.from(
document.querySelectorAll(
"#http-custom-headers .http-custom-input .http-custom-input-value"
)
- ).pop();
+ ).at(-1);
newHeaderValue.focus();
- EventUtils.sendString("my-value");
+ EventUtils.sendString("my-value", monitor.panelWin);
const postValue = document.querySelector("#http-custom-postdata-value");
postValue.focus();
- EventUtils.sendString("{'Name': 'Value'}");
+ EventUtils.sendString("{'Name': 'Value'}", monitor.panelWin);
- // Close the panel
+ info("Close the panel");
const closePanel = document.querySelector(
".network-action-bar .tabs-navigation .sidebar-toggle"
);
closePanel.click();
+}
- // Open the panel again to see if the content is still there
- waitForPanels = waitUntil(
+async function runTests(tab, monitor, document, isPrivate = false) {
+ info("Open the panel again to see if the content is still there");
+ const waitForPanels = waitFor(
() =>
document.querySelector(".http-custom-request-panel") &&
document.querySelector("#http-custom-request-send-button").disabled ===
- false
+ isPrivate
);
- HTTPCustomRequestButton = document.querySelector(
+ const HTTPCustomRequestButton = document.querySelector(
"#netmonitor-toolbar-container .devtools-http-custom-request-icon"
);
HTTPCustomRequestButton.click();
await waitForPanels;
- is(
- methodValue.value,
- "POST",
- "The content should still be there after the user close the panel and re-opened"
- );
-
- is(
- url.value,
- "https://www.example.com?My-param=",
- "The url should still be there after the user close the panel and re-opened"
- );
+ // Wait a few seconds to make sure all the fields have been updated
+ await wait(1500);
+
+ const customMethod = document.querySelector("#http-custom-method-value");
+ const customUrl = document.querySelector(".http-custom-url-value");
+ const customQuery = document.querySelectorAll(
+ "#http-custom-query .tabpanel-summary-container.http-custom-input textarea"
+ );
+ const customHeaders = document.querySelectorAll(
+ "#http-custom-headers .tabpanel-summary-container.http-custom-input textarea"
+ );
+ const postDataValue = document.querySelector("#http-custom-postdata-value");
+
+ if (isPrivate) {
+ is(
+ customMethod.value,
+ "GET",
+ "The method should not be persisted after the user close the panel and re-opened in PBM"
+ );
+
+ is(
+ customUrl.value,
+ "",
+ "The url should not be there after the user close the panel and re-opened in PBM"
+ );
+
+ is(
+ customQuery.length,
+ 0,
+ "The Parameter should not be there after the user close the panel and re-opened in PBM"
+ );
+
+ is(
+ customHeaders.length,
+ 0,
+ "There should be no custom headers after the user close the panel and re-opened in PBM"
+ );
+
+ is(
+ postDataValue.value,
+ "",
+ "The post data should still be reset after the user close the panel and re-opened in PBM"
+ );
+ } else {
+ is(
+ customMethod.value,
+ "POST",
+ "The method should be persisted after the user close the panel and re-opened"
+ );
+
+ is(
+ customUrl.value,
+ "https://www.example.com?My-param=",
+ "The url should still be there after the user close the panel and re-opened"
+ );
+
+ const [nameParam] = Array.from(customQuery);
+ is(
+ nameParam.value,
+ "My-param",
+ "The Parameter name should still be there after the user close the panel and re-opened"
+ );
+
+ const [name, value] = Array.from(customHeaders);
+ is(
+ name.value,
+ "My-header",
+ "The header name should still be there after the user close the panel and re-opened"
+ );
+ is(
+ value.value,
+ "my-value",
+ "The header value should still be there after the user close the panel and re-opened"
+ );
+
+ is(
+ postDataValue.value,
+ "{'Name': 'Value'}",
+ "The content should still be there after the user close the panel and re-opened"
+ );
+ }
+}
+
+add_task(async function testRequestPanelPersistedContent() {
+ // Turn true the pref
+ await pushPref("devtools.netmonitor.features.newEditAndResend", true);
+ // Reset the storage for the persisted custom request
+ await asyncStorage.removeItem("devtools.netmonitor.customRequest");
- const [nameParam] = Array.from(
- document.querySelectorAll(
- "#http-custom-query .tabpanel-summary-container.http-custom-input textarea"
- )
- );
- is(
- nameParam.value,
- "My-param",
- "The Parameter name should still be there after the user close the panel and re-opened"
- );
+ const { tab, monitor } = await initNetMonitor(HTTPS_CUSTOM_GET_URL, {
+ requestCount: 1,
+ });
+ const { document, store, windowRequire } = monitor.panelWin;
+ const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
+ store.dispatch(Actions.batchEnable(false));
- const [name, value] = Array.from(
- document.querySelectorAll(
- "#http-custom-headers .tabpanel-summary-container.http-custom-input textarea"
- )
- );
- is(
- name.value,
- "My-header",
- "The header name should still be there after the user close the panel and re-opened"
- );
- is(
- value.value,
- "my-value",
- "The header value should still be there after the user close the panel and re-opened"
- );
+ info("Starting test... ");
+ info("Add initial custom request test content");
+ await addCustomRequestTestContent(tab, monitor, document);
+ await runTests(tab, monitor, document);
+ await teardown(monitor);
+});
- is(
- postValue.value,
- "{'Name': 'Value'}",
- "The content should still be there after the user close the panel and re-opened"
+add_task(async function testRequestPanelPersistedContentInPrivateWindow() {
+ await pushPref("devtools.netmonitor.features.newEditAndResend", true);
+ const { tab, monitor, privateWindow } = await initNetMonitor(
+ HTTPS_CUSTOM_GET_URL,
+ {
+ requestCount: 1,
+ openInPrivateWindow: true,
+ }
);
+ const { document, store, windowRequire } = monitor.panelWin;
+ const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
+ store.dispatch(Actions.batchEnable(false));
- await teardown(monitor);
+ info("Starting test in private window... ");
+ await runTests(tab, monitor, document, true);
+ await teardown(monitor, privateWindow);
});
=====================================
devtools/client/netmonitor/test/head.js
=====================================
@@ -321,6 +321,7 @@ function initNetMonitor(
expectedEventTimings,
waitForLoad = true,
enableCache = false,
+ openInPrivateWindow = false,
}
) {
info("Initializing a network monitor pane.");
@@ -341,7 +342,22 @@ function initNetMonitor(
],
});
- const tab = await addTab(url, { waitForLoad });
+ let tab = null;
+ let privateWindow = null;
+
+ if (openInPrivateWindow) {
+ privateWindow = await BrowserTestUtils.openNewBrowserWindow({
+ private: true,
+ });
+ ok(
+ PrivateBrowsingUtils.isContentWindowPrivate(privateWindow),
+ "window is private"
+ );
+ tab = BrowserTestUtils.addTab(privateWindow.gBrowser, url);
+ } else {
+ tab = await addTab(url, { waitForLoad });
+ }
+
info("Net tab added successfully: " + url);
const toolbox = await gDevTools.showToolboxForTab(tab, {
@@ -371,7 +387,7 @@ function initNetMonitor(
await clearNetworkEvents(monitor);
}
- return { tab, monitor, toolbox };
+ return { tab, monitor, toolbox, privateWindow };
})();
}
@@ -408,7 +424,7 @@ async function clearNetworkEvents(monitor) {
store.dispatch(Actions.clearRequests());
}
-function teardown(monitor) {
+function teardown(monitor, privateWindow) {
info("Destroying the specified network monitor.");
return (async function () {
@@ -419,6 +435,12 @@ function teardown(monitor) {
await monitor.toolbox.destroy();
await removeTab(tab);
+
+ if (privateWindow) {
+ const closed = BrowserTestUtils.windowClosed(privateWindow);
+ privateWindow.BrowserCommands.tryToCloseWindow();
+ await closed;
+ }
})();
}
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/compare/bed64b838cfebd5ad0aa56692fed78b1fe7d2d94...400cba03e0a45832a11ac7b2b89d00988904d836
--
This project does not include diff previews in email notifications.
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/compare/bed64b838cfebd5ad0aa56692fed78b1fe7d2d94...400cba03e0a45832a11ac7b2b89d00988904d836
You're receiving this email because of your account on gitlab.torproject.org.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.torproject.org/pipermail/tor-commits/attachments/20240513/f51d3a72/attachment-0001.htm>
More information about the tor-commits
mailing list