mirror of
https://github.com/ToolJet/ToolJet
synced 2026-05-03 03:17:32 +00:00
230 lines
7.1 KiB
JavaScript
230 lines
7.1 KiB
JavaScript
import { commonSelectors } from "Selectors/common";
|
|
import { commonText } from "Texts/common";
|
|
import { workflowsText } from "Texts/workflows";
|
|
import { workflowSelector } from "Selectors/workflows";
|
|
import { deleteDatasource } from "Support/utils/dataSource";
|
|
import { selectAppCardOption, closeModal } from "Support/utils/common";
|
|
|
|
export const createWorkflowApp = (wfName) => {
|
|
cy.get(workflowSelector.globalWorkFlowsIcon).click();
|
|
cy.get(workflowSelector.workflowsCreateButton).click();
|
|
cy.get(workflowSelector.workFlowNameInputField).type(wfName);
|
|
cy.get(workflowSelector.createWorkFlowsButton).click();
|
|
};
|
|
|
|
export const fillStartNodeJsonInput = () => {
|
|
cy.get(workflowSelector.startNode).click({ force: true });
|
|
cy.get(workflowSelector.parametersInputField)
|
|
.click()
|
|
.realType("{")
|
|
.realType('"')
|
|
.realType(workflowsText.jsonKey)
|
|
.realType('"')
|
|
.realType(":")
|
|
.realType('"')
|
|
.realType(workflowsText.jsonValue)
|
|
.realType('"')
|
|
.realType("}");
|
|
cy.wait(500);
|
|
cy.get("body").click(50, 50);
|
|
cy.wait(500);
|
|
};
|
|
|
|
export const connectDataSourceNode = (nodeType) => {
|
|
cy.get(workflowSelector.startNodeHandleRight).trigger("mousedown", {
|
|
button: 0,
|
|
force: true,
|
|
});
|
|
|
|
cy.get(".react-flow__pane")
|
|
.trigger("mousemove", { clientX: 600, clientY: 300, force: true })
|
|
.wait(500)
|
|
.trigger("mouseup", { force: true });
|
|
cy.contains(nodeType, { timeout: 5000 })
|
|
.scrollIntoView()
|
|
.click({ force: true });
|
|
};
|
|
|
|
export const verifyTextInResponseOutput = (expectedText) => {
|
|
cy.get(workflowSelector.workflowRunButton).click();
|
|
cy.get(workflowSelector.workflowLogs).should(
|
|
"have.text",
|
|
workflowsText.workflowRunLogText
|
|
);
|
|
|
|
cy.get('[data-cy="response1-node-name"]').click();
|
|
cy.wait(500);
|
|
cy.get('[data-cy="tab-output"]').click();
|
|
|
|
cy.wait(500);
|
|
cy.get("body").then(($body) => {
|
|
if (
|
|
$body
|
|
.find("span.node-key")
|
|
.filter((_, el) => el.innerText === workflowsText.responseNodeKey)
|
|
.length
|
|
) {
|
|
cy.contains("span.node-key", workflowsText.responseNodeKey, {
|
|
timeout: 3000,
|
|
})
|
|
.click({ force: true })
|
|
.wait(300);
|
|
}
|
|
});
|
|
|
|
cy.get("body").then(($body) => {
|
|
const icons = $body.find("span.json-tree-node-icon");
|
|
if (icons.length > 0) {
|
|
cy.wrap(icons).each(($el) => {
|
|
if ($el[0].style.transform === "rotate(0deg)") {
|
|
cy.wrap($el).click({ force: true }).wait(200);
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
cy.get(".json-tree-valuetype", { timeout: 3000 }).then(($vals) => {
|
|
const texts = [...$vals].map((el) => el.innerText.trim());
|
|
const match = texts.some((txt) => txt.includes(expectedText));
|
|
expect(
|
|
match,
|
|
`Expected some value to include "${expectedText}", but got:\n\n${texts.join("\n")}`
|
|
).to.be.true;
|
|
});
|
|
};
|
|
|
|
export const connectNodeToResponseNode = (nodeTitle, returnStatement) => {
|
|
cy.get(workflowSelector.nodeName(nodeTitle))
|
|
.should("exist")
|
|
.parents(".react-flow__node")
|
|
.as("sourceNode");
|
|
|
|
cy.get(workflowSelector.nodeHandleRight(nodeTitle)).trigger("mousedown", {
|
|
button: 0,
|
|
force: true,
|
|
});
|
|
|
|
cy.get(".react-flow__pane")
|
|
.trigger("mousemove", { clientX: 800, clientY: 400, force: true })
|
|
.trigger("mouseup", { force: true });
|
|
|
|
cy.wait(500);
|
|
|
|
cy.contains(workflowsText.responseNodeLabel, { timeout: 5000 }).click({
|
|
force: true,
|
|
});
|
|
cy.wait(500);
|
|
|
|
cy.get(workflowSelector.nodeName(workflowsText.responseNodeName))
|
|
.parents(".react-flow__node")
|
|
.click({ force: true });
|
|
|
|
cy.get('.cm-content[contenteditable="true"]')
|
|
.clearAndTypeOnCodeMirror("")
|
|
.clearAndTypeOnCodeMirror("")
|
|
.clearAndTypeOnCodeMirror(returnStatement);
|
|
|
|
cy.get("body").click(50, 50);
|
|
cy.wait(500);
|
|
};
|
|
|
|
export const deleteWorkflow = (wfName) => {
|
|
cy.intercept("DELETE", "/api/apps/*").as("appDeleted");
|
|
navigateBackToWorkflowsDashboard();
|
|
cy.get(commonSelectors.appCard(wfName))
|
|
.realHover()
|
|
.find(commonSelectors.appCardOptionsButton)
|
|
.realHover()
|
|
.click();
|
|
cy.get(workflowSelector.deleteWorkFlowOption).click();
|
|
cy.get(commonSelectors.buttonSelector(commonText.modalYesButton)).click();
|
|
cy.wait("@appDeleted");
|
|
};
|
|
|
|
export const navigateBackToWorkflowsDashboard = () => {
|
|
cy.get(commonSelectors.pageLogo).click();
|
|
cy.get(commonSelectors.backToAppOption).click();
|
|
};
|
|
|
|
export const revealWorkflowToken = (selectors) => {
|
|
cy.get(selectors.workflowTokenField)
|
|
.invoke("text")
|
|
.then((tokenText) => {
|
|
if (tokenText.includes("*")) {
|
|
cy.get(selectors.workflowTokenEyeIcon).click({ force: true });
|
|
cy.wait(300);
|
|
revealWorkflowToken(selectors);
|
|
}
|
|
});
|
|
};
|
|
|
|
export const deleteWorkflowfromDashboard = (wfName) => {
|
|
cy.intercept("DELETE", "/api/apps/*").as("appDeleted");
|
|
cy.get(commonSelectors.appCard(wfName))
|
|
.realHover()
|
|
.find(commonSelectors.appCardOptionsButton)
|
|
.realHover()
|
|
.click();
|
|
cy.get(workflowSelector.deleteWorkFlowOption).click();
|
|
cy.get(commonSelectors.buttonSelector(commonText.modalYesButton)).click();
|
|
cy.wait("@appDeleted");
|
|
};
|
|
|
|
export const exportWorkflowApp = (
|
|
wfName,
|
|
fixtureFile = "cypress/fixtures/exportedApp.json"
|
|
) => {
|
|
navigateBackToWorkflowsDashboard();
|
|
|
|
selectAppCardOption(
|
|
wfName,
|
|
commonSelectors.appCardOptions(workflowsText.exportWFOption)
|
|
);
|
|
cy.wait(2000);
|
|
|
|
cy.exec("ls -t ./cypress/downloads/ | head -1").then((result) => {
|
|
const downloadedAppExportFileName = result.stdout.trim();
|
|
const filePath = `./cypress/downloads/${downloadedAppExportFileName}`;
|
|
cy.readFile(filePath, { timeout: 15000 }).then((json) => {
|
|
cy.writeFile(fixtureFile, json);
|
|
});
|
|
});
|
|
deleteWorkflowfromDashboard(wfName);
|
|
};
|
|
|
|
export const importWorkflowApp = (
|
|
wfName,
|
|
fixturePath = "cypress/fixtures/exportedApp.json"
|
|
) => {
|
|
cy.get(workflowSelector.importWorkFlowsOption).click();
|
|
cy.get(workflowSelector.importWorkFlowsLabel).click();
|
|
cy.get('input[type="file"]').first().selectFile(fixturePath, { force: true });
|
|
cy.wait(2000);
|
|
cy.get(workflowSelector.workFlowNameInputField).clear().type(wfName);
|
|
cy.get(workflowSelector.importWorkFlowsButton).click();
|
|
};
|
|
|
|
export const deleteAppandWorkflowAfterExecution = (wfName, appName) => {
|
|
cy.backToApps();
|
|
cy.deleteApp(appName);
|
|
cy.get(workflowSelector.globalWorkFlowsIcon).click();
|
|
cy.intercept("DELETE", "/api/apps/*").as("appDeleted");
|
|
cy.get(commonSelectors.appCard(wfName))
|
|
.realHover()
|
|
.find(commonSelectors.appCardOptionsButton)
|
|
.realHover()
|
|
.click();
|
|
cy.get(workflowSelector.deleteWorkFlowOption).click();
|
|
cy.get(commonSelectors.buttonSelector(commonText.modalYesButton)).click();
|
|
cy.wait("@appDeleted");
|
|
};
|
|
|
|
export const addWorkflowInApp = (wfName) => {
|
|
cy.get(workflowSelector.showDSPopoverButton).click();
|
|
cy.get(workflowSelector.workflowSearchInput).type(workflowsText.workflowText);
|
|
cy.contains(`[id*="react-select-"]`, workflowsText.workflowText).click();
|
|
cy.get(workflowSelector.queryRenameInput).clear().type(wfName);
|
|
cy.get(workflowSelector.workflowDropdown).click();
|
|
cy.get(workflowSelector.workflowSelectInput).realType(wfName);
|
|
cy.get(workflowSelector.workflowSelectOption).contains(wfName).click();
|
|
};
|