@reown/appkit-controllers 1.7.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +190 -0
- package/dist/esm/exports/index.js +32 -0
- package/dist/esm/exports/index.js.map +1 -0
- package/dist/esm/exports/modal.js +2 -0
- package/dist/esm/exports/modal.js.map +1 -0
- package/dist/esm/exports/react.js +52 -0
- package/dist/esm/exports/react.js.map +1 -0
- package/dist/esm/exports/vue.js +63 -0
- package/dist/esm/exports/vue.js.map +1 -0
- package/dist/esm/src/controllers/AccountController.js +160 -0
- package/dist/esm/src/controllers/AccountController.js.map +1 -0
- package/dist/esm/src/controllers/AlertController.js +35 -0
- package/dist/esm/src/controllers/AlertController.js.map +1 -0
- package/dist/esm/src/controllers/ApiController.js +260 -0
- package/dist/esm/src/controllers/ApiController.js.map +1 -0
- package/dist/esm/src/controllers/AssetController.js +43 -0
- package/dist/esm/src/controllers/AssetController.js.map +1 -0
- package/dist/esm/src/controllers/BlockchainApiController.js +472 -0
- package/dist/esm/src/controllers/BlockchainApiController.js.map +1 -0
- package/dist/esm/src/controllers/ChainController.js +548 -0
- package/dist/esm/src/controllers/ChainController.js.map +1 -0
- package/dist/esm/src/controllers/ConnectionController.js +190 -0
- package/dist/esm/src/controllers/ConnectionController.js.map +1 -0
- package/dist/esm/src/controllers/ConnectorController.js +272 -0
- package/dist/esm/src/controllers/ConnectorController.js.map +1 -0
- package/dist/esm/src/controllers/EnsController.js +144 -0
- package/dist/esm/src/controllers/EnsController.js.map +1 -0
- package/dist/esm/src/controllers/EventsController.js +76 -0
- package/dist/esm/src/controllers/EventsController.js.map +1 -0
- package/dist/esm/src/controllers/ModalController.js +120 -0
- package/dist/esm/src/controllers/ModalController.js.map +1 -0
- package/dist/esm/src/controllers/OnRampController.js +132 -0
- package/dist/esm/src/controllers/OnRampController.js.map +1 -0
- package/dist/esm/src/controllers/OptionsController.js +146 -0
- package/dist/esm/src/controllers/OptionsController.js.map +1 -0
- package/dist/esm/src/controllers/PublicStateController.js +20 -0
- package/dist/esm/src/controllers/PublicStateController.js.map +1 -0
- package/dist/esm/src/controllers/RouterController.js +125 -0
- package/dist/esm/src/controllers/RouterController.js.map +1 -0
- package/dist/esm/src/controllers/SendController.js +305 -0
- package/dist/esm/src/controllers/SendController.js.map +1 -0
- package/dist/esm/src/controllers/SnackController.js +62 -0
- package/dist/esm/src/controllers/SnackController.js.map +1 -0
- package/dist/esm/src/controllers/SwapController.js +674 -0
- package/dist/esm/src/controllers/SwapController.js.map +1 -0
- package/dist/esm/src/controllers/ThemeController.js +55 -0
- package/dist/esm/src/controllers/ThemeController.js.map +1 -0
- package/dist/esm/src/controllers/TooltipController.js +41 -0
- package/dist/esm/src/controllers/TooltipController.js.map +1 -0
- package/dist/esm/src/controllers/TransactionsController.js +113 -0
- package/dist/esm/src/controllers/TransactionsController.js.map +1 -0
- package/dist/esm/src/utils/AssetUtil.js +86 -0
- package/dist/esm/src/utils/AssetUtil.js.map +1 -0
- package/dist/esm/src/utils/ConstantsUtil.js +239 -0
- package/dist/esm/src/utils/ConstantsUtil.js.map +1 -0
- package/dist/esm/src/utils/CoreHelperUtil.js +354 -0
- package/dist/esm/src/utils/CoreHelperUtil.js.map +1 -0
- package/dist/esm/src/utils/ERC7811Util.js +111 -0
- package/dist/esm/src/utils/ERC7811Util.js.map +1 -0
- package/dist/esm/src/utils/EnsUtil.js +10 -0
- package/dist/esm/src/utils/EnsUtil.js.map +1 -0
- package/dist/esm/src/utils/FetchUtil.js +73 -0
- package/dist/esm/src/utils/FetchUtil.js.map +1 -0
- package/dist/esm/src/utils/MobileWallet.js +31 -0
- package/dist/esm/src/utils/MobileWallet.js.map +1 -0
- package/dist/esm/src/utils/OptionsUtil.js +29 -0
- package/dist/esm/src/utils/OptionsUtil.js.map +1 -0
- package/dist/esm/src/utils/RouterUtil.js +23 -0
- package/dist/esm/src/utils/RouterUtil.js.map +1 -0
- package/dist/esm/src/utils/SIWXUtil.js +258 -0
- package/dist/esm/src/utils/SIWXUtil.js.map +1 -0
- package/dist/esm/src/utils/SendApiUtil.js +65 -0
- package/dist/esm/src/utils/SendApiUtil.js.map +1 -0
- package/dist/esm/src/utils/StorageUtil.js +485 -0
- package/dist/esm/src/utils/StorageUtil.js.map +1 -0
- package/dist/esm/src/utils/SwapApiUtil.js +89 -0
- package/dist/esm/src/utils/SwapApiUtil.js.map +1 -0
- package/dist/esm/src/utils/SwapCalculationUtil.js +74 -0
- package/dist/esm/src/utils/SwapCalculationUtil.js.map +1 -0
- package/dist/esm/src/utils/TypeUtil.js +2 -0
- package/dist/esm/src/utils/TypeUtil.js.map +1 -0
- package/dist/esm/tests/constants/OnrampTransactions.js +151 -0
- package/dist/esm/tests/constants/OnrampTransactions.js.map +1 -0
- package/dist/esm/tests/controllers/AccountController.test.js +186 -0
- package/dist/esm/tests/controllers/AccountController.test.js.map +1 -0
- package/dist/esm/tests/controllers/AlertController.test.js +48 -0
- package/dist/esm/tests/controllers/AlertController.test.js.map +1 -0
- package/dist/esm/tests/controllers/ApiController.test.js +608 -0
- package/dist/esm/tests/controllers/ApiController.test.js.map +1 -0
- package/dist/esm/tests/controllers/AssetController.test.js +92 -0
- package/dist/esm/tests/controllers/AssetController.test.js.map +1 -0
- package/dist/esm/tests/controllers/BlockchainApiController.test.js +38 -0
- package/dist/esm/tests/controllers/BlockchainApiController.test.js.map +1 -0
- package/dist/esm/tests/controllers/ChainController.test.js +382 -0
- package/dist/esm/tests/controllers/ChainController.test.js.map +1 -0
- package/dist/esm/tests/controllers/ConnectionController.test.js +151 -0
- package/dist/esm/tests/controllers/ConnectionController.test.js.map +1 -0
- package/dist/esm/tests/controllers/ConnectorController.test.js +282 -0
- package/dist/esm/tests/controllers/ConnectorController.test.js.map +1 -0
- package/dist/esm/tests/controllers/EnsController.test.js +186 -0
- package/dist/esm/tests/controllers/EnsController.test.js.map +1 -0
- package/dist/esm/tests/controllers/EventsController.test.js +47 -0
- package/dist/esm/tests/controllers/EventsController.test.js.map +1 -0
- package/dist/esm/tests/controllers/ModalController.test.js +66 -0
- package/dist/esm/tests/controllers/ModalController.test.js.map +1 -0
- package/dist/esm/tests/controllers/OnRampController.test.js +118 -0
- package/dist/esm/tests/controllers/OnRampController.test.js.map +1 -0
- package/dist/esm/tests/controllers/OptionsController.test.js +42 -0
- package/dist/esm/tests/controllers/OptionsController.test.js.map +1 -0
- package/dist/esm/tests/controllers/PublicStateController.test.js +33 -0
- package/dist/esm/tests/controllers/PublicStateController.test.js.map +1 -0
- package/dist/esm/tests/controllers/RouterController.test.js +103 -0
- package/dist/esm/tests/controllers/RouterController.test.js.map +1 -0
- package/dist/esm/tests/controllers/SendController.test.js +136 -0
- package/dist/esm/tests/controllers/SendController.test.js.map +1 -0
- package/dist/esm/tests/controllers/SnackController.test.js +86 -0
- package/dist/esm/tests/controllers/SnackController.test.js.map +1 -0
- package/dist/esm/tests/controllers/SwapController.test.js +105 -0
- package/dist/esm/tests/controllers/SwapController.test.js.map +1 -0
- package/dist/esm/tests/controllers/ThemeController.test.js +26 -0
- package/dist/esm/tests/controllers/ThemeController.test.js.map +1 -0
- package/dist/esm/tests/controllers/TooltipController.test.js +40 -0
- package/dist/esm/tests/controllers/TooltipController.test.js.map +1 -0
- package/dist/esm/tests/controllers/TransactionsController.test.js +239 -0
- package/dist/esm/tests/controllers/TransactionsController.test.js.map +1 -0
- package/dist/esm/tests/hooks/react.test.js +149 -0
- package/dist/esm/tests/hooks/react.test.js.map +1 -0
- package/dist/esm/tests/hooks/vue.test.js +56 -0
- package/dist/esm/tests/hooks/vue.test.js.map +1 -0
- package/dist/esm/tests/mocks/ChainController.js +24 -0
- package/dist/esm/tests/mocks/ChainController.js.map +1 -0
- package/dist/esm/tests/mocks/SwapController.js +118 -0
- package/dist/esm/tests/mocks/SwapController.js.map +1 -0
- package/dist/esm/tests/mocks/useAppKitAccount.js +41 -0
- package/dist/esm/tests/mocks/useAppKitAccount.js.map +1 -0
- package/dist/esm/tests/utils/AssetUtil.test.js +108 -0
- package/dist/esm/tests/utils/AssetUtil.test.js.map +1 -0
- package/dist/esm/tests/utils/CoreHelperUtil.test.js +67 -0
- package/dist/esm/tests/utils/CoreHelperUtil.test.js.map +1 -0
- package/dist/esm/tests/utils/ERC7811.test.js +268 -0
- package/dist/esm/tests/utils/ERC7811.test.js.map +1 -0
- package/dist/esm/tests/utils/EnsUtil.test.js +23 -0
- package/dist/esm/tests/utils/EnsUtil.test.js.map +1 -0
- package/dist/esm/tests/utils/FetchUtil.test.js +175 -0
- package/dist/esm/tests/utils/FetchUtil.test.js.map +1 -0
- package/dist/esm/tests/utils/MobileWallet.test.js +72 -0
- package/dist/esm/tests/utils/MobileWallet.test.js.map +1 -0
- package/dist/esm/tests/utils/OptionsUtil.test.js +20 -0
- package/dist/esm/tests/utils/OptionsUtil.test.js.map +1 -0
- package/dist/esm/tests/utils/RouterUtil.test.js +62 -0
- package/dist/esm/tests/utils/RouterUtil.test.js.map +1 -0
- package/dist/esm/tests/utils/SendApiUtil.test.js +340 -0
- package/dist/esm/tests/utils/SendApiUtil.test.js.map +1 -0
- package/dist/esm/tests/utils/StorageUtil.test.js +162 -0
- package/dist/esm/tests/utils/StorageUtil.test.js.map +1 -0
- package/dist/esm/tests/utils/SwapApiUtil.test.js +213 -0
- package/dist/esm/tests/utils/SwapApiUtil.test.js.map +1 -0
- package/dist/esm/tests/utils/SwapCalculationUtil.test.js +80 -0
- package/dist/esm/tests/utils/SwapCalculationUtil.test.js.map +1 -0
- package/dist/esm/tsconfig.tsbuildinfo +1 -0
- package/dist/types/exports/index.d.ts +51 -0
- package/dist/types/exports/modal.d.ts +2 -0
- package/dist/types/exports/react.d.ts +9 -0
- package/dist/types/exports/vue.d.ts +9 -0
- package/dist/types/src/controllers/AccountController.d.ts +56 -0
- package/dist/types/src/controllers/AlertController.d.ts +17 -0
- package/dist/types/src/controllers/ApiController.d.ts +52 -0
- package/dist/types/src/controllers/AssetController.d.ts +22 -0
- package/dist/types/src/controllers/BlockchainApiController.d.ts +59 -0
- package/dist/types/src/controllers/ChainController.d.ts +75 -0
- package/dist/types/src/controllers/ConnectionController.d.ts +86 -0
- package/dist/types/src/controllers/ConnectorController.d.ts +61 -0
- package/dist/types/src/controllers/EnsController.d.ts +26 -0
- package/dist/types/src/controllers/EventsController.d.ts +17 -0
- package/dist/types/src/controllers/ModalController.d.ts +27 -0
- package/dist/types/src/controllers/OnRampController.d.ts +55 -0
- package/dist/types/src/controllers/OptionsController.d.ts +364 -0
- package/dist/types/src/controllers/PublicStateController.d.ts +33 -0
- package/dist/types/src/controllers/RouterController.d.ts +56 -0
- package/dist/types/src/controllers/SendController.d.ts +52 -0
- package/dist/types/src/controllers/SnackController.d.ts +29 -0
- package/dist/types/src/controllers/SwapController.d.ts +127 -0
- package/dist/types/src/controllers/ThemeController.d.ts +30 -0
- package/dist/types/src/controllers/TooltipController.d.ts +25 -0
- package/dist/types/src/controllers/TransactionsController.d.ts +25 -0
- package/dist/types/src/utils/AssetUtil.d.ts +15 -0
- package/dist/types/src/utils/ConstantsUtil.d.ts +86 -0
- package/dist/types/src/utils/CoreHelperUtil.d.ts +56 -0
- package/dist/types/src/utils/ERC7811Util.d.ts +67 -0
- package/dist/types/src/utils/EnsUtil.d.ts +3 -0
- package/dist/types/src/utils/FetchUtil.d.ts +26 -0
- package/dist/types/src/utils/MobileWallet.d.ts +9 -0
- package/dist/types/src/utils/OptionsUtil.d.ts +5 -0
- package/dist/types/src/utils/RouterUtil.d.ts +4 -0
- package/dist/types/src/utils/SIWXUtil.d.ts +183 -0
- package/dist/types/src/utils/SendApiUtil.d.ts +13 -0
- package/dist/types/src/utils/StorageUtil.d.ts +99 -0
- package/dist/types/src/utils/SwapApiUtil.d.ts +27 -0
- package/dist/types/src/utils/SwapCalculationUtil.d.ts +22 -0
- package/dist/types/src/utils/TypeUtil.d.ts +981 -0
- package/dist/types/tests/constants/OnrampTransactions.d.ts +138 -0
- package/dist/types/tests/controllers/AccountController.test.d.ts +1 -0
- package/dist/types/tests/controllers/AlertController.test.d.ts +1 -0
- package/dist/types/tests/controllers/ApiController.test.d.ts +1 -0
- package/dist/types/tests/controllers/AssetController.test.d.ts +1 -0
- package/dist/types/tests/controllers/BlockchainApiController.test.d.ts +1 -0
- package/dist/types/tests/controllers/ChainController.test.d.ts +1 -0
- package/dist/types/tests/controllers/ConnectionController.test.d.ts +1 -0
- package/dist/types/tests/controllers/ConnectorController.test.d.ts +1 -0
- package/dist/types/tests/controllers/EnsController.test.d.ts +1 -0
- package/dist/types/tests/controllers/EventsController.test.d.ts +1 -0
- package/dist/types/tests/controllers/ModalController.test.d.ts +1 -0
- package/dist/types/tests/controllers/OnRampController.test.d.ts +1 -0
- package/dist/types/tests/controllers/OptionsController.test.d.ts +1 -0
- package/dist/types/tests/controllers/PublicStateController.test.d.ts +1 -0
- package/dist/types/tests/controllers/RouterController.test.d.ts +1 -0
- package/dist/types/tests/controllers/SendController.test.d.ts +1 -0
- package/dist/types/tests/controllers/SnackController.test.d.ts +1 -0
- package/dist/types/tests/controllers/SwapController.test.d.ts +1 -0
- package/dist/types/tests/controllers/ThemeController.test.d.ts +1 -0
- package/dist/types/tests/controllers/TooltipController.test.d.ts +1 -0
- package/dist/types/tests/controllers/TransactionsController.test.d.ts +1 -0
- package/dist/types/tests/hooks/react.test.d.ts +1 -0
- package/dist/types/tests/hooks/vue.test.d.ts +2 -0
- package/dist/types/tests/mocks/ChainController.d.ts +2 -0
- package/dist/types/tests/mocks/SwapController.d.ts +75 -0
- package/dist/types/tests/mocks/useAppKitAccount.d.ts +40 -0
- package/dist/types/tests/utils/AssetUtil.test.d.ts +1 -0
- package/dist/types/tests/utils/CoreHelperUtil.test.d.ts +1 -0
- package/dist/types/tests/utils/ERC7811.test.d.ts +1 -0
- package/dist/types/tests/utils/EnsUtil.test.d.ts +1 -0
- package/dist/types/tests/utils/FetchUtil.test.d.ts +1 -0
- package/dist/types/tests/utils/MobileWallet.test.d.ts +1 -0
- package/dist/types/tests/utils/OptionsUtil.test.d.ts +1 -0
- package/dist/types/tests/utils/RouterUtil.test.d.ts +1 -0
- package/dist/types/tests/utils/SendApiUtil.test.d.ts +1 -0
- package/dist/types/tests/utils/StorageUtil.test.d.ts +1 -0
- package/dist/types/tests/utils/SwapApiUtil.test.d.ts +1 -0
- package/dist/types/tests/utils/SwapCalculationUtil.test.d.ts +1 -0
- package/package.json +81 -0
- package/readme.md +11 -0
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { ConstantsUtil } from '@reown/appkit-common';
|
|
3
|
+
import { AlertController, EventsController, FetchUtil } from '../../exports/index.js';
|
|
4
|
+
// -- Setup --------------------------------------------------------------------
|
|
5
|
+
const event = { type: 'track', event: 'MODAL_CLOSE', properties: { connected: true } };
|
|
6
|
+
// -- Tests --------------------------------------------------------------------
|
|
7
|
+
describe('EventsController', () => {
|
|
8
|
+
it('should have valid default state', () => {
|
|
9
|
+
expect(EventsController.state.data).toEqual({
|
|
10
|
+
type: 'track',
|
|
11
|
+
event: 'MODAL_CREATED'
|
|
12
|
+
});
|
|
13
|
+
});
|
|
14
|
+
it('should update state correctly on sendEvent()', () => {
|
|
15
|
+
EventsController.sendEvent(event);
|
|
16
|
+
expect(EventsController.state.data).toEqual(event);
|
|
17
|
+
});
|
|
18
|
+
it('should trigger an alert error if the analytics event fails with a forbidden status', async () => {
|
|
19
|
+
const error = new Error('forbidden');
|
|
20
|
+
error.cause = new Response(null, {
|
|
21
|
+
status: ConstantsUtil.HTTP_STATUS_CODES.FORBIDDEN
|
|
22
|
+
});
|
|
23
|
+
vi.spyOn(AlertController, 'open');
|
|
24
|
+
vi.spyOn(FetchUtil.prototype, 'post').mockRejectedValue(error);
|
|
25
|
+
await EventsController._sendAnalyticsEvent({
|
|
26
|
+
...EventsController.state,
|
|
27
|
+
data: { type: 'track', event: 'MODAL_CLOSE', properties: { connected: true } }
|
|
28
|
+
});
|
|
29
|
+
expect(AlertController.open).toHaveBeenCalledWith({
|
|
30
|
+
shortMessage: 'Invalid App Configuration',
|
|
31
|
+
longMessage: expect.stringContaining('not found on Allowlist')
|
|
32
|
+
}, 'error');
|
|
33
|
+
expect(EventsController.state.reportedErrors['FORBIDDEN']).toBe(true);
|
|
34
|
+
});
|
|
35
|
+
it('should include sdk properties when sending an analytics event', async () => {
|
|
36
|
+
vi.spyOn(FetchUtil.prototype, 'post').mockResolvedValue({});
|
|
37
|
+
await EventsController._sendAnalyticsEvent({
|
|
38
|
+
...EventsController.state,
|
|
39
|
+
data: { type: 'track', event: 'MODAL_CLOSE', properties: { connected: true } }
|
|
40
|
+
});
|
|
41
|
+
expect(FetchUtil.prototype.post).toHaveBeenCalledWith(expect.objectContaining({
|
|
42
|
+
path: '/e',
|
|
43
|
+
params: EventsController.getSdkProperties()
|
|
44
|
+
}));
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
//# sourceMappingURL=EventsController.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EventsController.test.js","sourceRoot":"","sources":["../../../../tests/controllers/EventsController.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { beforeEach, describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { ApiController, ChainController, ConnectorController, ModalController, RouterController } from '../../exports/index.js';
|
|
3
|
+
// -- Tests --------------------------------------------------------------------
|
|
4
|
+
describe('ModalController', () => {
|
|
5
|
+
beforeEach(() => {
|
|
6
|
+
vi.clearAllMocks();
|
|
7
|
+
});
|
|
8
|
+
it('should have valid default state', () => {
|
|
9
|
+
expect(ModalController.state.open).toEqual(false);
|
|
10
|
+
});
|
|
11
|
+
// Skipping for now, need to figure out a way to test this with new prefetch check
|
|
12
|
+
it.skip('should update state correctly on open()', () => {
|
|
13
|
+
ModalController.open();
|
|
14
|
+
expect(ModalController.state.open).toEqual(true);
|
|
15
|
+
});
|
|
16
|
+
it('should update state correctly on close()', () => {
|
|
17
|
+
ModalController.close();
|
|
18
|
+
expect(ModalController.state.open).toEqual(false);
|
|
19
|
+
});
|
|
20
|
+
it('should prefetch when open() is called', async () => {
|
|
21
|
+
vi.spyOn(ApiController, 'fetchFeaturedWallets');
|
|
22
|
+
vi.spyOn(ApiController, 'fetchRecommendedWallets');
|
|
23
|
+
vi.spyOn(ApiController, 'fetchConnectorImages');
|
|
24
|
+
vi.spyOn(ApiController, 'fetchNetworkImages');
|
|
25
|
+
await ModalController.open();
|
|
26
|
+
expect(ApiController.fetchFeaturedWallets).toHaveBeenCalledOnce();
|
|
27
|
+
expect(ApiController.fetchRecommendedWallets).toHaveBeenCalledOnce();
|
|
28
|
+
expect(ApiController.fetchConnectorImages).toHaveBeenCalledOnce();
|
|
29
|
+
expect(ApiController.fetchNetworkImages).toHaveBeenCalledOnce();
|
|
30
|
+
});
|
|
31
|
+
it('should handle namespace parameter correctly in open()', async () => {
|
|
32
|
+
const namespace = 'bip122';
|
|
33
|
+
vi.spyOn(ConnectorController, 'setFilterByNamespace');
|
|
34
|
+
vi.spyOn(ChainController, 'switchActiveNamespace');
|
|
35
|
+
vi.spyOn(ModalController, 'setLoading');
|
|
36
|
+
await ModalController.open({ namespace });
|
|
37
|
+
expect(ConnectorController.setFilterByNamespace).toHaveBeenCalledWith(namespace);
|
|
38
|
+
expect(ChainController.switchActiveNamespace).toHaveBeenCalledWith(namespace);
|
|
39
|
+
expect(ModalController.setLoading).toHaveBeenCalledWith(true, namespace);
|
|
40
|
+
});
|
|
41
|
+
it('should not call switchActiveNamespace if namespace parameter is the same', async () => {
|
|
42
|
+
const namespace = 'bip122';
|
|
43
|
+
ChainController.switchActiveNamespace(namespace);
|
|
44
|
+
vi.spyOn(ChainController, 'switchActiveNetwork');
|
|
45
|
+
await ModalController.open({ namespace });
|
|
46
|
+
expect(ChainController.switchActiveNetwork).not.toHaveBeenCalled();
|
|
47
|
+
});
|
|
48
|
+
it('should check account depending on namespace when calling open()', async () => {
|
|
49
|
+
ChainController.state.noAdapters = false;
|
|
50
|
+
vi.spyOn(ChainController, 'getAccountData').mockReturnValueOnce({
|
|
51
|
+
currentTab: 0,
|
|
52
|
+
tokenBalance: [],
|
|
53
|
+
smartAccountDeployed: false,
|
|
54
|
+
addressLabels: new Map(),
|
|
55
|
+
allAccounts: [],
|
|
56
|
+
user: undefined,
|
|
57
|
+
caipAddress: 'eip155:1:0x123'
|
|
58
|
+
});
|
|
59
|
+
const resetSpy = vi.spyOn(RouterController, 'reset');
|
|
60
|
+
await ModalController.open({ namespace: 'eip155' });
|
|
61
|
+
expect(resetSpy).toHaveBeenCalledWith('Account');
|
|
62
|
+
await ModalController.open({ namespace: 'bip122' });
|
|
63
|
+
expect(resetSpy).toHaveBeenCalledWith('Connect');
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
//# sourceMappingURL=ModalController.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModalController.test.js","sourceRoot":"","sources":["../../../../tests/controllers/ModalController.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { ApiController, BlockchainApiController, OnRampController } from '../../exports/index.js';
|
|
3
|
+
import { USDC_CURRENCY_DEFAULT, USD_CURRENCY_DEFAULT } from '../../src/controllers/OnRampController.js';
|
|
4
|
+
import { ONRAMP_PROVIDERS } from '../../src/utils/ConstantsUtil.js';
|
|
5
|
+
const purchaseCurrencies = [
|
|
6
|
+
{ id: 'test-coin', symbol: 'TEST', name: 'Test Coin', networks: [] },
|
|
7
|
+
{ id: 'test-coin-2', symbol: 'TES2', name: 'Test Coin 2', networks: [] }
|
|
8
|
+
];
|
|
9
|
+
const paymentCurrencies = [
|
|
10
|
+
{ id: 'test-currency', payment_method_limits: [] },
|
|
11
|
+
{ id: 'test-currency-2', payment_method_limits: [] }
|
|
12
|
+
];
|
|
13
|
+
const mockQuote = {
|
|
14
|
+
paymentTotal: {
|
|
15
|
+
amount: '100',
|
|
16
|
+
currency: 'USD'
|
|
17
|
+
},
|
|
18
|
+
paymentSubtotal: {
|
|
19
|
+
amount: '200',
|
|
20
|
+
currency: 'USD'
|
|
21
|
+
},
|
|
22
|
+
purchaseAmount: {
|
|
23
|
+
amount: '100',
|
|
24
|
+
currency: 'USDC'
|
|
25
|
+
},
|
|
26
|
+
coinbaseFee: {
|
|
27
|
+
amount: '50',
|
|
28
|
+
currency: 'USD'
|
|
29
|
+
},
|
|
30
|
+
networkFee: {
|
|
31
|
+
amount: '50',
|
|
32
|
+
currency: 'USD'
|
|
33
|
+
},
|
|
34
|
+
quoteId: 'test'
|
|
35
|
+
};
|
|
36
|
+
const defaultState = {
|
|
37
|
+
providers: ONRAMP_PROVIDERS,
|
|
38
|
+
selectedProvider: null,
|
|
39
|
+
error: null,
|
|
40
|
+
purchaseCurrency: USDC_CURRENCY_DEFAULT,
|
|
41
|
+
paymentCurrency: USD_CURRENCY_DEFAULT,
|
|
42
|
+
purchaseCurrencies: [USDC_CURRENCY_DEFAULT],
|
|
43
|
+
paymentCurrencies: [],
|
|
44
|
+
quotesLoading: false
|
|
45
|
+
};
|
|
46
|
+
// -- Tests --------------------------------------------------------------------
|
|
47
|
+
describe('OnRampController', () => {
|
|
48
|
+
it('should have valid default state', () => {
|
|
49
|
+
expect(OnRampController.state).toEqual(defaultState);
|
|
50
|
+
});
|
|
51
|
+
it('should get available currencies and properly update state', async () => {
|
|
52
|
+
OnRampController.resetState();
|
|
53
|
+
const getOnrampOptions = vi
|
|
54
|
+
.spyOn(BlockchainApiController, 'getOnrampOptions')
|
|
55
|
+
.mockResolvedValueOnce({
|
|
56
|
+
purchaseCurrencies,
|
|
57
|
+
paymentCurrencies
|
|
58
|
+
});
|
|
59
|
+
const fetchCurrencyImages = vi
|
|
60
|
+
.spyOn(ApiController, 'fetchCurrencyImages')
|
|
61
|
+
.mockResolvedValueOnce(undefined);
|
|
62
|
+
const fetchTokenImages = vi
|
|
63
|
+
.spyOn(ApiController, 'fetchTokenImages')
|
|
64
|
+
.mockResolvedValueOnce(undefined);
|
|
65
|
+
await OnRampController.getAvailableCurrencies();
|
|
66
|
+
expect(getOnrampOptions).toHaveBeenCalled();
|
|
67
|
+
expect(fetchCurrencyImages).toHaveBeenCalledWith(paymentCurrencies?.map(currency => currency.id));
|
|
68
|
+
expect(fetchTokenImages).toHaveBeenCalledWith(purchaseCurrencies?.map(token => token.symbol));
|
|
69
|
+
expect(OnRampController.state.purchaseCurrencies).toEqual(purchaseCurrencies);
|
|
70
|
+
expect(OnRampController.state.paymentCurrencies).toEqual(paymentCurrencies);
|
|
71
|
+
});
|
|
72
|
+
it('should get quotes and properly update state with default params', async () => {
|
|
73
|
+
OnRampController.resetState();
|
|
74
|
+
const getOnrampQuote = vi
|
|
75
|
+
.spyOn(BlockchainApiController, 'getOnrampQuote')
|
|
76
|
+
.mockResolvedValue(mockQuote);
|
|
77
|
+
const quote = await OnRampController.getQuote();
|
|
78
|
+
expect(quote).toEqual(mockQuote);
|
|
79
|
+
expect(getOnrampQuote).toHaveBeenCalledWith({
|
|
80
|
+
purchaseCurrency: USDC_CURRENCY_DEFAULT,
|
|
81
|
+
paymentCurrency: USD_CURRENCY_DEFAULT,
|
|
82
|
+
amount: '0',
|
|
83
|
+
network: 'USDC'
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
it('should get quotes and properly update state with set state', async () => {
|
|
87
|
+
OnRampController.resetState();
|
|
88
|
+
const getOnrampQuote = vi
|
|
89
|
+
.spyOn(BlockchainApiController, 'getOnrampQuote')
|
|
90
|
+
.mockResolvedValue(mockQuote);
|
|
91
|
+
OnRampController.setPaymentAmount(100);
|
|
92
|
+
OnRampController.setPurchaseCurrency(purchaseCurrencies[0]);
|
|
93
|
+
OnRampController.setPaymentCurrency(paymentCurrencies[0]);
|
|
94
|
+
const quote = await OnRampController.getQuote();
|
|
95
|
+
expect(quote).toEqual(mockQuote);
|
|
96
|
+
expect(getOnrampQuote).toHaveBeenCalledWith({
|
|
97
|
+
purchaseCurrency: purchaseCurrencies[0],
|
|
98
|
+
paymentCurrency: paymentCurrencies[0],
|
|
99
|
+
amount: '100',
|
|
100
|
+
network: 'TEST'
|
|
101
|
+
});
|
|
102
|
+
expect(OnRampController.state.purchaseAmount).toEqual(100);
|
|
103
|
+
expect(OnRampController.state.quotesLoading).toEqual(false);
|
|
104
|
+
});
|
|
105
|
+
it('should set error when failing to get quotes', async () => {
|
|
106
|
+
OnRampController.resetState();
|
|
107
|
+
const error = new Error('Test error');
|
|
108
|
+
const getOnrampQuote = vi
|
|
109
|
+
.spyOn(BlockchainApiController, 'getOnrampQuote')
|
|
110
|
+
.mockRejectedValue(error);
|
|
111
|
+
const quote = await OnRampController.getQuote();
|
|
112
|
+
expect(quote).toEqual(null);
|
|
113
|
+
expect(getOnrampQuote).toHaveBeenCalled();
|
|
114
|
+
expect(OnRampController.state.error).toEqual(error.message);
|
|
115
|
+
expect(OnRampController.state.quotesLoading).toEqual(false);
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
//# sourceMappingURL=OnRampController.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OnRampController.test.js","sourceRoot":"","sources":["../../../../tests/controllers/OnRampController.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { OptionsController } from '../../exports/index.js';
|
|
3
|
+
import { ConstantsUtil } from '../../src/utils/ConstantsUtil.js';
|
|
4
|
+
// -- Tests --------------------------------------------------------------------
|
|
5
|
+
describe('OptionsController', () => {
|
|
6
|
+
it('should have valid default state', () => {
|
|
7
|
+
expect(OptionsController.state).toEqual({
|
|
8
|
+
features: ConstantsUtil.DEFAULT_FEATURES,
|
|
9
|
+
projectId: '',
|
|
10
|
+
sdkType: 'appkit',
|
|
11
|
+
sdkVersion: 'html-wagmi-undefined',
|
|
12
|
+
defaultAccountTypes: {
|
|
13
|
+
bip122: 'payment',
|
|
14
|
+
eip155: 'smartAccount',
|
|
15
|
+
polkadot: 'eoa',
|
|
16
|
+
solana: 'eoa'
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
it('should update state correctly on setProjectId()', () => {
|
|
21
|
+
OptionsController.setProjectId('123');
|
|
22
|
+
expect(OptionsController.state.projectId).toEqual('123');
|
|
23
|
+
});
|
|
24
|
+
it('should update state correctly on setSdkVersion()', () => {
|
|
25
|
+
OptionsController.setSdkVersion('react-wagmi-3.0.0');
|
|
26
|
+
expect(OptionsController.state.sdkVersion).toEqual('react-wagmi-3.0.0');
|
|
27
|
+
});
|
|
28
|
+
it('should update state correctly on setAllowUnsupportedChain()', () => {
|
|
29
|
+
OptionsController.setAllowUnsupportedChain(true);
|
|
30
|
+
expect(OptionsController.state.allowUnsupportedChain).toEqual(true);
|
|
31
|
+
});
|
|
32
|
+
it('should set defaultAccountType partially and not change if undefined is provided', () => {
|
|
33
|
+
OptionsController.setDefaultAccountTypes({ eip155: 'eoa', bip122: undefined });
|
|
34
|
+
expect(OptionsController.state.defaultAccountTypes).toEqual({
|
|
35
|
+
bip122: 'payment',
|
|
36
|
+
eip155: 'eoa',
|
|
37
|
+
polkadot: 'eoa',
|
|
38
|
+
solana: 'eoa'
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=OptionsController.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OptionsController.test.js","sourceRoot":"","sources":["../../../../tests/controllers/OptionsController.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAE7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAA;AAEhE,gFAAgF;AAChF,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;YACtC,QAAQ,EAAE,aAAa,CAAC,gBAAgB;YACxC,SAAS,EAAE,EAAE;YACb,OAAO,EAAE,QAAQ;YACjB,UAAU,EAAE,sBAAsB;YAClC,mBAAmB,EAAE;gBACnB,MAAM,EAAE,SAAS;gBACjB,MAAM,EAAE,cAAc;gBACtB,QAAQ,EAAE,KAAK;gBACf,MAAM,EAAE,KAAK;aACd;SACF,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,iBAAiB,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;QACrC,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAC1D,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,iBAAiB,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAA;QACpD,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAA;IACzE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACrE,iBAAiB,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAA;QAChD,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IACrE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,iFAAiF,EAAE,GAAG,EAAE;QACzF,iBAAiB,CAAC,sBAAsB,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAA;QAC9E,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC;YAC1D,MAAM,EAAE,SAAS;YACjB,MAAM,EAAE,KAAK;YACb,QAAQ,EAAE,KAAK;YACf,MAAM,EAAE,KAAK;SACd,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { PublicStateController } from '../../exports/index.js';
|
|
3
|
+
// -- Tests --------------------------------------------------------------------
|
|
4
|
+
describe('PublicStateController', () => {
|
|
5
|
+
it('should have valid default state', () => {
|
|
6
|
+
expect(PublicStateController.state).toEqual({
|
|
7
|
+
loading: false,
|
|
8
|
+
open: false,
|
|
9
|
+
selectedNetworkId: undefined,
|
|
10
|
+
activeChain: undefined,
|
|
11
|
+
initialized: false
|
|
12
|
+
});
|
|
13
|
+
});
|
|
14
|
+
it('should update state correctly on set()', () => {
|
|
15
|
+
PublicStateController.set({ open: true });
|
|
16
|
+
expect(PublicStateController.state).toEqual({
|
|
17
|
+
loading: false,
|
|
18
|
+
selectedNetworkId: undefined,
|
|
19
|
+
activeChain: undefined,
|
|
20
|
+
initialized: false,
|
|
21
|
+
open: true
|
|
22
|
+
});
|
|
23
|
+
PublicStateController.set({ selectedNetworkId: 'eip155:1' });
|
|
24
|
+
expect(PublicStateController.state).toEqual({
|
|
25
|
+
loading: false,
|
|
26
|
+
open: true,
|
|
27
|
+
selectedNetworkId: 'eip155:1',
|
|
28
|
+
activeChain: undefined,
|
|
29
|
+
initialized: false
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
//# sourceMappingURL=PublicStateController.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PublicStateController.test.js","sourceRoot":"","sources":["../../../../tests/controllers/PublicStateController.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAE7C,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAA;AAE9D,gFAAgF;AAChF,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;YAC1C,OAAO,EAAE,KAAK;YACd,IAAI,EAAE,KAAK;YACX,iBAAiB,EAAE,SAAS;YAC5B,WAAW,EAAE,SAAS;YACtB,WAAW,EAAE,KAAK;SACnB,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wCAAwC,EAAE,GAAG,EAAE;QAChD,qBAAqB,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAA;QACzC,MAAM,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;YAC1C,OAAO,EAAE,KAAK;YACd,iBAAiB,EAAE,SAAS;YAC5B,WAAW,EAAE,SAAS;YACtB,WAAW,EAAE,KAAK;YAClB,IAAI,EAAE,IAAI;SACX,CAAC,CAAA;QACF,qBAAqB,CAAC,GAAG,CAAC,EAAE,iBAAiB,EAAE,UAAU,EAAE,CAAC,CAAA;QAC5D,MAAM,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;YAC1C,OAAO,EAAE,KAAK;YACd,IAAI,EAAE,IAAI;YACV,iBAAiB,EAAE,UAAU;YAC7B,WAAW,EAAE,SAAS;YACtB,WAAW,EAAE,KAAK;SACnB,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { ConstantsUtil } from '@reown/appkit-common';
|
|
3
|
+
import { RouterController } from '../../exports/index.js';
|
|
4
|
+
// -- Tests --------------------------------------------------------------------
|
|
5
|
+
describe('RouterController', () => {
|
|
6
|
+
it('should have valid default state', () => {
|
|
7
|
+
expect(RouterController.state).toEqual({
|
|
8
|
+
view: 'Connect',
|
|
9
|
+
history: ['Connect'],
|
|
10
|
+
transactionStack: []
|
|
11
|
+
});
|
|
12
|
+
});
|
|
13
|
+
it('should update state correctly on push()', () => {
|
|
14
|
+
RouterController.push('Account');
|
|
15
|
+
expect(RouterController.state).toEqual({
|
|
16
|
+
view: 'Account',
|
|
17
|
+
history: ['Connect', 'Account'],
|
|
18
|
+
transactionStack: []
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
it('should not update state when push() is called with the same view', () => {
|
|
22
|
+
RouterController.push('Account');
|
|
23
|
+
expect(RouterController.state).toEqual({
|
|
24
|
+
view: 'Account',
|
|
25
|
+
history: ['Connect', 'Account'],
|
|
26
|
+
transactionStack: []
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
it('should update state correctly on goBack()', () => {
|
|
30
|
+
RouterController.goBack();
|
|
31
|
+
expect(RouterController.state).toEqual({
|
|
32
|
+
view: 'Connect',
|
|
33
|
+
history: ['Connect'],
|
|
34
|
+
transactionStack: []
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
it('should not update state when goBack() is called with only one view in history', () => {
|
|
38
|
+
RouterController.goBack();
|
|
39
|
+
expect(RouterController.state).toEqual({
|
|
40
|
+
view: 'Connect',
|
|
41
|
+
history: ['Connect'],
|
|
42
|
+
transactionStack: []
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
it('should update state correctly on reset()', () => {
|
|
46
|
+
RouterController.reset('Account');
|
|
47
|
+
expect(RouterController.state).toEqual({
|
|
48
|
+
view: 'Account',
|
|
49
|
+
history: ['Account'],
|
|
50
|
+
transactionStack: []
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
it('should update state correctly on replace()', () => {
|
|
54
|
+
RouterController.push('Connect');
|
|
55
|
+
RouterController.replace('Networks');
|
|
56
|
+
expect(RouterController.state).toEqual({
|
|
57
|
+
view: 'Networks',
|
|
58
|
+
history: ['Account', 'Networks'],
|
|
59
|
+
transactionStack: []
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
it('should update state correctly on push() with data', () => {
|
|
63
|
+
RouterController.push('ConnectingExternal', {
|
|
64
|
+
connector: {
|
|
65
|
+
id: 'test',
|
|
66
|
+
name: 'wcConnector',
|
|
67
|
+
type: 'WALLET_CONNECT',
|
|
68
|
+
chain: ConstantsUtil.CHAIN.EVM
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
expect(RouterController.state).toEqual({
|
|
72
|
+
view: 'ConnectingExternal',
|
|
73
|
+
history: ['Account', 'Networks', 'ConnectingExternal'],
|
|
74
|
+
data: {
|
|
75
|
+
connector: {
|
|
76
|
+
id: 'test',
|
|
77
|
+
type: 'WALLET_CONNECT',
|
|
78
|
+
chain: ConstantsUtil.CHAIN.EVM,
|
|
79
|
+
name: 'wcConnector'
|
|
80
|
+
}
|
|
81
|
+
},
|
|
82
|
+
transactionStack: []
|
|
83
|
+
});
|
|
84
|
+
});
|
|
85
|
+
it('should clear data wallet state when goBack() is called', () => {
|
|
86
|
+
RouterController.push('Connect', {
|
|
87
|
+
wallet: {
|
|
88
|
+
id: 'test',
|
|
89
|
+
name: 'test_wallet'
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
RouterController.goBack();
|
|
93
|
+
expect(RouterController.state).toEqual({
|
|
94
|
+
view: 'ConnectingExternal',
|
|
95
|
+
history: ['Account', 'Networks', 'ConnectingExternal'],
|
|
96
|
+
transactionStack: [],
|
|
97
|
+
data: {
|
|
98
|
+
wallet: undefined
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
//# sourceMappingURL=RouterController.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RouterController.test.js","sourceRoot":"","sources":["../../../../tests/controllers/RouterController.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import { mainnet } from 'viem/chains';
|
|
2
|
+
import { beforeEach, describe, expect, it, vi } from 'vitest';
|
|
3
|
+
import { ConstantsUtil } from '@reown/appkit-common';
|
|
4
|
+
import { ChainController, CoreHelperUtil, SendController, SnackController } from '../../exports/index.js';
|
|
5
|
+
import { SendApiUtil } from '../../src/utils/SendApiUtil.js';
|
|
6
|
+
// -- Setup --------------------------------------------------------------------
|
|
7
|
+
const token = {
|
|
8
|
+
name: 'Optimism',
|
|
9
|
+
address: 'eip155:10:0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee',
|
|
10
|
+
symbol: 'OP',
|
|
11
|
+
chainId: 'eip155:10',
|
|
12
|
+
value: 6.05441523113072,
|
|
13
|
+
price: 4.5340112,
|
|
14
|
+
quantity: {
|
|
15
|
+
decimals: '18',
|
|
16
|
+
numeric: '1.335333100000000000'
|
|
17
|
+
},
|
|
18
|
+
iconUrl: 'https://token-icons.s3.amazonaws.com/0x4200000000000000000000000000000000000042.png'
|
|
19
|
+
};
|
|
20
|
+
const sendTokenAmount = 0.1;
|
|
21
|
+
const receiverAddress = '0xd8da6bf26964af9d7eed9e03e53415d37aa96045';
|
|
22
|
+
const receiverProfileName = 'john.eth';
|
|
23
|
+
const receiverProfileImageUrl = 'https://ipfs.com/0x123.png';
|
|
24
|
+
const extendedMainnet = {
|
|
25
|
+
...mainnet,
|
|
26
|
+
chainNamespace: ConstantsUtil.CHAIN.EVM,
|
|
27
|
+
caipNetworkId: 'eip155:1'
|
|
28
|
+
};
|
|
29
|
+
// -- Tests --------------------------------------------------------------------
|
|
30
|
+
describe('SendController', () => {
|
|
31
|
+
it('should have valid default state', () => {
|
|
32
|
+
expect(SendController.state).toEqual({ tokenBalances: [], loading: false });
|
|
33
|
+
});
|
|
34
|
+
it('should update state correctly on setToken()', () => {
|
|
35
|
+
SendController.setToken(token);
|
|
36
|
+
expect(SendController.state.token).toEqual(token);
|
|
37
|
+
});
|
|
38
|
+
it('should update state correctly on setTokenAmount()', () => {
|
|
39
|
+
SendController.setTokenAmount(sendTokenAmount);
|
|
40
|
+
expect(SendController.state.sendTokenAmount).toEqual(sendTokenAmount);
|
|
41
|
+
});
|
|
42
|
+
it('should update state correctly on receiverAddress()', () => {
|
|
43
|
+
SendController.setReceiverAddress(receiverAddress);
|
|
44
|
+
expect(SendController.state.receiverAddress).toEqual(receiverAddress);
|
|
45
|
+
});
|
|
46
|
+
it('should update state correctly on receiverProfileName()', () => {
|
|
47
|
+
SendController.setReceiverProfileName(receiverProfileName);
|
|
48
|
+
expect(SendController.state.receiverProfileName).toEqual(receiverProfileName);
|
|
49
|
+
});
|
|
50
|
+
it('should update state correctly on receiverProfileName()', () => {
|
|
51
|
+
SendController.setReceiverProfileImageUrl(receiverProfileImageUrl);
|
|
52
|
+
expect(SendController.state.receiverProfileImageUrl).toEqual(receiverProfileImageUrl);
|
|
53
|
+
});
|
|
54
|
+
it('should update state correctly on resetSend()', () => {
|
|
55
|
+
SendController.resetSend();
|
|
56
|
+
expect(SendController.state).toEqual({ tokenBalances: [], loading: false });
|
|
57
|
+
});
|
|
58
|
+
describe('fetchTokenBalance()', () => {
|
|
59
|
+
beforeEach(() => {
|
|
60
|
+
vi.spyOn(ChainController, 'state', 'get').mockReturnValue({
|
|
61
|
+
activeCaipNetwork: extendedMainnet,
|
|
62
|
+
activeCaipAddress: 'eip155:1:0x123'
|
|
63
|
+
});
|
|
64
|
+
vi.spyOn(SendApiUtil, 'getMyTokensWithBalance').mockResolvedValue([]);
|
|
65
|
+
vi.spyOn(CoreHelperUtil, 'isAllowedRetry').mockReturnValue(true);
|
|
66
|
+
vi.spyOn(SnackController, 'showError').mockImplementation(() => { });
|
|
67
|
+
});
|
|
68
|
+
it('should not fetch balance if its not allowed to retry', async () => {
|
|
69
|
+
vi.spyOn(CoreHelperUtil, 'isAllowedRetry').mockReturnValue(false);
|
|
70
|
+
SendController.state.lastRetry = Date.now();
|
|
71
|
+
const result = await SendController.fetchTokenBalance();
|
|
72
|
+
expect(result).toEqual([]);
|
|
73
|
+
expect(SendApiUtil.getMyTokensWithBalance).not.toHaveBeenCalled();
|
|
74
|
+
expect(SendController.state.loading).toBe(false);
|
|
75
|
+
});
|
|
76
|
+
it('should not fetch balance if chainId is not defined', async () => {
|
|
77
|
+
vi.spyOn(ChainController, 'state', 'get').mockReturnValue({
|
|
78
|
+
activeCaipNetwork: {
|
|
79
|
+
chainNamespace: 'eip155'
|
|
80
|
+
},
|
|
81
|
+
activeCaipAddress: 'eip155:1:0x123'
|
|
82
|
+
});
|
|
83
|
+
const result = await SendController.fetchTokenBalance();
|
|
84
|
+
expect(result).toEqual([]);
|
|
85
|
+
expect(SendApiUtil.getMyTokensWithBalance).not.toHaveBeenCalled();
|
|
86
|
+
});
|
|
87
|
+
it('should not fetch balance if namespace is not defined', async () => {
|
|
88
|
+
vi.spyOn(ChainController, 'state', 'get').mockReturnValue({
|
|
89
|
+
activeCaipNetwork: { ...extendedMainnet, chainNamespace: undefined },
|
|
90
|
+
activeCaipAddress: 'eip155:1:0x123'
|
|
91
|
+
});
|
|
92
|
+
const result = await SendController.fetchTokenBalance();
|
|
93
|
+
expect(result).toEqual([]);
|
|
94
|
+
expect(SendApiUtil.getMyTokensWithBalance).not.toHaveBeenCalled();
|
|
95
|
+
});
|
|
96
|
+
it('should not fetch balance if address is not defined', async () => {
|
|
97
|
+
vi.spyOn(ChainController, 'state', 'get').mockReturnValue({
|
|
98
|
+
activeCaipNetwork: extendedMainnet,
|
|
99
|
+
activeCaipAddress: undefined
|
|
100
|
+
});
|
|
101
|
+
const result = await SendController.fetchTokenBalance();
|
|
102
|
+
expect(result).toEqual([]);
|
|
103
|
+
expect(SendApiUtil.getMyTokensWithBalance).not.toHaveBeenCalled();
|
|
104
|
+
});
|
|
105
|
+
it('should set the retry if something fails', async () => {
|
|
106
|
+
const mockError = new Error('API Error');
|
|
107
|
+
vi.spyOn(SendApiUtil, 'getMyTokensWithBalance').mockRejectedValue(mockError);
|
|
108
|
+
const onError = vi.fn();
|
|
109
|
+
const now = Date.now();
|
|
110
|
+
vi.setSystemTime(now);
|
|
111
|
+
const result = await SendController.fetchTokenBalance(onError);
|
|
112
|
+
expect(result).toEqual([]);
|
|
113
|
+
expect(SendController.state.lastRetry).toBe(now);
|
|
114
|
+
expect(onError).toHaveBeenCalledWith(mockError);
|
|
115
|
+
expect(SnackController.showError).toHaveBeenCalledWith('Token Balance Unavailable');
|
|
116
|
+
});
|
|
117
|
+
it('should fetch balance if everything is correct', async () => {
|
|
118
|
+
const mockBalances = [
|
|
119
|
+
{
|
|
120
|
+
quantity: { decimals: '18' },
|
|
121
|
+
symbol: 'ETH',
|
|
122
|
+
address: '0x123'
|
|
123
|
+
},
|
|
124
|
+
{ quantity: { decimals: '0' }, symbol: 'ZERO', address: '0x456' },
|
|
125
|
+
{ quantity: { decimals: '6' }, symbol: 'USDC', address: '0x789' }
|
|
126
|
+
];
|
|
127
|
+
vi.spyOn(SendApiUtil, 'getMyTokensWithBalance').mockResolvedValue(mockBalances);
|
|
128
|
+
const result = await SendController.fetchTokenBalance();
|
|
129
|
+
expect(result).toEqual(mockBalances);
|
|
130
|
+
expect(SendController.state.tokenBalances).toEqual(mockBalances);
|
|
131
|
+
expect(SendController.state.lastRetry).toBeUndefined();
|
|
132
|
+
expect(SendController.state.loading).toBe(false);
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
//# sourceMappingURL=SendController.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SendController.test.js","sourceRoot":"","sources":["../../../../tests/controllers/SendController.test.ts"],"names":[],"mappings":"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"}
|