mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-13 13:57:29 -08:00
d0e44d450f
## Summary Provide details about your pull request and what it adds, fixes, or changes. Photos and videos are recommended. Adi's idea here to help diagnose: https://n8nio.slack.com/archives/C069KJBJ8HE/p1702300349277609?thread_ts=1702299930.728029&cid=C069KJBJ8HE ... #### How to test the change: 1. ... ## Issues fixed Include links to Github issue or Community forum post or **Linear ticket**: > Important in order to close automatically and provide context to reviewers ... ## Review / Merge checklist - [ ] PR title and summary are descriptive. **Remember, the title automatically goes into the changelog. Use `(no-changelog)` otherwise.** ([conventions](https://github.com/n8n-io/n8n/blob/master/.github/pull_request_title_conventions.md)) - [ ] [Docs updated](https://github.com/n8n-io/n8n-docs) or follow-up ticket created. - [ ] Tests included. > A bug is not considered fixed, unless a test is added to prevent it from happening again. A feature is not complete without tests. > > *(internal)* You can use Slack commands to trigger [e2e tests](https://www.notion.so/n8n/How-to-use-Test-Instances-d65f49dfc51f441ea44367fb6f67eb0a?pvs=4#a39f9e5ba64a48b58a71d81c837e8227) or [deploy test instance](https://www.notion.so/n8n/How-to-use-Test-Instances-d65f49dfc51f441ea44367fb6f67eb0a?pvs=4#f6a177d32bde4b57ae2da0b8e454bfce) or [deploy early access version on Cloud](https://www.notion.so/n8n/Cloudbot-3dbe779836004972b7057bc989526998?pvs=4#fef2d36ab02247e1a0f65a74f6fb534e).
49 lines
2 KiB
TypeScript
49 lines
2 KiB
TypeScript
import { WorkflowRepository } from '@/databases/repositories/workflow.repository';
|
|
import { ActiveWorkflowRunner } from '@/ActiveWorkflowRunner';
|
|
import { mockInstance } from '../shared/mocking';
|
|
import { randomName } from './shared/random';
|
|
import { generateNanoId } from '@/databases/utils/generators';
|
|
import type { WorkflowEntity } from '@/databases/entities/WorkflowEntity';
|
|
import { setupTestServer } from './shared/utils';
|
|
import type { SuperAgentTest } from 'supertest';
|
|
import { createOwner } from './shared/db/users';
|
|
import { MultiMainSetup } from '@/services/orchestration/main/MultiMainSetup.ee';
|
|
|
|
describe('DebugController', () => {
|
|
const workflowRepository = mockInstance(WorkflowRepository);
|
|
const activeWorkflowRunner = mockInstance(ActiveWorkflowRunner);
|
|
|
|
let testServer = setupTestServer({ endpointGroups: ['debug'] });
|
|
let ownerAgent: SuperAgentTest;
|
|
|
|
beforeAll(async () => {
|
|
const owner = await createOwner();
|
|
ownerAgent = testServer.authAgentFor(owner);
|
|
testServer.license.enable('feat:multipleMainInstances');
|
|
});
|
|
|
|
describe('GET /debug/multi-main-setup', () => {
|
|
test('should return multi-main setup details', async () => {
|
|
const workflowId = generateNanoId();
|
|
const activeWorkflows = [{ id: workflowId, name: randomName() }] as WorkflowEntity[];
|
|
const activationErrors = { [workflowId]: 'Failed to activate' };
|
|
const instanceId = 'main-71JdWtq306epIFki';
|
|
|
|
workflowRepository.find.mockResolvedValue(activeWorkflows);
|
|
activeWorkflowRunner.allActiveInMemory.mockReturnValue([workflowId]);
|
|
activeWorkflowRunner.getAllWorkflowActivationErrors.mockResolvedValue(activationErrors);
|
|
jest.spyOn(MultiMainSetup.prototype, 'instanceId', 'get').mockReturnValue(instanceId);
|
|
jest.spyOn(MultiMainSetup.prototype, 'fetchLeaderKey').mockResolvedValue('some-leader-key');
|
|
|
|
const response = await ownerAgent.get('/debug/multi-main-setup').expect(200);
|
|
|
|
expect(response.body.data).toMatchObject({
|
|
instanceId,
|
|
leaderKey: 'some-leader-key',
|
|
activeWorkflows,
|
|
activationErrors,
|
|
});
|
|
});
|
|
});
|
|
});
|