mirror of
https://github.com/status-im/status-go.git
synced 2025-01-18 18:55:47 +00:00
7fd9fefdef
This commit adds LoginAccount endpoint. This makes it consistent with CreateAccount and RestoreAccount as they use similar config. The notable difference with the previous endpoint is the API, which is the same as CreateAccount/RestoreAccount, and the fact that it will override your networks configuration. Storing them in the config is now not needed anymore, as that's always driven from the backend, and we won't allow custom networks in the new wallet.
90 lines
2.8 KiB
Go
90 lines
2.8 KiB
Go
package api
|
|
|
|
import (
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/status-im/status-go/protocol/requests"
|
|
)
|
|
|
|
func TestBuildDefaultNetworks(t *testing.T) {
|
|
poktToken := "poket-token"
|
|
infuraToken := "infura-token"
|
|
request := &requests.CreateAccount{
|
|
WalletSecretsConfig: requests.WalletSecretsConfig{
|
|
PoktToken: poktToken,
|
|
InfuraToken: infuraToken,
|
|
},
|
|
}
|
|
|
|
actualNetworks := buildDefaultNetworks(request)
|
|
|
|
require.Len(t, actualNetworks, 6)
|
|
|
|
require.Equal(t, mainnetChainID, actualNetworks[0].ChainID)
|
|
|
|
require.True(t, strings.Contains(actualNetworks[0].RPCURL, poktToken))
|
|
require.True(t, strings.Contains(actualNetworks[0].FallbackURL, infuraToken))
|
|
|
|
require.Equal(t, goerliChainID, actualNetworks[1].ChainID)
|
|
|
|
require.True(t, strings.Contains(actualNetworks[1].RPCURL, poktToken))
|
|
require.True(t, strings.Contains(actualNetworks[1].FallbackURL, infuraToken))
|
|
|
|
require.Equal(t, optimismChainID, actualNetworks[2].ChainID)
|
|
|
|
require.True(t, strings.Contains(actualNetworks[2].RPCURL, poktToken))
|
|
require.True(t, strings.Contains(actualNetworks[2].FallbackURL, infuraToken))
|
|
|
|
require.Equal(t, optimismGoerliChainID, actualNetworks[3].ChainID)
|
|
|
|
require.True(t, strings.Contains(actualNetworks[3].RPCURL, infuraToken))
|
|
require.Equal(t, "", actualNetworks[3].FallbackURL)
|
|
|
|
require.Equal(t, arbitrumChainID, actualNetworks[4].ChainID)
|
|
|
|
require.True(t, strings.Contains(actualNetworks[4].RPCURL, poktToken))
|
|
require.True(t, strings.Contains(actualNetworks[4].FallbackURL, infuraToken))
|
|
|
|
require.Equal(t, arbitrumGoerliChainID, actualNetworks[5].ChainID)
|
|
|
|
require.True(t, strings.Contains(actualNetworks[5].RPCURL, infuraToken))
|
|
require.Equal(t, "", actualNetworks[5].FallbackURL)
|
|
}
|
|
|
|
func TestBuildDefaultNetworksGanache(t *testing.T) {
|
|
ganacheURL := "ganacheurl"
|
|
request := &requests.CreateAccount{
|
|
WalletSecretsConfig: requests.WalletSecretsConfig{
|
|
GanacheURL: ganacheURL,
|
|
},
|
|
}
|
|
|
|
actualNetworks := buildDefaultNetworks(request)
|
|
|
|
require.Len(t, actualNetworks, 6)
|
|
|
|
for _, n := range actualNetworks {
|
|
require.True(t, strings.Contains(n.RPCURL, ganacheURL))
|
|
require.True(t, strings.Contains(n.FallbackURL, ganacheURL))
|
|
|
|
}
|
|
|
|
require.Equal(t, mainnetChainID, actualNetworks[0].ChainID)
|
|
|
|
require.NotNil(t, actualNetworks[0].TokenOverrides)
|
|
require.Len(t, actualNetworks[0].TokenOverrides, 1)
|
|
require.Equal(t, sntSymbol, actualNetworks[0].TokenOverrides[0].Symbol)
|
|
require.Equal(t, ganacheTokenAddress, actualNetworks[0].TokenOverrides[0].Address)
|
|
|
|
require.Equal(t, goerliChainID, actualNetworks[1].ChainID)
|
|
|
|
require.NotNil(t, actualNetworks[1].TokenOverrides)
|
|
require.Len(t, actualNetworks[1].TokenOverrides, 1)
|
|
require.Equal(t, sttSymbol, actualNetworks[1].TokenOverrides[0].Symbol)
|
|
require.Equal(t, ganacheTokenAddress, actualNetworks[1].TokenOverrides[0].Address)
|
|
|
|
}
|