1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-24 21:41:33 +01:00

[PM-5189] Working through jest tests for OverlayBackground and refining repositioning delays

This commit is contained in:
Cesar Gonzalez 2024-06-25 10:44:31 -05:00
parent e598733f9b
commit d4b423f8c1
No known key found for this signature in database
GPG Key ID: 3381A5457F8CCECF
2 changed files with 149 additions and 4 deletions

View File

@ -633,6 +633,28 @@ describe("OverlayBackground", () => {
expect(repositionInlineMenuSpy).toHaveBeenCalled(); expect(repositionInlineMenuSpy).toHaveBeenCalled();
}); });
}); });
describe("toggleInlineMenuHidden", () => {
beforeEach(async () => {
await initOverlayElementPorts();
});
it("skips adjusting the hidden status of the inline menu if the sender tab does not contain the focused field", async () => {
const focusedFieldData = createFocusedFieldDataMock({ tabId: 2 });
sendMockExtensionMessage({ command: "updateFocusedFieldData", focusedFieldData }, sender);
const otherSender = mock<chrome.runtime.MessageSender>({ tab: { id: 2 } });
await overlayBackground["toggleInlineMenuHidden"](
{ isInlineMenuHidden: true },
otherSender,
);
expect(buttonPortSpy.postMessage).not.toHaveBeenCalledWith({
command: "toggleAutofillInlineMenuHidden",
styles: { display: "none" },
});
});
});
}); });
}); });
@ -1087,6 +1109,9 @@ describe("OverlayBackground", () => {
}); });
it("sends a message to close the inline menu if the form field is not focused and not filling", async () => { it("sends a message to close the inline menu if the form field is not focused and not filling", async () => {
overlayBackground["isInlineMenuButtonVisible"] = true;
overlayBackground["isInlineMenuListVisible"] = true;
sendMockExtensionMessage({ command: "closeAutofillInlineMenu" }, sender); sendMockExtensionMessage({ command: "closeAutofillInlineMenu" }, sender);
await flushPromises(); await flushPromises();
@ -1098,6 +1123,32 @@ describe("OverlayBackground", () => {
}, },
{ frameId: 0 }, { frameId: 0 },
); );
expect(overlayBackground["isInlineMenuButtonVisible"]).toBe(false);
expect(overlayBackground["isInlineMenuListVisible"]).toBe(false);
});
it("sets a property indicating that the inline menu button is not visible", async () => {
overlayBackground["isInlineMenuButtonVisible"] = true;
sendMockExtensionMessage(
{ command: "closeAutofillInlineMenu", overlayElement: AutofillOverlayElement.Button },
sender,
);
await flushPromises();
expect(overlayBackground["isInlineMenuButtonVisible"]).toBe(false);
});
it("sets a property indicating that the inline menu list is not visible", async () => {
overlayBackground["isInlineMenuListVisible"] = true;
sendMockExtensionMessage(
{ command: "closeAutofillInlineMenu", overlayElement: AutofillOverlayElement.List },
sender,
);
await flushPromises();
expect(overlayBackground["isInlineMenuListVisible"]).toBe(false);
}); });
}); });
@ -1106,6 +1157,21 @@ describe("OverlayBackground", () => {
await initOverlayElementPorts(); await initOverlayElementPorts();
}); });
it("skips checking if the inline menu is focused if the sender does not contain the focused field", async () => {
const sender = mock<chrome.runtime.MessageSender>({ tab: { id: 1 } });
const focusedFieldData = createFocusedFieldDataMock();
sendMockExtensionMessage({ command: "updateFocusedFieldData", focusedFieldData });
sendMockExtensionMessage({ command: "checkAutofillInlineMenuFocused" }, sender);
expect(listPortSpy.postMessage).not.toHaveBeenCalledWith({
command: "checkAutofillInlineMenuListFocused",
});
expect(buttonPortSpy.postMessage).not.toHaveBeenCalledWith({
command: "checkAutofillInlineMenuButtonFocused",
});
});
it("will check if the inline menu list is focused if the list port is open", () => { it("will check if the inline menu list is focused if the list port is open", () => {
sendMockExtensionMessage({ command: "checkAutofillInlineMenuFocused" }); sendMockExtensionMessage({ command: "checkAutofillInlineMenuFocused" });
@ -1314,6 +1380,70 @@ describe("OverlayBackground", () => {
}); });
}); });
describe("updateAutofillInlineMenuElementIsVisibleStatus message handler", () => {
let sender: chrome.runtime.MessageSender;
let focusedFieldData: FocusedFieldData;
beforeEach(() => {
sender = mock<chrome.runtime.MessageSender>({ tab: { id: 1 } });
focusedFieldData = createFocusedFieldDataMock();
overlayBackground["isInlineMenuButtonVisible"] = true;
overlayBackground["isInlineMenuListVisible"] = false;
});
it("skips updating the inline menu visibility status if the sender tab does not contain the focused field", async () => {
const otherSender = mock<chrome.runtime.MessageSender>({ tab: { id: 2 } });
sendMockExtensionMessage(
{ command: "updateFocusedFieldData", focusedFieldData },
otherSender,
);
sendMockExtensionMessage(
{
command: "updateAutofillInlineMenuElementIsVisibleStatus",
overlayElement: AutofillOverlayElement.Button,
isInlineMenuElementVisible: false,
},
sender,
);
expect(overlayBackground["isInlineMenuButtonVisible"]).toBe(true);
expect(overlayBackground["isInlineMenuListVisible"]).toBe(false);
});
it("updates the visibility status of the inline menu button", async () => {
sendMockExtensionMessage({ command: "updateFocusedFieldData", focusedFieldData }, sender);
sendMockExtensionMessage(
{
command: "updateAutofillInlineMenuElementIsVisibleStatus",
overlayElement: AutofillOverlayElement.Button,
isInlineMenuElementVisible: false,
},
sender,
);
expect(overlayBackground["isInlineMenuButtonVisible"]).toBe(false);
expect(overlayBackground["isInlineMenuListVisible"]).toBe(false);
});
it("updates the visibility status of the inline menu list", async () => {
sendMockExtensionMessage({ command: "updateFocusedFieldData", focusedFieldData }, sender);
sendMockExtensionMessage(
{
command: "updateAutofillInlineMenuElementIsVisibleStatus",
overlayElement: AutofillOverlayElement.List,
isInlineMenuElementVisible: true,
},
sender,
);
expect(overlayBackground["isInlineMenuButtonVisible"]).toBe(true);
expect(overlayBackground["isInlineMenuListVisible"]).toBe(true);
});
});
describe("checkIsAutofillInlineMenuButtonVisible message handler", () => { describe("checkIsAutofillInlineMenuButtonVisible message handler", () => {
it("returns true when the inline menu button is visible", async () => { it("returns true when the inline menu button is visible", async () => {
overlayBackground["isInlineMenuButtonVisible"] = true; overlayBackground["isInlineMenuButtonVisible"] = true;

View File

@ -589,6 +589,11 @@ export class OverlayBackground implements OverlayBackgroundInterface {
this.isInlineMenuListVisible = false; this.isInlineMenuListVisible = false;
} }
if (!overlayElement) {
this.isInlineMenuButtonVisible = false;
this.isInlineMenuListVisible = false;
}
void BrowserApi.tabSendMessage(sender.tab, { command, overlayElement }, sendOptions); void BrowserApi.tabSendMessage(sender.tab, { command, overlayElement }, sendOptions);
} }
@ -1233,15 +1238,25 @@ export class OverlayBackground implements OverlayBackgroundInterface {
return; return;
} }
if (this.focusedFieldData.frameId > 0 && this.subFrameOffsetsForTab[sender.tab.id]) { this.resetFocusedFieldSubFrameOffsets(sender);
this.subFrameOffsetsForTab[sender.tab.id].set(this.focusedFieldData.frameId, null);
}
this.cancelInlineMenuFadeInAndPositionUpdate(); this.cancelInlineMenuFadeInAndPositionUpdate();
void this.toggleInlineMenuHidden({ isInlineMenuHidden: true }, sender); void this.toggleInlineMenuHidden({ isInlineMenuHidden: true }, sender);
this.repositionInlineMenuSubject.next(sender); this.repositionInlineMenuSubject.next(sender);
} }
/**
* Sets the sub frame offsets for the currently focused field's frame to a null value .
* This ensures that we can delay presentation of the inline menu after a reposition
* event if the user clicks on a field before the sub frames can be rebuilt.
*
* @param sender
*/
private resetFocusedFieldSubFrameOffsets(sender: chrome.runtime.MessageSender) {
if (this.focusedFieldData.frameId > 0 && this.subFrameOffsetsForTab[sender.tab.id]) {
this.subFrameOffsetsForTab[sender.tab.id].set(this.focusedFieldData.frameId, null);
}
}
/** /**
* Triggers when a focus event occurs within a tab. Will reposition the inline menu * Triggers when a focus event occurs within a tab. Will reposition the inline menu
* if the focused field is within the viewport. * if the focused field is within the viewport.