diff --git a/tests/desktop/normal/features_and_events/frm_node.spec.ts b/tests/desktop/normal/features_and_events/frm_node.spec.ts new file mode 100644 index 00000000..50a46c04 --- /dev/null +++ b/tests/desktop/normal/features_and_events/frm_node.spec.ts @@ -0,0 +1,167 @@ +import { test, expect } from "@playwright/test"; +import { Helioviewer } from "../../../page_objects/helioviewer"; +import { mockEvents } from "../../../utils/events"; + +/** + * This test mocks some random events for CCMC + * then selects some specific frm, + * then asserts all of the childnodes of frm , should be checked, + * also asserts all of the other nodes, should be unchecked + */ +test("Checked frm should check all of its child event_instances", async ({ page, browser }, info) => { + // mocked event data + const events = { + CCMC: { + et1: { + et1frm1: { + et1frm1ei1: {}, + et1frm1ei2: {} + } + }, + et2: { + et2frm1: { + et2frm1ei1: {}, + et2frm1ei2: {}, + et2frm1ei3: {} + }, + et2frm2: { + et2frm2ei1: {}, + et2frm2ei2: {} + } + } + } + }; + + // mock events + await mockEvents(page, events); + + // load helioviewer + let hv = new Helioviewer(page, info); + + // Action 1 : BROWSE TO HELIOVIEWER + await hv.Load(); + await hv.CloseAllNotifications(); + + // Action 2 : Open left sources panel + await hv.OpenSidebar(); + + // Parse event tree pieces + const ccmc = hv.parseTree("CCMC"); + + // Action 3 : Check frm et2frm1 + await ccmc.toggleCheckFRM("et2", "et2frm1"); + + // Action 4: Assert all event markers belongs to FRM = et2frm1 to be visible, + await ccmc.assertEventVisible("et2frm1ei1"); + await ccmc.assertEventVisible("et2frm1ei2"); + await ccmc.assertEventVisible("et2frm1ei3"); + + // Action 5: Assert all event markers of not selected frms should not be visible, + await ccmc.assertEventNotVisible("et1frm1ei1"); + await ccmc.assertEventNotVisible("et1frm1ei2"); + await ccmc.assertEventNotVisible("et2frm2ei1"); + await ccmc.assertEventNotVisible("et2frm2ei2"); + + // Action 5: Open up all frm branches + await ccmc.toggleBranchFRM("et1", "et1frm1"); + await ccmc.toggleBranchFRM("et2", "et2frm1"); + await ccmc.toggleBranchFRM("et2", "et2frm2"); + + // Action 6: Assert all nodes for branch et2 + await ccmc.assertEventTypeNodeHalfChecked("et2"); + await ccmc.assertFrmNodeChecked("et2", "et2frm1"); + await ccmc.assertEventInstanceNodeChecked("et2", "et2frm1", "et2frm1ei1"); + await ccmc.assertEventInstanceNodeChecked("et2", "et2frm1", "et2frm1ei2"); + await ccmc.assertEventInstanceNodeChecked("et2", "et2frm1", "et2frm1ei3"); + await ccmc.assertFrmNodeUnchecked("et2", "et2frm2"); + await ccmc.assertEventInstanceNodeUnchecked("et2", "et2frm2", "et2frm2ei1"); + await ccmc.assertEventInstanceNodeUnchecked("et2", "et2frm2", "et2frm2ei2"); + + // Action 7: Assert all nodes for branch et1 + await ccmc.assertEventTypeNodeUnchecked("et1"); + await ccmc.assertFrmNodeUnchecked("et1", "et1frm1"); + await ccmc.assertEventInstanceNodeUnchecked("et1", "et1frm1", "et1frm1ei1"); + await ccmc.assertEventInstanceNodeUnchecked("et1", "et1frm1", "et1frm1ei2"); + + // Action 8: Toggle again to uncheck all child nodes of selected frm + await ccmc.toggleCheckFRM("et2", "et2frm1"); + + // Action 9: Assert et2 branch state should be reset now + await ccmc.assertEventTypeNodeUnchecked("et2"); + await ccmc.assertFrmNodeUnchecked("et2", "et2frm1"); + await ccmc.assertFrmNodeUnchecked("et2", "et2frm2"); + await ccmc.assertEventInstanceNodeUnchecked("et2", "et2frm1", "et2frm1ei1"); + await ccmc.assertEventInstanceNodeUnchecked("et2", "et2frm1", "et2frm1ei2"); + await ccmc.assertEventInstanceNodeUnchecked("et2", "et2frm1", "et2frm1ei3"); + await ccmc.assertEventInstanceNodeUnchecked("et2", "et2frm2", "et2frm2ei1"); + await ccmc.assertEventInstanceNodeUnchecked("et2", "et2frm2", "et2frm2ei2"); +}); + +/** + * This test mocks some random events for CCMC + * then selects some specific frms + * then reloads the page and validates all selected frms should still be checked, + */ +test("Selected FRMs should still be selected after page reload", async ({ page, browser }, info) => { + // mocked event data + const events = { + CCMC: { + et1: { + et1frm1: { + et1frm1ei1: {}, + et1frm1ei2: {} + }, + et1frm2: { + et1frm2ei1: {}, + et1frm2ei2: {} + } + }, + et2: { + et2frm1: { + et2frm1ei1: {}, + et2frm1ei2: {}, + et2frm1ei3: {} + }, + et2frm2: { + et2frm2ei1: {}, + et2frm2ei2: {} + } + } + } + }; + + // mock events + await mockEvents(page, events); + + // load helioviewer + let hv = new Helioviewer(page, info); + + // Action 1 : BROWSE TO HELIOVIEWER + await hv.Load(); + await hv.CloseAllNotifications(); + + // Action 2 : Open left sources panel + await hv.OpenSidebar(); + + // Parse event tree pieces + const ccmc = hv.parseTree("CCMC"); + + // Action 3 : Check some event_types + await ccmc.toggleCheckFRM("et1", "et1frm2"); + await ccmc.toggleCheckFRM("et2", "et2frm1"); + await ccmc.toggleCheckFRM("et2", "et2frm2"); + + // Action 4 : Refresh page + await hv.Load(); + await hv.CloseAllNotifications(); + + // Action 5: Assert all et1 branch + await ccmc.assertEventTypeNodeHalfChecked("et1"); + await ccmc.assertFrmNodeUnchecked("et1", "et1frm1"); + await ccmc.assertFrmNodeChecked("et1", "et1frm2"); + + // Action 6: Assert all et2 branch + await ccmc.assertEventTypeNodeChecked("et2"); + await ccmc.assertFrmNodeChecked("et2", "et2frm1"); + await ccmc.assertFrmNodeChecked("et2", "et2frm2"); +}); diff --git a/tests/page_objects/event_tree.ts b/tests/page_objects/event_tree.ts index 919e301f..2db69207 100644 --- a/tests/page_objects/event_tree.ts +++ b/tests/page_objects/event_tree.ts @@ -399,6 +399,17 @@ class EventTree { await expect(eventTypeNode).toHaveClass(/jstree-unchecked/); } + /** + * This function checks if the given event_type node is halfchecked (not all of its childrens are selected) in event tree. + * @param {string} event_type, The event type name pointing to the node in tree (e.g. "Active Region", "Corona Hole"). + * @return {Promise} A promise for you to wait for assertion to complete. + */ + async assertEventTypeNodeHalfChecked(event_type: string): Promise { + const eventTypeLink = this.page.getByRole("link", { name: EventTree.makeNumericRegex(event_type) }); + const eventTypeNode = await this.root.getByRole("listitem").filter({ has: eventTypeLink }); + await expect(eventTypeNode).toHaveClass(/jstree-undetermined/); + } + /** * This function checks if the given frm node is unchecked in event tree. * @param {string} event_type, The event type name pointing to the node in tree (e.g. "Active Region", "Corona Hole").