2023-11-27 07:18:10 -08:00
|
|
|
import { CredentialsModal, MessageBox } from '../pages/modals';
|
2023-11-30 04:09:12 -08:00
|
|
|
import {
|
|
|
|
clickUseWorkflowButtonByTitle,
|
|
|
|
visitTemplateCollectionPage,
|
|
|
|
testData,
|
|
|
|
} from '../pages/template-collection';
|
2023-12-11 10:21:10 -08:00
|
|
|
import * as templateCredentialsSetupPage from '../pages/template-credential-setup';
|
2023-11-27 07:18:10 -08:00
|
|
|
import { TemplateWorkflowPage } from '../pages/template-workflow';
|
|
|
|
import { WorkflowPage } from '../pages/workflow';
|
|
|
|
|
|
|
|
const templateWorkflowPage = new TemplateWorkflowPage();
|
|
|
|
const credentialsModal = new CredentialsModal();
|
|
|
|
const messageBox = new MessageBox();
|
|
|
|
const workflowPage = new WorkflowPage();
|
|
|
|
|
|
|
|
const testTemplate = templateCredentialsSetupPage.testData.simpleTemplate;
|
|
|
|
|
|
|
|
describe('Template credentials setup', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
cy.intercept('GET', `https://api.n8n.io/api/templates/workflows/${testTemplate.id}`, {
|
|
|
|
fixture: testTemplate.fixture,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can be opened from template workflow page', () => {
|
|
|
|
templateWorkflowPage.actions.visit(testTemplate.id);
|
2023-12-11 10:21:10 -08:00
|
|
|
templateWorkflowPage.getters.useTemplateButton().should('be.visible');
|
|
|
|
templateCredentialsSetupPage.enableTemplateCredentialSetupFeatureFlag();
|
2023-11-27 07:18:10 -08:00
|
|
|
templateWorkflowPage.actions.clickUseThisWorkflowButton();
|
|
|
|
|
|
|
|
templateCredentialsSetupPage.getters
|
|
|
|
.title(`Setup 'Promote new Shopify products on Twitter and Telegram' template`)
|
2023-11-30 04:09:12 -08:00
|
|
|
.should('be.visible');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can be opened from template collection page', () => {
|
|
|
|
visitTemplateCollectionPage(testData.ecommerceStarterPack);
|
2023-12-11 10:21:10 -08:00
|
|
|
templateCredentialsSetupPage.enableTemplateCredentialSetupFeatureFlag();
|
2023-11-30 04:09:12 -08:00
|
|
|
clickUseWorkflowButtonByTitle('Promote new Shopify products on Twitter and Telegram');
|
|
|
|
|
|
|
|
templateCredentialsSetupPage.getters
|
|
|
|
.title(`Setup 'Promote new Shopify products on Twitter and Telegram' template`)
|
2023-11-27 07:18:10 -08:00
|
|
|
.should('be.visible');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can be opened with a direct url', () => {
|
2023-12-11 10:21:10 -08:00
|
|
|
templateCredentialsSetupPage.visitTemplateCredentialSetupPage(testTemplate.id);
|
2023-11-27 07:18:10 -08:00
|
|
|
|
|
|
|
templateCredentialsSetupPage.getters
|
|
|
|
.title(`Setup 'Promote new Shopify products on Twitter and Telegram' template`)
|
|
|
|
.should('be.visible');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('has all the elements on page', () => {
|
2023-12-11 10:21:10 -08:00
|
|
|
templateCredentialsSetupPage.visitTemplateCredentialSetupPage(testTemplate.id);
|
2023-11-27 07:18:10 -08:00
|
|
|
|
|
|
|
templateCredentialsSetupPage.getters
|
|
|
|
.title(`Setup 'Promote new Shopify products on Twitter and Telegram' template`)
|
|
|
|
.should('be.visible');
|
|
|
|
|
|
|
|
templateCredentialsSetupPage.getters
|
|
|
|
.infoCallout()
|
|
|
|
.should(
|
|
|
|
'contain.text',
|
|
|
|
'You need 1x Shopify, 1x X (Formerly Twitter) and 1x Telegram account to setup this template',
|
|
|
|
);
|
|
|
|
|
|
|
|
const expectedAppNames = ['1. Shopify', '2. X (Formerly Twitter)', '3. Telegram'];
|
|
|
|
const expectedAppDescriptions = [
|
|
|
|
'The credential you select will be used in the product created node of the workflow template.',
|
|
|
|
'The credential you select will be used in the Twitter node of the workflow template.',
|
|
|
|
'The credential you select will be used in the Telegram node of the workflow template.',
|
|
|
|
];
|
|
|
|
|
|
|
|
templateCredentialsSetupPage.getters.appCredentialSteps().each(($el, index) => {
|
|
|
|
templateCredentialsSetupPage.getters
|
|
|
|
.stepHeading($el)
|
|
|
|
.should('have.text', expectedAppNames[index]);
|
|
|
|
templateCredentialsSetupPage.getters
|
|
|
|
.stepDescription($el)
|
|
|
|
.should('have.text', expectedAppDescriptions[index]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can skip template creation', () => {
|
2023-12-11 10:21:10 -08:00
|
|
|
templateCredentialsSetupPage.visitTemplateCredentialSetupPage(testTemplate.id);
|
2023-11-27 07:18:10 -08:00
|
|
|
|
|
|
|
templateCredentialsSetupPage.getters.skipLink().click();
|
|
|
|
workflowPage.getters.canvasNodes().should('have.length', 3);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can create credentials and workflow from the template', () => {
|
2023-12-11 10:21:10 -08:00
|
|
|
templateCredentialsSetupPage.visitTemplateCredentialSetupPage(testTemplate.id);
|
2023-11-27 07:18:10 -08:00
|
|
|
|
2023-12-07 09:35:34 -08:00
|
|
|
// Continue button should be disabled if no credentials are created
|
|
|
|
templateCredentialsSetupPage.getters.continueButton().should('be.disabled');
|
2023-11-27 07:18:10 -08:00
|
|
|
|
|
|
|
templateCredentialsSetupPage.getters.createAppCredentialsButton('Shopify').click();
|
|
|
|
credentialsModal.getters.editCredentialModal().find('input:first()').type('test');
|
|
|
|
credentialsModal.actions.save(false);
|
|
|
|
credentialsModal.actions.close();
|
|
|
|
|
2023-12-07 09:35:34 -08:00
|
|
|
// Continue button should be enabled if at least one has been created
|
|
|
|
templateCredentialsSetupPage.getters.continueButton().should('be.enabled');
|
|
|
|
|
2023-11-27 07:18:10 -08:00
|
|
|
templateCredentialsSetupPage.getters.createAppCredentialsButton('X (Formerly Twitter)').click();
|
|
|
|
credentialsModal.getters.editCredentialModal().find('input:first()').type('test');
|
|
|
|
credentialsModal.actions.save(false);
|
|
|
|
credentialsModal.actions.close();
|
|
|
|
messageBox.actions.cancel();
|
|
|
|
|
|
|
|
templateCredentialsSetupPage.getters.createAppCredentialsButton('Telegram').click();
|
|
|
|
credentialsModal.getters.editCredentialModal().find('input:first()').type('test');
|
|
|
|
credentialsModal.actions.save(false);
|
|
|
|
credentialsModal.actions.close();
|
|
|
|
|
|
|
|
cy.intercept('POST', '/rest/workflows').as('createWorkflow');
|
|
|
|
templateCredentialsSetupPage.getters.continueButton().should('be.enabled');
|
|
|
|
templateCredentialsSetupPage.getters.continueButton().click();
|
|
|
|
cy.wait('@createWorkflow');
|
|
|
|
|
|
|
|
workflowPage.getters.canvasNodes().should('have.length', 3);
|
|
|
|
});
|
|
|
|
});
|