mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-21 17:40:48 -08:00
5156313074
Some checks are pending
Test Master / install-and-build (push) Waiting to run
Test Master / Unit tests (18.x) (push) Blocked by required conditions
Test Master / Unit tests (20.x) (push) Blocked by required conditions
Test Master / Unit tests (22.4) (push) Blocked by required conditions
Test Master / Lint (push) Blocked by required conditions
Test Master / Notify Slack on failure (push) Blocked by required conditions
Benchmark Docker Image CI / build (push) Waiting to run
58 lines
1.6 KiB
TypeScript
58 lines
1.6 KiB
TypeScript
import Container from 'typedi';
|
|
|
|
import { ExecutionMetadataRepository } from '@/databases/repositories/execution-metadata.repository';
|
|
import { ExecutionMetadataService } from '@/services/execution-metadata.service';
|
|
import { createExecution } from '@test-integration/db/executions';
|
|
import { createWorkflow } from '@test-integration/db/workflows';
|
|
|
|
import * as testDb from '../shared/test-db';
|
|
|
|
let executionMetadataRepository: ExecutionMetadataRepository;
|
|
let executionMetadataService: ExecutionMetadataService;
|
|
|
|
beforeAll(async () => {
|
|
await testDb.init();
|
|
|
|
executionMetadataRepository = Container.get(ExecutionMetadataRepository);
|
|
executionMetadataService = Container.get(ExecutionMetadataService);
|
|
});
|
|
|
|
afterAll(async () => {
|
|
await testDb.terminate();
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await testDb.truncate(['User']);
|
|
});
|
|
|
|
describe('ProjectService', () => {
|
|
describe('save', () => {
|
|
it('should deduplicate entries by exeuctionId and key, keeping the latest one', async () => {
|
|
//
|
|
// ARRANGE
|
|
//
|
|
const workflow = await createWorkflow();
|
|
const execution = await createExecution({}, workflow);
|
|
const key = 'key';
|
|
const value1 = 'value1';
|
|
const value2 = 'value2';
|
|
|
|
//
|
|
// ACT
|
|
//
|
|
await executionMetadataService.save(execution.id, { [key]: value1 });
|
|
await executionMetadataService.save(execution.id, { [key]: value2 });
|
|
|
|
//
|
|
// ASSERT
|
|
//
|
|
const rows = await executionMetadataRepository.find({
|
|
where: { executionId: execution.id, key },
|
|
});
|
|
|
|
expect(rows).toHaveLength(1);
|
|
expect(rows[0]).toHaveProperty('value', value2);
|
|
});
|
|
});
|
|
});
|