2023-09-25 06:49:36 -07:00
|
|
|
import { TemplatesPage } from '../pages/templates';
|
|
|
|
import { WorkflowPage } from '../pages/workflow';
|
|
|
|
|
|
|
|
import OnboardingWorkflow from '../fixtures/Onboarding_workflow.json';
|
2023-12-18 08:40:00 -08:00
|
|
|
import WorkflowTemplate from '../fixtures/Workflow_template_write_http_query.json';
|
|
|
|
import { TemplateWorkflowPage } from '../pages/template-workflow';
|
2023-09-25 06:49:36 -07:00
|
|
|
|
|
|
|
const templatesPage = new TemplatesPage();
|
|
|
|
const workflowPage = new WorkflowPage();
|
2023-12-18 08:40:00 -08:00
|
|
|
const templateWorkflowPage = new TemplateWorkflowPage();
|
2023-09-25 06:49:36 -07:00
|
|
|
|
|
|
|
describe('Templates', () => {
|
|
|
|
it('can open onboarding flow', () => {
|
|
|
|
templatesPage.actions.openOnboardingFlow(1234, OnboardingWorkflow.name, OnboardingWorkflow);
|
|
|
|
cy.url().then(($url) => {
|
|
|
|
expect($url).to.match(/.*\/workflow\/.*?onboardingId=1234$/);
|
|
|
|
})
|
|
|
|
|
|
|
|
workflowPage.actions.shouldHaveWorkflowName(`Demo: ${name}`);
|
|
|
|
|
|
|
|
workflowPage.getters.canvasNodes().should('have.length', 4);
|
|
|
|
workflowPage.getters.stickies().should('have.length', 1);
|
|
|
|
workflowPage.getters.canvasNodes().first().should('have.descendants', '.node-pin-data-icon');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can import template', () => {
|
|
|
|
templatesPage.actions.importTemplate(1234, OnboardingWorkflow.name, OnboardingWorkflow);
|
|
|
|
|
|
|
|
cy.url().then(($url) => {
|
|
|
|
expect($url).to.include('/workflow/new?templateId=1234');
|
|
|
|
});
|
2023-12-22 06:07:05 -08:00
|
|
|
|
2023-09-25 06:49:36 -07:00
|
|
|
workflowPage.getters.canvasNodes().should('have.length', 4);
|
|
|
|
workflowPage.getters.stickies().should('have.length', 1);
|
|
|
|
workflowPage.actions.shouldHaveWorkflowName(OnboardingWorkflow.name);
|
|
|
|
});
|
2023-12-18 08:40:00 -08:00
|
|
|
|
2023-12-22 06:07:05 -08:00
|
|
|
it('should save template id with the workflow', () => {
|
|
|
|
cy.visit(templatesPage.url);
|
2024-01-10 03:35:47 -08:00
|
|
|
cy.intercept('GET', '**/api/templates/**').as('loadApi');
|
|
|
|
cy.get('.el-skeleton.n8n-loading').should('not.exist');
|
|
|
|
templatesPage.getters.firstTemplateCard().should('exist');
|
|
|
|
cy.wait('@loadApi');
|
2023-12-22 06:07:05 -08:00
|
|
|
templatesPage.getters.firstTemplateCard().click();
|
|
|
|
cy.url().should('include', '/templates/');
|
|
|
|
|
|
|
|
cy.url().then(($url) => {
|
|
|
|
const templateId = $url.split('/').pop();
|
|
|
|
|
|
|
|
templatesPage.getters.useTemplateButton().click();
|
|
|
|
cy.url().should('include', '/workflow/new');
|
|
|
|
workflowPage.actions.saveWorkflowOnButtonClick();
|
|
|
|
|
|
|
|
workflowPage.actions.selectAll();
|
|
|
|
workflowPage.actions.hitCopy();
|
|
|
|
|
|
|
|
cy.grantBrowserPermissions('clipboardReadWrite', 'clipboardSanitizedWrite');
|
|
|
|
// Check workflow JSON by copying it to clipboard
|
|
|
|
cy.readClipboard().then((workflowJSON) => {
|
|
|
|
expect(workflowJSON).to.contain(`"templateId": "${templateId}"`);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2023-12-18 08:40:00 -08:00
|
|
|
it('can open template with images and hides workflow screenshots', () => {
|
|
|
|
templateWorkflowPage.actions.openTemplate(WorkflowTemplate);
|
|
|
|
|
|
|
|
templateWorkflowPage.getters.description().find('img').should('have.length', 1);
|
|
|
|
});
|
2023-09-25 06:49:36 -07:00
|
|
|
});
|