From c8e3065992a5087c3eb9aabdbbe41062f59350ea Mon Sep 17 00:00:00 2001 From: gantunesr <17601467+gantunesr@users.noreply.github.com> Date: Mon, 2 Dec 2024 00:01:06 -0300 Subject: [PATCH] test: improve MultichainBalancesController unit test --- .../MultichainBalancesController.test.ts | 43 ++++++++++++++++++- 1 file changed, 41 insertions(+), 2 deletions(-) diff --git a/packages/assets-controllers/src/MultichainBalancesController/MultichainBalancesController.test.ts b/packages/assets-controllers/src/MultichainBalancesController/MultichainBalancesController.test.ts index 67bf150ba7..bfa032dc79 100644 --- a/packages/assets-controllers/src/MultichainBalancesController/MultichainBalancesController.test.ts +++ b/packages/assets-controllers/src/MultichainBalancesController/MultichainBalancesController.test.ts @@ -4,7 +4,7 @@ import type { CaipAssetType, InternalAccount, } from '@metamask/keyring-api'; -import { BtcAccountType, BtcMethod } from '@metamask/keyring-api'; +import { BtcAccountType, BtcMethod, EthAccountType, EthMethod } from '@metamask/keyring-api'; import { KeyringTypes } from '@metamask/keyring-controller'; import { v4 as uuidv4 } from 'uuid'; @@ -41,6 +41,27 @@ const mockBtcAccount = { type: BtcAccountType.P2wpkh, }; +const mockEthAccount = { + address: '0x807dE1cf8f39E83258904b2f7b473E5C506E4aC1', + id: uuidv4(), + metadata: { + name: 'Ethereum Account 1', + importTime: Date.now(), + keyring: { + type: KeyringTypes.snap, + }, + snap: { + id: 'mock-eth-snap', + name: 'mock-eth-snap', + enabled: true, + }, + lastSelected: 0, + }, + options: {}, + methods: [EthMethod.SignTypedDataV4, EthMethod.SignTransaction], + type: EthAccountType.Eoa, +}; + const mockBalanceResult = { 'bip122:000000000933ea01ad0ee984209779ba/slip44:0': { amount: '0.00000000', @@ -88,7 +109,7 @@ const setupController = ({ controllerMessenger.registerActionHandler( 'AccountsController:listMultichainAccounts', mockListMultichainAccounts.mockReturnValue( - mocks?.listMultichainAccounts ?? [mockBtcAccount], + mocks?.listMultichainAccounts ?? [mockBtcAccount, mockEthAccount], ), ); @@ -178,4 +199,22 @@ describe('BalancesController', () => { balances: {}, }); }); + + it('does not track balances for EVM accounts', async () => { + const { controller, messenger, mockListMultichainAccounts } = + setupController({ + mocks: { + listMultichainAccounts: [], + }, + }); + + controller.start(); + mockListMultichainAccounts.mockReturnValue([mockEthAccount]); + messenger.publish('AccountsController:accountAdded', mockEthAccount); + await controller.updateBalances(); + + expect(controller.state).toStrictEqual({ + balances: {}, + }); + }); });