test(editor): Fix flaky e2e tests (#4779)
* test(editor): Fix default-owner and credentials saving e2e specs * test(editor): fix webhook node test * test(editor): add cy command for browser permissions * test(editor): add cy command for reading clipboard * Fix 3-default-owner spec * Resolve review comments * Merge spec * Fix http node and expression editor modal specs * Add optional param to credentials modal saving action to wait for the test endpoint * Improve sidebar items clicking and increase credentials saving timeout * Rename http e2e spec to fix ordering * Fix pasting and copying of nodes e2e spec * Make sure to only access error.cause if it exists * Wait longer for the keyboard press * Make sure to focus the body when typing * Try type delay * Use meta key based on the running platform * Fix flaky workflowTagElements getter Co-authored-by: Csaba Tuncsik <csaba@n8n.io>
This commit is contained in:
@@ -24,92 +24,86 @@ const firstName = randFirstName();
|
||||
const lastName = randLastName();
|
||||
|
||||
describe('Default owner', () => {
|
||||
// todo test should redirect to setup if have not skipped
|
||||
|
||||
beforeEach(() => {
|
||||
before(() => {
|
||||
cy.resetAll();
|
||||
});
|
||||
beforeEach(() => {
|
||||
cy.visit('/');
|
||||
})
|
||||
|
||||
it('should be able to use n8n without user management and setup UM', () => {
|
||||
describe('should skip owner setup', () => {
|
||||
cy.skipSetup();
|
||||
cy.url().should('include', workflowsPage.url);
|
||||
});
|
||||
it('should skip owner setup', () => {
|
||||
cy.skipSetup();
|
||||
});
|
||||
|
||||
describe('should be able to create workflows', () => {
|
||||
workflowsPage.getters.newWorkflowButtonCard().should('be.visible');
|
||||
workflowsPage.getters.newWorkflowButtonCard().click();
|
||||
it('should be able to create workflows', () => {
|
||||
workflowsPage.getters.newWorkflowButtonCard().should('be.visible');
|
||||
workflowsPage.getters.newWorkflowButtonCard().click();
|
||||
|
||||
cy.createFixtureWorkflow('Test_workflow_1.json', `Test workflow`);
|
||||
cy.createFixtureWorkflow('Test_workflow_1.json', `Test workflow`);
|
||||
|
||||
// reload page, ensure owner still has access
|
||||
cy.reload();
|
||||
// reload page, ensure owner still has access
|
||||
cy.reload();
|
||||
|
||||
workflowPage.getters.workflowNameInput().should('contain.value', 'Test workflow');
|
||||
});
|
||||
workflowPage.getters.workflowNameInput().should('contain.value', 'Test workflow');
|
||||
});
|
||||
|
||||
describe('should be able to add new credentials', () => {
|
||||
cy.visit(credentialsPage.url);
|
||||
it('should be able to add new credentials', () => {
|
||||
cy.visit(credentialsPage.url);
|
||||
|
||||
credentialsPage.getters.emptyListCreateCredentialButton().click();
|
||||
credentialsPage.getters.emptyListCreateCredentialButton().click();
|
||||
|
||||
credentialsModal.getters.newCredentialModal().should('be.visible');
|
||||
credentialsModal.getters.newCredentialTypeSelect().should('be.visible');
|
||||
credentialsModal.getters.newCredentialTypeOption('Notion API').click();
|
||||
credentialsModal.getters.newCredentialModal().should('be.visible');
|
||||
credentialsModal.getters.newCredentialTypeSelect().should('be.visible');
|
||||
credentialsModal.getters.newCredentialTypeOption('Notion API').click();
|
||||
|
||||
credentialsModal.getters.newCredentialTypeButton().click();
|
||||
credentialsModal.getters.newCredentialTypeButton().click();
|
||||
|
||||
credentialsModal.getters.connectionParameter('API Key').type('1234567890');
|
||||
credentialsModal.getters.connectionParameter('API Key').type('1234567890');
|
||||
|
||||
credentialsModal.actions.setName('My awesome Notion account');
|
||||
credentialsModal.actions.save();
|
||||
credentialsModal.actions.setName('My awesome Notion account');
|
||||
credentialsModal.actions.save();
|
||||
|
||||
credentialsModal.actions.close();
|
||||
credentialsModal.actions.close();
|
||||
|
||||
credentialsModal.getters.newCredentialModal().should('not.exist');
|
||||
credentialsModal.getters.editCredentialModal().should('not.exist');
|
||||
credentialsModal.getters.newCredentialModal().should('not.exist');
|
||||
credentialsModal.getters.editCredentialModal().should('not.exist');
|
||||
|
||||
credentialsPage.getters.credentialCards().should('have.length', 1);
|
||||
});
|
||||
credentialsPage.getters.credentialCards().should('have.length', 1);
|
||||
});
|
||||
|
||||
describe('should be able to setup UM from settings', () => {
|
||||
mainSidebar.getters.settings().should('be.visible');
|
||||
mainSidebar.actions.goToSettings();
|
||||
cy.url().should('include', settingsUsersPage.url);
|
||||
it('should be able to setup UM from settings', () => {
|
||||
mainSidebar.getters.settings().should('be.visible');
|
||||
mainSidebar.actions.goToSettings();
|
||||
cy.url().should('include', settingsUsersPage.url);
|
||||
|
||||
settingsUsersPage.actions.goToOwnerSetup();
|
||||
settingsUsersPage.actions.goToOwnerSetup();
|
||||
|
||||
cy.url().should('include', signupPage.url);
|
||||
});
|
||||
cy.url().should('include', signupPage.url);
|
||||
});
|
||||
|
||||
describe('should be able to setup instance and migrate workflows and credentials', () => {
|
||||
cy.setup({ email, firstName, lastName, password });
|
||||
it('should be able to setup instance and migrate workflows and credentials', () => {
|
||||
cy.setup({ email, firstName, lastName, password });
|
||||
|
||||
messageBox.getters.content().should('contain.text', '1 existing workflow and 1 credential')
|
||||
messageBox.getters.content().should('contain.text', '1 existing workflow and 1 credential')
|
||||
|
||||
messageBox.actions.confirm();
|
||||
});
|
||||
messageBox.actions.confirm();
|
||||
cy.url().should('include', settingsUsersPage.url);
|
||||
settingsSidebar.actions.back();
|
||||
|
||||
describe('should be redirected back to users page after setup', () => {
|
||||
cy.url().should('include', settingsUsersPage.url);
|
||||
// todo test users and that owner exist
|
||||
});
|
||||
cy.url().should('include', workflowsPage.url);
|
||||
|
||||
describe('can click back to workflows and have migrated workflow after setup', () => {
|
||||
settingsSidebar.actions.back();
|
||||
workflowsPage.getters.workflowCards().should('have.length', 1);
|
||||
});
|
||||
|
||||
cy.url().should('include', workflowsPage.url);
|
||||
it('can click back to main menu and have migrated credential after setup', () => {
|
||||
cy.signin({ email, password });
|
||||
cy.visit(workflowsPage.url);
|
||||
|
||||
workflowsPage.getters.workflowCards().should('have.length', 1);
|
||||
});
|
||||
mainSidebar.actions.goToCredentials();
|
||||
|
||||
describe('can click back to main menu and have migrated credential after setup', () => {
|
||||
mainSidebar.actions.goToCredentials();
|
||||
cy.url().should('include', credentialsPage.url);
|
||||
|
||||
cy.url().should('include', workflowsPage.url);
|
||||
|
||||
workflowsPage.getters.workflowCards().should('have.length', 1);
|
||||
});
|
||||
credentialsPage.getters.credentialCards().should('have.length', 1);
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
@@ -29,19 +29,9 @@ describe('NDV', () => {
|
||||
ndv.getters.nodeExecuteButton().first().click();
|
||||
ndv.getters.copyInput().click();
|
||||
|
||||
cy.wrap(Cypress.automation('remote:debugger:protocol', {
|
||||
command: 'Browser.grantPermissions',
|
||||
params: {
|
||||
permissions: ['clipboardReadWrite', 'clipboardSanitizedWrite'],
|
||||
origin: window.location.origin,
|
||||
},
|
||||
}));
|
||||
cy.grantBrowserPermissions('clipboardReadWrite', 'clipboardSanitizedWrite');
|
||||
|
||||
cy.window().its('navigator.permissions')
|
||||
.invoke('query', {name: 'clipboard-read'})
|
||||
.its('state').should('equal', 'granted');
|
||||
|
||||
cy.window().its('navigator.clipboard').invoke('readText').then(url => {
|
||||
cy.readClipboard().then(url => {
|
||||
cy.request({
|
||||
method: 'GET',
|
||||
url,
|
||||
|
||||
@@ -90,10 +90,16 @@ describe('Workflow Actions', () => {
|
||||
});
|
||||
|
||||
it('should copy nodes', () => {
|
||||
const metaKey = Cypress.platform === 'darwin' ? '{meta}' : '{ctrl}';
|
||||
|
||||
WorkflowPage.actions.addNodeToCanvas(SCHEDULE_TRIGGER_NODE_NAME);
|
||||
WorkflowPage.actions.addNodeToCanvas(CODE_NODE);
|
||||
cy.get('body').type('{meta}', { release: false }).type('a');
|
||||
cy.get('body').type('{meta}', { release: false }).type('c');
|
||||
WorkflowPage.getters.canvasNodes().should('have.have.length', 2);
|
||||
|
||||
cy.get("#node-creator").should('not.exist');
|
||||
cy.get('body').type(metaKey, { delay: 500, release: false }).type('a');
|
||||
cy.get('.jtk-drag-selected').should('have.length', 2);
|
||||
cy.get('body').type(metaKey, { delay: 500, release: false }).type('c');
|
||||
WorkflowPage.getters.successToast().should('exist');
|
||||
});
|
||||
|
||||
|
||||
@@ -15,10 +15,10 @@ describe('HTTP Request node', () => {
|
||||
WorkflowPage.actions.addInitialNodeToCanvas('Manual Trigger');
|
||||
WorkflowPage.actions.addNodeToCanvas('HTTP Request');
|
||||
WorkflowPage.actions.openNodeNdv('HTTP Request');
|
||||
WorkflowPage.actions.typeIntoParameterInput('url', 'https://google.com');
|
||||
WorkflowPage.actions.typeIntoParameterInput('url', 'https://catfact.ninja/fact');
|
||||
|
||||
WorkflowPage.actions.executeNodeFromNdv();
|
||||
|
||||
WorkflowPage.getters.ndvOutputPanel().contains('<!doctype html>');
|
||||
WorkflowPage.getters.ndvOutputPanel().contains('fact');
|
||||
});
|
||||
});
|
||||
@@ -4,7 +4,7 @@ const WorkflowPage = new WorkflowPageClass();
|
||||
|
||||
describe('Expression editor modal', () => {
|
||||
before(() => {
|
||||
cy.task('db:reset');
|
||||
cy.task('reset');
|
||||
cy.skipSetup();
|
||||
});
|
||||
|
||||
|
||||
Reference in New Issue
Block a user