mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-17 10:02:05 +00:00
56 lines
1.4 KiB
TypeScript
56 lines
1.4 KiB
TypeScript
import type { User } from '@/databases/entities/user';
|
|
import { Telemetry } from '@/telemetry';
|
|
import { mockInstance } from '@test/mocking';
|
|
|
|
import { createTeamProject } from '../shared/db/projects';
|
|
import { createUser } from '../shared/db/users';
|
|
import { createWorkflowWithTrigger } from '../shared/db/workflows';
|
|
import * as testDb from '../shared/test-db';
|
|
import * as utils from '../shared/utils/';
|
|
|
|
mockInstance(Telemetry);
|
|
|
|
let member: User;
|
|
|
|
const testServer = utils.setupTestServer({
|
|
endpointGroups: ['workflows'],
|
|
enabledFeatures: ['feat:sharing', 'feat:advancedPermissions'],
|
|
});
|
|
|
|
beforeAll(async () => {
|
|
member = await createUser({ role: 'global:member' });
|
|
|
|
await utils.initNodeTypes();
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
await testDb.truncate(['Workflow', 'SharedWorkflow']);
|
|
});
|
|
|
|
describe('PUT /:workflowId/transfer', () => {
|
|
// This tests does not mock the ActiveWorkflowManager, which helps catching
|
|
// possible deadlocks when using transactions wrong.
|
|
test('can transfer an active workflow', async () => {
|
|
//
|
|
// ARRANGE
|
|
//
|
|
const destinationProject = await createTeamProject('Team Project', member);
|
|
|
|
const workflow = await createWorkflowWithTrigger({ active: true }, member);
|
|
|
|
//
|
|
// ACT
|
|
//
|
|
const response = await testServer
|
|
.authAgentFor(member)
|
|
.put(`/workflows/${workflow.id}/transfer`)
|
|
.send({ destinationProjectId: destinationProject.id })
|
|
.expect(200);
|
|
|
|
//
|
|
// ASSERT
|
|
//
|
|
expect(response.body).toEqual({});
|
|
});
|
|
});
|