-
-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Expand file tree
/
Copy pathtokens-controller-init.test.ts
More file actions
90 lines (78 loc) · 2.57 KB
/
tokens-controller-init.test.ts
File metadata and controls
90 lines (78 loc) · 2.57 KB
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
import { buildMessengerClientInitRequestMock } from '../utils/test-utils';
import { ExtendedMessenger } from '../../ExtendedMessenger';
import {
getTokensControllerMessenger,
getTokensControllerInitMessenger,
TokensControllerInitMessenger,
} from '../messengers/tokens-controller-messenger';
import { MessengerClientInitRequest } from '../types';
import { tokensControllerInit } from './tokens-controller-init';
import {
TokensController,
TokensControllerMessenger,
} from '@metamask/assets-controllers';
import { MOCK_ANY_NAMESPACE, MockAnyNamespace } from '@metamask/messenger';
jest.mock('@metamask/assets-controllers');
function getInitRequestMock(): jest.Mocked<
MessengerClientInitRequest<
TokensControllerMessenger,
TokensControllerInitMessenger
>
> {
const baseMessenger = new ExtendedMessenger<MockAnyNamespace, never, never>({
namespace: MOCK_ANY_NAMESPACE,
});
const requestMock = {
...buildMessengerClientInitRequestMock(baseMessenger),
controllerMessenger: getTokensControllerMessenger(baseMessenger),
initMessenger: getTokensControllerInitMessenger(baseMessenger),
};
baseMessenger.registerActionHandler(
// @ts-expect-error: Partial mock.
'NetworkController:getSelectedNetworkClient',
() => ({
provider: {},
}),
);
// @ts-expect-error: Partial mock.
requestMock.getMessengerClient.mockImplementation((name) => {
if (name === 'NetworkController') {
return {
state: {
selectedNetworkClientId: 'mainnet',
},
getNetworkClientById: jest
.fn()
.mockImplementation((networkClientId) => {
if (networkClientId === 'mainnet') {
return {
configuration: {
chainId: '0x1',
},
};
}
throw new Error(`Network client "${networkClientId}" not found.`);
}),
};
}
throw new Error(`Controller "${name}" not found.`);
});
return requestMock;
}
describe('tokensControllerInit', () => {
it('initializes the controller', () => {
const { controller } = tokensControllerInit(getInitRequestMock());
expect(controller).toBeInstanceOf(TokensController);
});
it('passes the proper arguments to the controller', () => {
tokensControllerInit(getInitRequestMock());
const controllerMock = jest.mocked(TokensController);
expect(controllerMock).toHaveBeenCalledWith({
messenger: expect.any(Object),
state: undefined,
chainId: '0x1',
provider: {},
tokenListService: expect.any(Object),
});
});
});