status-desktop/storybook/qmlTests/tests/tst_TokenSelectorViewAdaptor.qml
Lukáš Tinkl a12a6a4894 feat[UI - Wallet Stability] Create generic/reusable assets listview component
TLDR: later this should form a basic building block for a new
TokenSelector picker component, potentially replacing the current
HoldingSelector* and TokenListView components (support for collectibles
TBD as part of https://github.com/status-im/status-desktop/issues/15121)

- create reusable `TokenSelectorAssetDelegate` and `TokenSelectorView`
- add corresponding SB page, showcasing the flow/integration and the
separation of concerns between the view, adaptor and delegate layers
- add QML testcase for TokenSelectorView
- don't display crypto symbol for token balances per chain tags
- update the stores and SB pages
- add some missing formatter functions to LocaleUtils and CurrenciesStore

Fixes #14716
2024-06-18 23:09:20 +02:00

112 lines
3.6 KiB
QML

import QtQuick 2.15
import QtTest 1.15
import Models 1.0
import StatusQ.Core.Utils 0.1
import AppLayouts.Wallet.stores 1.0
import AppLayouts.Wallet.adaptors 1.0
Item {
id: root
width: 600
height: 400
QtObject {
id: d
readonly property var flatNetworks: NetworksModel.flatNetworks
readonly property var assetsStore: WalletAssetsStore {
id: thisWalletAssetStore
walletTokensStore: TokensStore {
plainTokensBySymbolModel: TokensBySymbolModel {}
}
readonly property var baseGroupedAccountAssetModel: GroupedAccountsAssetsModel {}
assetsWithFilteredBalances: thisWalletAssetStore.groupedAccountsAssetsModel
}
}
Component {
id: componentUnderTest
TokenSelectorViewAdaptor {
assetsModel: d.assetsStore.groupedAccountAssetsModel
flatNetworksModel: d.flatNetworks
currentCurrency: "USD"
}
}
property TokenSelectorViewAdaptor controlUnderTest: null
TestCase {
name: "TokenSelectorViewAdaptor"
when: windowShown
function init() {
controlUnderTest = createTemporaryObject(componentUnderTest, root)
}
function test_search() {
verify(!!controlUnderTest)
const searchText = "dAi"
const originalCount = controlUnderTest.outputAssetsModel.count
controlUnderTest.searchString = searchText
// search yields 1 result
tryCompare(controlUnderTest.outputAssetsModel, "count", 1)
// resetting search string resets the view back to original count
controlUnderTest.searchString = ""
tryCompare(controlUnderTest.outputAssetsModel, "count", originalCount)
}
function test_showCommunityAssets() {
verify(!!controlUnderTest)
const originalCount = controlUnderTest.outputAssetsModel.count
// turn on showing the community assets, verify we now have more items
controlUnderTest.showCommunityAssets = true
tryVerify(() => controlUnderTest.outputAssetsModel.count > originalCount)
// turning them back off, verify we are back to the original number of items
controlUnderTest.showCommunityAssets = false
tryCompare(controlUnderTest.outputAssetsModel, "count", originalCount)
}
function test_enabledChainIds() {
verify(!!controlUnderTest)
// enable just "1" (Eth Mainnet) chain
controlUnderTest.enabledChainIds = [1]
// grab the "DAI" entry
const delegate = ModelUtils.getByKey(controlUnderTest.outputAssetsModel, "tokensKey", "DAI")
verify(!!delegate)
const origBalance = delegate.currencyBalance
// should have 0 balance
tryCompare(delegate, "currencyBalance", 0)
// re-enable all chains, DAI should again have the original balance
controlUnderTest.enabledChainIds = []
tryCompare(delegate, "currencyBalance", origBalance)
}
function test_accountAddress() {
verify(!!controlUnderTest)
// enable the "Hot wallet" account address filter (0x7F47C2e98a4BBf5487E6fb082eC2D9Ab0E6d8881)
controlUnderTest.accountAddress = "0x7F47C2e98a4BBf5487E6fb082eC2D9Ab0E6d8881"
// grab the "STT" entry
const delegate = ModelUtils.getByKey(controlUnderTest.outputAssetsModel, "tokensKey", "STT")
verify(!!delegate)
// should have ~45.90 balance
fuzzyCompare(delegate.currencyBalance, 45.90, 0.01)
}
}
}