mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 12:57:29 -08:00
b67f803cbe
* fix branch * fix deserialize, add filewriter * add catchAll eventGroup/Name * adding simple Redis sender and receiver to eventbus * remove native node threads * improve eventbus * refactor and simplify * more refactoring and syslog client * more refactor, improved endpoints and eventbus * remove local broker and receivers from mvp * destination de/serialization * create MessageEventBusDestinationEntity * db migrations, load destinations at startup * add delete destination endpoint * pnpm merge and circular import fix * delete destination fix * trigger log file shuffle after size reached * add environment variables for eventbus * reworking event messages * serialize to thread fix * some refactor and lint fixing * add emit to eventbus * cleanup and fix sending unsent * quicksave frontend trial * initial EventTree vue component * basic log streaming settings in vue * http request code merge * create destination settings modals * fix eventmessage options types * credentials are loaded * fix and clean up frontend code * move request code to axios * update lock file * merge fix * fix redis build * move destination interfaces into workflow pkg * revive sentry as destination * migration fixes and frontend cleanup * N8N-5777 / N8N-5789 N8N-5788 * N8N-5784 * N8N-5782 removed event levels * N8N-5790 sentry destination cleanup * N8N-5786 and refactoring * N8N-5809 and refactor/cleanup * UI fixes and anonymize renaming * N8N-5837 * N8N-5834 * fix no-items UI issues * remove card / settings label in modal * N8N-5842 fix * disable webhook auth for now and update ui * change sidebar to tabs * remove payload option * extend audit events with more user data * N8N-5853 and UI revert to sidebar * remove redis destination * N8N-5864 / N8N-5868 / N8N-5867 / N8N-5865 * ui and licensing fixes * add node events and info bubbles to frontend * ui wording changes * frontend tests * N8N-5896 and ee rename * improves backend tests * merge fix * fix backend test * make linter happy * remove unnecessary cfg / limit actions to owners * fix multiple sentry DSN and anon bug * eslint fix * more tests and fixes * merge fix * fix workflow audit events * remove 'n8n.workflow.execution.error' event * merge fix * lint fix * lint fix * review fixes * fix merge * prettier fixes * merge * review changes * use loggerproxy * remove catch from internal hook promises * fix tests * lint fix * include review PR changes * review changes * delete duplicate lines from a bad merge * decouple log-streaming UI options from public API * logstreaming -> log-streaming for consistency * do not make unnecessary api calls when log streaming is disabled * prevent sentryClient.close() from being called if init failed * fix the e2e test for log-streaming * review changes * cleanup * use `private` for one last private property * do not use node prefix package names.. just yet * remove unused import * fix the tests because there is a folder called `events`, tsc-alias is messing up all imports for native events module. https://github.com/justkey007/tsc-alias/issues/152 Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ <aditya@netroy.in>
191 lines
5.4 KiB
TypeScript
191 lines
5.4 KiB
TypeScript
// ***********************************************
|
|
// This example commands.js shows you how to
|
|
// create various custom commands and overwrite
|
|
// existing commands.
|
|
//
|
|
// For more comprehensive examples of custom
|
|
// commands please read more here:
|
|
// https://on.cypress.io/custom-commands
|
|
// ***********************************************
|
|
//
|
|
//
|
|
// -- This is a parent command --
|
|
// Cypress.Commands.add('login', (email, password) => { ... })
|
|
//
|
|
//
|
|
// -- This is a child command --
|
|
// Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... })
|
|
//
|
|
//
|
|
// -- This is a dual command --
|
|
// Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... })
|
|
//
|
|
//
|
|
// -- This will overwrite an existing command --
|
|
// Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... })
|
|
|
|
import { WorkflowsPage, SigninPage, SignupPage } from '../pages';
|
|
import { N8N_AUTH_COOKIE } from '../constants';
|
|
import { WorkflowPage as WorkflowPageClass } from '../pages/workflow';
|
|
import { MessageBox } from '../pages/modals/message-box';
|
|
|
|
Cypress.Commands.add('getByTestId', (selector, ...args) => {
|
|
return cy.get(`[data-test-id="${selector}"]`, ...args);
|
|
});
|
|
|
|
Cypress.Commands.add('createFixtureWorkflow', (fixtureKey, workflowName) => {
|
|
const WorkflowPage = new WorkflowPageClass();
|
|
|
|
// We need to force the click because the input is hidden
|
|
WorkflowPage.getters
|
|
.workflowImportInput()
|
|
.selectFile(`cypress/fixtures/${fixtureKey}`, { force: true });
|
|
WorkflowPage.getters.workflowNameInput().should('be.disabled');
|
|
WorkflowPage.getters.workflowNameInput().parent().click();
|
|
WorkflowPage.getters.workflowNameInput().should('be.enabled');
|
|
WorkflowPage.getters.workflowNameInput().clear().type(workflowName).type('{enter}');
|
|
|
|
WorkflowPage.getters.saveButton().should('contain', 'Saved');
|
|
});
|
|
|
|
Cypress.Commands.add(
|
|
'findChildByTestId',
|
|
{ prevSubject: true },
|
|
(subject: Cypress.Chainable<JQuery<HTMLElement>>, childTestId) => {
|
|
return subject.find(`[data-test-id="${childTestId}"]`);
|
|
},
|
|
);
|
|
|
|
Cypress.Commands.add('waitForLoad', () => {
|
|
cy.getByTestId('node-view-loader').should('not.exist', { timeout: 10000 });
|
|
cy.get('.el-loading-mask').should('not.exist', { timeout: 10000 });
|
|
});
|
|
|
|
Cypress.Commands.add('signin', ({ email, password }) => {
|
|
const signinPage = new SigninPage();
|
|
const workflowsPage = new WorkflowsPage();
|
|
|
|
cy.session(
|
|
[email, password],
|
|
() => {
|
|
cy.visit(signinPage.url);
|
|
|
|
signinPage.getters.form().within(() => {
|
|
signinPage.getters.email().type(email);
|
|
signinPage.getters.password().type(password);
|
|
signinPage.getters.submit().click();
|
|
});
|
|
|
|
// we should be redirected to /workflows
|
|
cy.url().should('include', workflowsPage.url);
|
|
},
|
|
{
|
|
validate() {
|
|
cy.getCookie(N8N_AUTH_COOKIE).should('exist');
|
|
},
|
|
},
|
|
);
|
|
});
|
|
|
|
Cypress.Commands.add('setup', ({ email, firstName, lastName, password }) => {
|
|
const signupPage = new SignupPage();
|
|
|
|
cy.visit(signupPage.url);
|
|
|
|
signupPage.getters.form().within(() => {
|
|
cy.url().then((url) => {
|
|
if (url.endsWith(signupPage.url)) {
|
|
signupPage.getters.email().type(email);
|
|
signupPage.getters.firstName().type(firstName);
|
|
signupPage.getters.lastName().type(lastName);
|
|
signupPage.getters.password().type(password);
|
|
signupPage.getters.submit().click();
|
|
} else {
|
|
cy.log('User already signed up');
|
|
}
|
|
});
|
|
});
|
|
});
|
|
|
|
Cypress.Commands.add('skipSetup', () => {
|
|
const signupPage = new SignupPage();
|
|
const workflowsPage = new WorkflowsPage();
|
|
const Confirmation = new MessageBox();
|
|
|
|
cy.visit(signupPage.url);
|
|
|
|
signupPage.getters.form().within(() => {
|
|
cy.url().then((url) => {
|
|
if (url.endsWith(signupPage.url)) {
|
|
signupPage.getters.skip().click();
|
|
|
|
Confirmation.getters.header().should('contain.text', 'Skip owner account setup?');
|
|
Confirmation.actions.confirm();
|
|
|
|
// we should be redirected to /workflows
|
|
cy.url().should('include', workflowsPage.url);
|
|
} else {
|
|
cy.log('User already signed up');
|
|
}
|
|
});
|
|
});
|
|
});
|
|
|
|
Cypress.Commands.add('resetAll', () => {
|
|
cy.task('reset');
|
|
Cypress.session.clearAllSavedSessions();
|
|
});
|
|
|
|
Cypress.Commands.add('setupOwner', (payload) => {
|
|
cy.task('setup-owner', payload);
|
|
});
|
|
|
|
Cypress.Commands.add('enableFeature', (feature) => {
|
|
cy.task('enable-feature', feature);
|
|
});
|
|
|
|
Cypress.Commands.add('grantBrowserPermissions', (...permissions: string[]) => {
|
|
if (Cypress.isBrowser('chrome')) {
|
|
cy.wrap(
|
|
Cypress.automation('remote:debugger:protocol', {
|
|
command: 'Browser.grantPermissions',
|
|
params: {
|
|
permissions,
|
|
origin: window.location.origin,
|
|
},
|
|
}),
|
|
);
|
|
}
|
|
});
|
|
Cypress.Commands.add('readClipboard', () =>
|
|
cy.window().its('navigator.clipboard').invoke('readText'),
|
|
);
|
|
|
|
Cypress.Commands.add('paste', { prevSubject: true }, (selector, pastePayload) => {
|
|
// https://developer.mozilla.org/en-US/docs/Web/API/Element/paste_event
|
|
cy.wrap(selector).then(($destination) => {
|
|
const pasteEvent = Object.assign(new Event('paste', { bubbles: true, cancelable: true }), {
|
|
clipboardData: {
|
|
getData: () => pastePayload,
|
|
},
|
|
});
|
|
$destination[0].dispatchEvent(pasteEvent);
|
|
});
|
|
});
|
|
|
|
Cypress.Commands.add('drag', (selector, xDiff, yDiff) => {
|
|
const element = cy.get(selector);
|
|
element.should('exist');
|
|
|
|
const originalLocation = Cypress.$(selector)[0].getBoundingClientRect();
|
|
|
|
element.trigger('mousedown');
|
|
element.trigger('mousemove', {
|
|
which: 1,
|
|
pageX: originalLocation.right + xDiff,
|
|
pageY: originalLocation.top + yDiff,
|
|
force: true,
|
|
});
|
|
element.trigger('mouseup');
|
|
});
|