mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-03 17:07:29 -08:00
168 lines
5.4 KiB
TypeScript
168 lines
5.4 KiB
TypeScript
import {
|
|
HTTP_REQUEST_NODE_NAME,
|
|
IF_NODE_NAME,
|
|
MANUAL_TRIGGER_NODE_NAME,
|
|
EDIT_FIELDS_SET_NODE_NAME,
|
|
} from '../constants';
|
|
import { WorkflowPage, NDV, WorkflowExecutionsTab } from '../pages';
|
|
|
|
const workflowPage = new WorkflowPage();
|
|
const ndv = new NDV();
|
|
const executionsTab = new WorkflowExecutionsTab();
|
|
|
|
describe('Debug', () => {
|
|
beforeEach(() => {
|
|
cy.enableFeature('debugInEditor');
|
|
});
|
|
|
|
it('should be able to debug executions', () => {
|
|
cy.intercept('GET', '/rest/executions?filter=*').as('getExecutions');
|
|
cy.intercept('GET', '/rest/executions/*').as('getExecution');
|
|
cy.intercept('POST', '/rest/workflows/**/run?**').as('postWorkflowRun');
|
|
|
|
cy.signinAsOwner();
|
|
|
|
workflowPage.actions.visit();
|
|
|
|
workflowPage.actions.addInitialNodeToCanvas(MANUAL_TRIGGER_NODE_NAME);
|
|
workflowPage.actions.addNodeToCanvas(HTTP_REQUEST_NODE_NAME);
|
|
workflowPage.actions.openNode(HTTP_REQUEST_NODE_NAME);
|
|
ndv.actions.typeIntoParameterInput('url', 'https://foo.bar');
|
|
ndv.actions.close();
|
|
|
|
workflowPage.actions.addNodeToCanvas(EDIT_FIELDS_SET_NODE_NAME, true);
|
|
|
|
workflowPage.actions.saveWorkflowUsingKeyboardShortcut();
|
|
workflowPage.actions.executeWorkflow();
|
|
|
|
cy.wait(['@postWorkflowRun']);
|
|
|
|
executionsTab.actions.switchToExecutionsTab();
|
|
|
|
cy.wait(['@getExecutions']);
|
|
|
|
executionsTab.getters.executionDebugButton().should('have.text', 'Debug in editor').click();
|
|
cy.url().should('include', '/debug');
|
|
cy.get('.el-notification').contains('Execution data imported').should('be.visible');
|
|
cy.get('.matching-pinned-nodes-confirmation').should('not.exist');
|
|
|
|
workflowPage.actions.openNode(HTTP_REQUEST_NODE_NAME);
|
|
ndv.actions.clearParameterInput('url');
|
|
ndv.actions.typeIntoParameterInput('url', 'https://postman-echo.com/get?foo1=bar1&foo2=bar2');
|
|
ndv.actions.close();
|
|
|
|
workflowPage.actions.saveWorkflowUsingKeyboardShortcut();
|
|
cy.url().should('not.include', '/debug');
|
|
|
|
workflowPage.actions.executeWorkflow();
|
|
|
|
cy.wait(['@postWorkflowRun']);
|
|
|
|
workflowPage.actions.openNode(HTTP_REQUEST_NODE_NAME);
|
|
ndv.actions.pinData();
|
|
ndv.actions.close();
|
|
|
|
executionsTab.actions.switchToExecutionsTab();
|
|
|
|
cy.wait(['@getExecutions']);
|
|
|
|
executionsTab.getters.executionListItems().should('have.length', 2).first().click();
|
|
cy.wait(['@getExecution']);
|
|
|
|
executionsTab.getters.executionDebugButton().should('have.text', 'Copy to editor').click();
|
|
|
|
let confirmDialog = cy.get('.matching-pinned-nodes-confirmation').filter(':visible');
|
|
confirmDialog.find('li').should('have.length', 2);
|
|
confirmDialog.get('.btn--cancel').click();
|
|
|
|
cy.wait(['@getExecutions']);
|
|
|
|
executionsTab.getters.executionListItems().should('have.length', 2).first().click();
|
|
cy.wait(['@getExecution']);
|
|
|
|
executionsTab.getters.executionDebugButton().should('have.text', 'Copy to editor').click();
|
|
|
|
confirmDialog = cy.get('.matching-pinned-nodes-confirmation').filter(':visible');
|
|
confirmDialog.find('li').should('have.length', 2);
|
|
confirmDialog.get('.btn--confirm').click();
|
|
cy.url().should('include', '/debug');
|
|
|
|
cy.ifCanvasVersion(
|
|
() => {
|
|
workflowPage.getters
|
|
.canvasNodes()
|
|
.first()
|
|
.should('have.descendants', '.node-pin-data-icon');
|
|
workflowPage.getters
|
|
.canvasNodes()
|
|
.not(':first')
|
|
.should('not.have.descendants', '.node-pin-data-icon');
|
|
},
|
|
() => {
|
|
workflowPage.getters
|
|
.canvasNodes()
|
|
.first()
|
|
.should('have.descendants', '[data-test-id="canvas-node-status-pinned"]');
|
|
workflowPage.getters
|
|
.canvasNodes()
|
|
.not(':first')
|
|
.should('not.have.descendants', '[data-test-id="canvas-node-status-pinned"]');
|
|
},
|
|
);
|
|
|
|
cy.reload(true);
|
|
cy.wait(['@getExecution']);
|
|
|
|
confirmDialog = cy.get('.matching-pinned-nodes-confirmation').filter(':visible');
|
|
confirmDialog.find('li').should('have.length', 1);
|
|
confirmDialog.get('.btn--confirm').click();
|
|
|
|
workflowPage.getters.canvasNodePlusEndpointByName(EDIT_FIELDS_SET_NODE_NAME).click();
|
|
workflowPage.actions.addNodeToCanvas(IF_NODE_NAME, false);
|
|
workflowPage.actions.saveWorkflowUsingKeyboardShortcut();
|
|
cy.url().should('not.include', '/debug');
|
|
|
|
executionsTab.actions.switchToExecutionsTab();
|
|
cy.wait(['@getExecutions']);
|
|
executionsTab.getters.executionDebugButton().should('have.text', 'Copy to editor').click();
|
|
|
|
confirmDialog = cy.get('.matching-pinned-nodes-confirmation').filter(':visible');
|
|
confirmDialog.find('li').should('have.length', 1);
|
|
confirmDialog.get('.btn--confirm').click();
|
|
cy.url().should('include', '/debug');
|
|
|
|
cy.ifCanvasVersion(
|
|
() => {
|
|
workflowPage.getters.canvasNodes().last().find('.node-info-icon').should('be.empty');
|
|
},
|
|
() => {
|
|
workflowPage.getters
|
|
.canvasNodes()
|
|
.last()
|
|
.find('[class*="statusIcons"]')
|
|
.should('not.exist');
|
|
},
|
|
);
|
|
|
|
workflowPage.getters.canvasNodes().first().dblclick();
|
|
ndv.actions.unPinData();
|
|
|
|
ndv.actions.close();
|
|
|
|
workflowPage.actions.saveWorkflowUsingKeyboardShortcut();
|
|
cy.url().should('not.include', '/debug');
|
|
|
|
workflowPage.actions.executeWorkflow();
|
|
workflowPage.actions.zoomToFit();
|
|
workflowPage.actions.deleteNode(IF_NODE_NAME);
|
|
|
|
executionsTab.actions.switchToExecutionsTab();
|
|
cy.wait(['@getExecutions']);
|
|
executionsTab.getters.executionListItems().should('have.length', 3).first().click();
|
|
cy.wait(['@getExecution']);
|
|
executionsTab.getters.executionDebugButton().should('have.text', 'Copy to editor').click();
|
|
cy.get('.el-notification').contains("Some execution data wasn't imported").should('be.visible');
|
|
cy.url().should('include', '/debug');
|
|
});
|
|
});
|