mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 21:07:28 -08:00
57 lines
1.6 KiB
TypeScript
57 lines
1.6 KiB
TypeScript
import Container from 'typedi';
|
|
import { Logger } from '@/Logger';
|
|
import config from '@/config';
|
|
import { RedisService } from '@/services/redis.service';
|
|
import { mockInstance } from '../../shared/mocking';
|
|
|
|
jest.mock('ioredis', () => {
|
|
const Redis = require('ioredis-mock');
|
|
if (typeof Redis === 'object') {
|
|
// the first mock is an ioredis shim because ioredis-mock depends on it
|
|
// https://github.com/stipsan/ioredis-mock/blob/master/src/index.js#L101-L111
|
|
return {
|
|
Command: { _transformer: { argument: {}, reply: {} } },
|
|
};
|
|
}
|
|
// second mock for our code
|
|
return function (...args: any) {
|
|
return new Redis(args);
|
|
};
|
|
});
|
|
|
|
mockInstance(Logger);
|
|
const redisService = Container.get(RedisService);
|
|
|
|
function setDefaultConfig() {
|
|
config.set('executions.mode', 'queue');
|
|
}
|
|
|
|
const PUBSUB_CHANNEL = 'testchannel';
|
|
|
|
describe('RedisService', () => {
|
|
beforeAll(async () => {
|
|
setDefaultConfig();
|
|
});
|
|
|
|
test('should create pubsub publisher and subscriber with handler', async () => {
|
|
const pub = await redisService.getPubSubPublisher();
|
|
const sub = await redisService.getPubSubSubscriber();
|
|
expect(pub).toBeDefined();
|
|
expect(sub).toBeDefined();
|
|
|
|
const mockHandler = jest.fn();
|
|
mockHandler.mockImplementation((_channel: string, _message: string) => {});
|
|
sub.addMessageHandler(PUBSUB_CHANNEL, mockHandler);
|
|
await sub.subscribe(PUBSUB_CHANNEL);
|
|
await pub.publish(PUBSUB_CHANNEL, 'test');
|
|
await new Promise((resolve) =>
|
|
setTimeout(async () => {
|
|
resolve(0);
|
|
}, 50),
|
|
);
|
|
expect(mockHandler).toHaveBeenCalled();
|
|
await sub.destroy();
|
|
await pub.destroy();
|
|
});
|
|
});
|