Adapt existing tests to use webextensions-jsdom

This commit is contained in:
stoically 2019-12-18 09:19:01 +01:00 committed by Jonathan Kingston
parent 568c05929e
commit 36f0e121a4
3 changed files with 153 additions and 180 deletions

View file

@ -1,12 +1,12 @@
describe("Assignment Feature", () => { describe("Assignment Feature", () => {
const activeTab = { const url = "http://example.com";
id: 1,
cookieStoreId: "firefox-container-1", let activeTab;
url: "http://example.com",
index: 0
};
beforeEach(async () => { beforeEach(async () => {
await helper.browser.initializeWithTab(activeTab); activeTab = await helper.browser.initializeWithTab({
cookieStoreId: "firefox-container-1",
url
});
}); });
describe("click the 'Always open in' checkbox in the popup", () => { describe("click the 'Always open in' checkbox in the popup", () => {
@ -16,23 +16,24 @@ describe("Assignment Feature", () => {
}); });
describe("open new Tab with the assigned URL in the default container", () => { describe("open new Tab with the assigned URL in the default container", () => {
const newTab = { let newTab;
id: 2,
cookieStoreId: "firefox-default",
url: activeTab.url,
index: 1,
active: true
};
beforeEach(async () => { beforeEach(async () => {
// new Tab opening activeTab.url in default container // new Tab opening activeTab.url in default container
await helper.browser.openNewTab(newTab); newTab = await helper.browser.openNewTab({
cookieStoreId: "firefox-default",
url
}, {
options: {
webRequestError: true // because request is canceled due to reopening
}
});
}); });
it("should open the confirm page", async () => { it("should open the confirm page", async () => {
// should have created a new tab with the confirm page // should have created a new tab with the confirm page
background.browser.tabs.create.should.have.been.calledWith({ background.browser.tabs.create.should.have.been.calledWithMatch({
url: "moz-extension://multi-account-containers/confirm-page.html?" + url: "moz-extension://fake/confirm-page.html?" +
`url=${encodeURIComponent(activeTab.url)}` + `url=${encodeURIComponent(url)}` +
`&cookieStoreId=${activeTab.cookieStoreId}`, `&cookieStoreId=${activeTab.cookieStoreId}`,
cookieStoreId: undefined, cookieStoreId: undefined,
openerTabId: null, openerTabId: null,
@ -53,16 +54,12 @@ describe("Assignment Feature", () => {
}); });
describe("open new Tab with the no longer assigned URL in the default container", () => { describe("open new Tab with the no longer assigned URL in the default container", () => {
const newTab = {
id: 3,
cookieStoreId: "firefox-default",
url: activeTab.url,
index: 3,
active: true
};
beforeEach(async () => { beforeEach(async () => {
// new Tab opening activeTab.url in default container // new Tab opening activeTab.url in default container
await helper.browser.openNewTab(newTab); await helper.browser.openNewTab({
cookieStoreId: "firefox-default",
url
});
}); });
it("should not open the confirm page", async () => { it("should not open the confirm page", async () => {

View file

@ -1,12 +1,11 @@
describe("External Webextensions", () => { describe("External Webextensions", () => {
const activeTab = { const url = "http://example.com";
id: 1,
cookieStoreId: "firefox-container-1",
url: "http://example.com",
index: 0
};
beforeEach(async () => { beforeEach(async () => {
await helper.browser.initializeWithTab(activeTab); await helper.browser.initializeWithTab({
cookieStoreId: "firefox-container-1",
url
});
await helper.popup.clickElementById("container-page-assigned"); await helper.popup.clickElementById("container-page-assigned");
}); });
@ -18,25 +17,18 @@ describe("External Webextensions", () => {
const message = { const message = {
method: "getAssignment", method: "getAssignment",
url: "http://example.com" url
}; };
const sender = { const sender = {
id: "external-webextension" id: "external-webextension"
}; };
// currently not possible to get the return value of yielding with sinon const [promise] = background.browser.runtime.onMessageExternal.addListener.yield(message, sender);
// so we expect that if no error is thrown and the storage was called, everything is ok const answer = await promise;
// maybe i get around to provide a PR https://github.com/sinonjs/sinon/issues/903 expect(answer).to.deep.equal({
// userContextId: "1",
// the alternative would be to expose the actual messageHandler and call it directly neverAsk: false
// but personally i think that goes against the black-box-ish nature of these feature tests });
const rejectionStub = sinon.stub();
process.on("unhandledRejection", rejectionStub);
background.browser.runtime.onMessageExternal.addListener.yield(message, sender);
await nextTick();
process.removeListener("unhandledRejection", rejectionStub);
rejectionStub.should.not.have.been.called;
background.browser.storage.local.get.should.have.been.called;
}); });
}); });
@ -48,20 +40,16 @@ describe("External Webextensions", () => {
const message = { const message = {
method: "getAssignment", method: "getAssignment",
url: "http://example.com" url
}; };
const sender = { const sender = {
id: "external-webextension" id: "external-webextension"
}; };
const rejectionStub = sinon.spy(); const [promise] = background.browser.runtime.onMessageExternal.addListener.yield(message, sender);
process.on("unhandledRejection", rejectionStub); return promise.catch(error => {
background.browser.runtime.onMessageExternal.addListener.yield(message, sender); expect(error.message).to.equal("Missing contextualIdentities permission");
await nextTick(); });
process.removeListener("unhandledRejection", rejectionStub);
rejectionStub.should.have.been.calledWith(sinon.match({
message: "Missing contextualIdentities permission"
}));
}); });
}); });
}); });

View file

@ -1,112 +1,82 @@
describe("#940", () => { describe("#940", () => {
describe("when other onBeforeRequestHandlers are faster and redirect with the same requestId", () => { describe("when other onBeforeRequestHandlers are faster and redirect with the same requestId", () => {
it("should not open two confirm pages", async () => { it("should not open two confirm pages", async () => {
// init await helper.browser.initializeWithTab({
const activeTab = {
id: 1,
cookieStoreId: "firefox-container-1", cookieStoreId: "firefox-container-1",
url: "http://example.com", url: "http://example.com"
index: 0 });
};
await helper.browser.initializeWithTab(activeTab);
// assign the activeTab.url
await helper.popup.clickElementById("container-page-assigned"); await helper.popup.clickElementById("container-page-assigned");
// start request and don't await the requests at all const responses = {};
// so the second request below is actually comparable to an actual redirect that also fires immediately await helper.browser.openNewTab({
const newTab = { url: "http://example.com"
id: 2, }, {
cookieStoreId: "firefox-default", options: {
url: activeTab.url, webRequestRedirects: ["https://example.com"],
index: 1, webRequestError: true,
active: true instantRedirects: true
}; },
helper.browser.openNewTab(newTab, { responses
requestId: 1
}); });
// other addon sees the same request const result = await responses.webRequest.onBeforeRequest[1];
// and redirects to the https version of activeTab.url expect(result).to.deep.equal({
// since it's a redirect the request has the same requestId cancel: true
background.browser.webRequest.onBeforeRequest.addListener.yield({
frameId: 0,
tabId: newTab.id,
url: "https://example.com",
requestId: 1
}); });
await nextTick();
background.browser.tabs.create.should.have.been.calledOnce; background.browser.tabs.create.should.have.been.calledOnce;
}); });
}); });
describe("when redirects change requestId midflight", () => { describe("when redirects change requestId midflight", () => {
let promiseResults; let newTab;
const newTabResponses = {};
const redirectedRequest = async (options = {}) => {
global.clock = sinon.useFakeTimers();
newTab = await helper.browser.openNewTab({
url: "http://youtube.com"
}, {
options: Object.assign({
webRequestRedirects: [
"https://youtube.com",
"https://www.youtube.com",
{
url: "https://www.youtube.com",
webRequest: {
requestId: 2
}
}
],
webRequestError: true,
instantRedirects: true
}, options),
responses: newTabResponses
});
};
beforeEach(async () => { beforeEach(async () => {
// init await helper.browser.initializeWithTab({
const activeTab = {
id: 1,
cookieStoreId: "firefox-container-1", cookieStoreId: "firefox-container-1",
url: "https://www.youtube.com", url: "https://www.youtube.com"
index: 0 });
};
await helper.browser.initializeWithTab(activeTab);
// assign the activeTab.url
await helper.popup.clickElementById("container-page-assigned"); await helper.popup.clickElementById("container-page-assigned");
// http://youtube.com
const newTab = {
id: 2,
cookieStoreId: "firefox-default",
url: "http://youtube.com",
index: 1,
active: true
};
const promise1 = helper.browser.openNewTab(newTab, {
requestId: 1
});
// https://youtube.com
const [promise2] = background.browser.webRequest.onBeforeRequest.addListener.yield({
frameId: 0,
tabId: newTab.id,
url: "https://youtube.com",
requestId: 1
});
// https://www.youtube.com
const [promise3] = background.browser.webRequest.onBeforeRequest.addListener.yield({
frameId: 0,
tabId: newTab.id,
url: "https://www.youtube.com",
requestId: 1
});
// https://www.youtube.com
const [promise4] = background.browser.webRequest.onBeforeRequest.addListener.yield({
frameId: 0,
tabId: newTab.id,
url: "https://www.youtube.com",
requestId: 2
});
promiseResults = await Promise.all([promise1, promise2, promise3, promise4]);
}); });
it("should not open two confirm pages", async () => { it("should not open two confirm pages", async () => {
await redirectedRequest();
// http://youtube.com is not assigned, no cancel, no reopening // http://youtube.com is not assigned, no cancel, no reopening
expect(promiseResults[0]).to.deep.equal({}); expect(await newTabResponses.webRequest.onBeforeRequest[0]).to.deep.equal({});
// https://youtube.com is not assigned, no cancel, no reopening // https://youtube.com is not assigned, no cancel, no reopening
expect(promiseResults[1]).to.deep.equal({}); expect(await newTabResponses.webRequest.onBeforeRequest[1]).to.deep.equal({});
// https://www.youtube.com is assigned, this triggers reopening, cancel // https://www.youtube.com is assigned, this triggers reopening, cancel
expect(promiseResults[2]).to.deep.equal({ expect(await newTabResponses.webRequest.onBeforeRequest[2]).to.deep.equal({
cancel: true cancel: true
}); });
// https://www.youtube.com is assigned, this was a redirect, cancel early, no reopening // https://www.youtube.com is assigned, this was a redirect, cancel early, no reopening
expect(promiseResults[3]).to.deep.equal({ expect(await newTabResponses.webRequest.onBeforeRequest[3]).to.deep.equal({
cancel: true cancel: true
}); });
@ -114,67 +84,85 @@ describe("#940", () => {
}); });
it("should uncancel after webRequest.onCompleted", async () => { it("should uncancel after webRequest.onCompleted", async () => {
const [promise1] = background.browser.webRequest.onCompleted.addListener.yield({ await redirectedRequest();
tabId: 2 // remove onCompleted listeners because in the real world this request would never complete
// and thus might trigger unexpected behavior because the tab gets removed when reopening
background.browser.webRequest.onCompleted.addListener = sinon.stub();
background.browser.tabs.create.resetHistory();
// we create a tab with the same id and use the same request id to see if uncanceled
await helper.browser.openNewTab({
id: newTab.id,
url: "https://www.youtube.com"
}, {
options: {
webRequest: {
requestId: newTabResponses.webRequest.request.requestId
}
}
}); });
await promise1;
const [promise2] = background.browser.webRequest.onBeforeRequest.addListener.yield({ background.browser.tabs.create.should.have.been.calledOnce;
frameId: 0,
tabId: 2,
url: "https://www.youtube.com",
requestId: 123
});
await promise2;
background.browser.tabs.create.should.have.been.calledTwice;
}); });
it("should uncancel after webRequest.onErrorOccurred", async () => { it("should uncancel after webRequest.onErrorOccurred", async () => {
const [promise1] = background.browser.webRequest.onErrorOccurred.addListener.yield({ await redirectedRequest();
tabId: 2 background.browser.tabs.create.resetHistory();
// we create a tab with the same id and use the same request id to see if uncanceled
await helper.browser.openNewTab({
id: newTab.id,
url: "https://www.youtube.com"
}, {
options: {
webRequest: {
requestId: newTabResponses.webRequest.request.requestId
},
webRequestError: true
}
}); });
await promise1;
// request to assigned url in same tab background.browser.tabs.create.should.have.been.calledOnce;
const [promise2] = background.browser.webRequest.onBeforeRequest.addListener.yield({
frameId: 0,
tabId: 2,
url: "https://www.youtube.com",
requestId: 123
});
await promise2;
background.browser.tabs.create.should.have.been.calledTwice;
}); });
it("should uncancel after 2 seconds", async () => { it("should uncancel after 2 seconds", async () => {
await new Promise(resolve => setTimeout(resolve, 2000)); await redirectedRequest({
// request to assigned url in same tab webRequestDontYield: ["onCompleted", "onErrorOccurred"]
const [promise2] = background.browser.webRequest.onBeforeRequest.addListener.yield({
frameId: 0,
tabId: 2,
url: "https://www.youtube.com",
requestId: 123
}); });
await promise2; global.clock.tick(2000);
background.browser.tabs.create.should.have.been.calledTwice; background.browser.tabs.create.resetHistory();
}).timeout(2002); // we create a tab with the same id and use the same request id to see if uncanceled
await helper.browser.openNewTab({
id: newTab.id,
url: "https://www.youtube.com"
}, {
options: {
webRequest: {
requestId: newTabResponses.webRequest.request.requestId
},
webRequestError: true
}
});
background.browser.tabs.create.should.have.been.calledOnce;
});
it("should not influence the canceled url in other tabs", async () => { it("should not influence the canceled url in other tabs", async () => {
const newTab = { await redirectedRequest();
id: 123, background.browser.tabs.create.resetHistory();
await helper.browser.openNewTab({
cookieStoreId: "firefox-default", cookieStoreId: "firefox-default",
url: "https://www.youtube.com", url: "https://www.youtube.com"
index: 10, }, {
active: true options: {
}; webRequestError: true
await helper.browser.openNewTab(newTab, { }
requestId: 321
}); });
background.browser.tabs.create.should.have.been.calledTwice; background.browser.tabs.create.should.have.been.calledOnce;
});
afterEach(() => {
global.clock.restore();
}); });
}); });
}); });