mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 12:57:29 -08:00
ci: Fix CI timeout issues (no-changelog) (#5250)
This commit is contained in:
parent
54333398ce
commit
c8a146ba31
|
@ -3,6 +3,9 @@ import express, { Router } from 'express';
|
|||
import fs from 'fs/promises';
|
||||
import path from 'path';
|
||||
|
||||
import validator from 'validator';
|
||||
import { middleware as openapiValidatorMiddleware } from 'express-openapi-validator';
|
||||
import YAML from 'yamljs';
|
||||
import type { HttpError } from 'express-openapi-validator/dist/framework/types';
|
||||
import type { OpenAPIV3 } from 'openapi-types';
|
||||
import type { JsonObject } from 'swagger-ui-express';
|
||||
|
@ -16,11 +19,9 @@ async function createApiRouter(
|
|||
version: string,
|
||||
openApiSpecPath: string,
|
||||
handlersDirectory: string,
|
||||
swaggerThemeCss: string,
|
||||
publicApiEndpoint: string,
|
||||
): Promise<Router> {
|
||||
const n8nPath = config.getEnv('path');
|
||||
const YAML = await import('yamljs');
|
||||
const swaggerDocument = YAML.load(openApiSpecPath) as JsonObject;
|
||||
// add the server depending on the config so the user can interact with the API
|
||||
// from the Swagger UI
|
||||
|
@ -33,6 +34,8 @@ async function createApiRouter(
|
|||
|
||||
if (!config.getEnv('publicApi.swaggerUi.disabled')) {
|
||||
const { serveFiles, setup } = await import('swagger-ui-express');
|
||||
const swaggerThemePath = path.join(__dirname, 'swaggerTheme.css');
|
||||
const swaggerThemeCss = await fs.readFile(swaggerThemePath, { encoding: 'utf-8' });
|
||||
|
||||
apiController.use(
|
||||
`/${publicApiEndpoint}/${version}/docs`,
|
||||
|
@ -45,12 +48,10 @@ async function createApiRouter(
|
|||
);
|
||||
}
|
||||
|
||||
const { default: validator } = await import('validator');
|
||||
const { middleware } = await import('express-openapi-validator');
|
||||
apiController.use(
|
||||
`/${publicApiEndpoint}/${version}`,
|
||||
express.json(),
|
||||
middleware({
|
||||
openapiValidatorMiddleware({
|
||||
apiSpec: openApiSpecPath,
|
||||
operationHandlers: handlersDirectory,
|
||||
validateRequests: true,
|
||||
|
@ -129,15 +130,13 @@ async function createApiRouter(
|
|||
export const loadPublicApiVersions = async (
|
||||
publicApiEndpoint: string,
|
||||
): Promise<{ apiRouters: express.Router[]; apiLatestVersion: number }> => {
|
||||
const swaggerThemePath = path.join(__dirname, 'swaggerTheme.css');
|
||||
const folders = await fs.readdir(__dirname);
|
||||
const css = (await fs.readFile(swaggerThemePath)).toString();
|
||||
const versions = folders.filter((folderName) => folderName.startsWith('v'));
|
||||
|
||||
const apiRouters = await Promise.all(
|
||||
versions.map(async (version) => {
|
||||
const openApiPath = path.join(__dirname, version, 'openapi.yml');
|
||||
return createApiRouter(version, openApiPath, __dirname, css, publicApiEndpoint);
|
||||
return createApiRouter(version, openApiPath, __dirname, publicApiEndpoint);
|
||||
}),
|
||||
);
|
||||
|
||||
|
|
|
@ -22,6 +22,7 @@ if (inE2ETests) {
|
|||
}
|
||||
if (inTest) {
|
||||
process.env.N8N_PUBLIC_API_DISABLED = 'true';
|
||||
process.env.N8N_PUBLIC_API_SWAGGERUI_DISABLED = 'true';
|
||||
} else {
|
||||
dotenv.config();
|
||||
}
|
||||
|
|
|
@ -18,7 +18,11 @@ let credentialOwnerRole: Role;
|
|||
let saveCredential: SaveCredentialFunction;
|
||||
|
||||
beforeAll(async () => {
|
||||
app = await utils.initTestServer({ endpointGroups: ['publicApi'], applyAuth: false });
|
||||
app = await utils.initTestServer({
|
||||
endpointGroups: ['publicApi'],
|
||||
applyAuth: false,
|
||||
enablePublicAPI: true,
|
||||
});
|
||||
await testDb.init();
|
||||
|
||||
utils.initConfigFile();
|
||||
|
|
|
@ -13,7 +13,11 @@ let globalOwnerRole: Role;
|
|||
let workflowRunner: ActiveWorkflowRunner;
|
||||
|
||||
beforeAll(async () => {
|
||||
app = await utils.initTestServer({ endpointGroups: ['publicApi'], applyAuth: false });
|
||||
app = await utils.initTestServer({
|
||||
endpointGroups: ['publicApi'],
|
||||
applyAuth: false,
|
||||
enablePublicAPI: true,
|
||||
});
|
||||
await testDb.init();
|
||||
|
||||
globalOwnerRole = await testDb.getGlobalOwnerRole();
|
||||
|
@ -43,7 +47,7 @@ beforeEach(async () => {
|
|||
});
|
||||
|
||||
afterEach(async () => {
|
||||
await workflowRunner.removeAll();
|
||||
await workflowRunner?.removeAll();
|
||||
});
|
||||
|
||||
afterAll(async () => {
|
||||
|
|
|
@ -17,7 +17,11 @@ let workflowOwnerRole: Role;
|
|||
let workflowRunner: ActiveWorkflowRunner;
|
||||
|
||||
beforeAll(async () => {
|
||||
app = await utils.initTestServer({ endpointGroups: ['publicApi'], applyAuth: false });
|
||||
app = await utils.initTestServer({
|
||||
endpointGroups: ['publicApi'],
|
||||
applyAuth: false,
|
||||
enablePublicAPI: true,
|
||||
});
|
||||
await testDb.init();
|
||||
|
||||
const [fetchedGlobalOwnerRole, fetchedGlobalMemberRole, fetchedWorkflowOwnerRole] =
|
||||
|
@ -49,7 +53,7 @@ beforeEach(async () => {
|
|||
});
|
||||
|
||||
afterEach(async () => {
|
||||
await workflowRunner.removeAll();
|
||||
await workflowRunner?.removeAll();
|
||||
});
|
||||
|
||||
afterAll(async () => {
|
||||
|
|
|
@ -95,7 +95,8 @@ export async function init() {
|
|||
* Drop test DB, closing bootstrap connection if existing.
|
||||
*/
|
||||
export async function terminate() {
|
||||
await Db.getConnection().destroy();
|
||||
const connection = Db.getConnection();
|
||||
if (connection.isInitialized) await connection.destroy();
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -82,16 +82,15 @@ CredentialTypes(loadNodesAndCredentials);
|
|||
|
||||
/**
|
||||
* Initialize a test server.
|
||||
*
|
||||
* @param applyAuth Whether to apply auth middleware to test server.
|
||||
* @param endpointGroups Groups of endpoints to apply to test server.
|
||||
*/
|
||||
export async function initTestServer({
|
||||
applyAuth,
|
||||
endpointGroups,
|
||||
enablePublicAPI = false,
|
||||
}: {
|
||||
applyAuth: boolean;
|
||||
endpointGroups?: EndpointGroup[];
|
||||
enablePublicAPI?: boolean;
|
||||
}) {
|
||||
const testServer = {
|
||||
app: express(),
|
||||
|
@ -124,17 +123,20 @@ export async function initTestServer({
|
|||
const [routerEndpoints, functionEndpoints] = classifyEndpointGroups(endpointGroups);
|
||||
|
||||
if (routerEndpoints.length) {
|
||||
const { apiRouters } = await loadPublicApiVersions(testServer.publicApiEndpoint);
|
||||
const map: Record<string, express.Router | express.Router[] | any> = {
|
||||
credentials: { controller: credentialsController, path: 'credentials' },
|
||||
workflows: { controller: workflowsController, path: 'workflows' },
|
||||
nodes: { controller: nodesController, path: 'nodes' },
|
||||
license: { controller: licenseController, path: 'license' },
|
||||
eventBus: { controller: eventBusRouter, path: 'eventbus' },
|
||||
publicApi: apiRouters,
|
||||
ldap: { controller: ldapController, path: 'ldap' },
|
||||
};
|
||||
|
||||
if (enablePublicAPI) {
|
||||
const { apiRouters } = await loadPublicApiVersions(testServer.publicApiEndpoint);
|
||||
map.publicApi = apiRouters;
|
||||
}
|
||||
|
||||
for (const group of routerEndpoints) {
|
||||
if (group === 'publicApi') {
|
||||
testServer.app.use(...(map[group] as express.Router[]));
|
||||
|
|
Loading…
Reference in a new issue