forked from chrisleekr/binance-trading-bot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsymbol-enable-action.test.js
72 lines (56 loc) · 1.84 KB
/
symbol-enable-action.test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/* eslint-disable global-require */
describe('symbol-enable-action.test.js', () => {
let mockWebSocketServer;
let mockWebSocketServerWebSocketSend;
let mockLogger;
let mockQueue;
let mockDeleteDisableAction;
beforeEach(() => {
jest.clearAllMocks().resetModules();
mockWebSocketServerWebSocketSend = jest.fn().mockResolvedValue(true);
mockWebSocketServer = {
send: mockWebSocketServerWebSocketSend
};
mockQueue = {
executeFor: jest.fn().mockResolvedValue(true),
hold: jest.fn().mockResolvedValue(true)
};
jest.mock('../../../../cronjob/trailingTradeHelper/queue', () => mockQueue);
});
describe('when symbol is provided', () => {
beforeEach(async () => {
const { logger } = require('../../../../helpers');
mockLogger = logger;
mockLogger.fields = { correlationId: 'correlationId' };
mockDeleteDisableAction = jest.fn().mockResolvedValue(true);
jest.mock('../../../../cronjob/trailingTradeHelper/common', () => ({
deleteDisableAction: mockDeleteDisableAction
}));
const { handleSymbolEnableAction } = require('../symbol-enable-action');
await handleSymbolEnableAction(logger, mockWebSocketServer, {
data: {
symbol: 'BTCUSDT'
}
});
});
it('triggers deleteDisableAction', () => {
expect(mockDeleteDisableAction).toHaveBeenCalledWith(
mockLogger,
'BTCUSDT'
);
});
it('triggers queue.executeFor', () => {
expect(mockQueue.executeFor).toHaveBeenCalledWith(mockLogger, 'BTCUSDT', {
correlationId: 'correlationId'
});
});
it('triggers ws.send', () => {
expect(mockWebSocketServerWebSocketSend).toHaveBeenCalledWith(
JSON.stringify({
result: true,
type: 'symbol-enable-action-result'
})
);
});
});
});