From 6de8c40b002ba3341744f3bff019c60c24ca926f Mon Sep 17 00:00:00 2001 From: BrodyHughes <41711440+BrodyHughes@users.noreply.github.com> Date: Mon, 3 Jun 2024 12:40:26 -0500 Subject: [PATCH] parent 47cbd3c9581d1af09e36128351fe7628add08b1d author BrodyHughes <41711440+BrodyHughes@users.noreply.github.com> 1717436426 -0500 committer BrodyHughes <41711440+BrodyHughes@users.noreply.github.com> 1718422215 -0500 . . . lots of fixes to hardhat assets fix user assets and list out more tests start mocking add quote response mocks and fix testID tap remove global fetch okie remove custom type and consume directly QuoteParams type finish basic flow . . . comments . . clean up oop clean rm unused package bumps prettier -_- . . . :/ . . . . . . --- e2e/1_importAndWatchWalletsFlow.spec.ts | 7 +- e2e/3_homeScreen.spec.ts | 16 +- e2e/4_discoverSheetFlow.spec.ts | 3 +- e2e/5_sendSheetFlowContacts.spec.ts | 3 +- e2e/7_maliciousDappConnection.spec.ts | 2 +- e2e/8_swapSheetFlow1.spec.ts | 135 ++++ e2e/Disabled/deeplinks.disabled.ts | 155 ----- ...hardhatTransactionFlowSendAndWC.disable.js | 397 ----------- .../hardhatTransactionFlowSwaps.disabled.js | 419 ------------ e2e/Disabled/hiddenTokensFlow.disabled.js | 71 -- e2e/Disabled/registerENSFlow.disabled.js | 642 ------------------ e2e/Disabled/sendSheetFlow.disabled.ts | 159 ----- e2e/Disabled/swapSheetFlow1.disabled.js | 341 ---------- e2e/Disabled/swapSheetFlow2.disabled.js | 479 ------------- e2e/Disabled/walletAvatarOptions.disabled.js | 163 ----- e2e/helpers.ts | 3 +- e2e/init.js | 2 + e2e/jest.e2e.config.js | 25 +- jest.config.js | 35 +- package.json | 3 +- .../screens/Swap/components/SearchInput.tsx | 1 + .../Swap/components/SwapActionButton.tsx | 1 + .../Swap/components/UserAssetsSync.tsx | 12 +- .../screens/Swap/hooks/useAssetsToSell.ts | 8 +- .../Swap/hooks/useSwapInputsController.ts | 2 + src/__swaps__/types/chains.ts | 4 + src/components/activity-list/ActivityList.js | 1 + .../FastComponents/FastBalanceCoinRow.tsx | 2 +- src/references/chain-assets.json | 4 +- src/references/index.ts | 29 +- .../TransactionDetails.tsx | 2 +- tsconfig.jest.json | 6 - tsconfig.spec.json | 15 + 33 files changed, 234 insertions(+), 2913 deletions(-) create mode 100644 e2e/8_swapSheetFlow1.spec.ts delete mode 100644 e2e/Disabled/deeplinks.disabled.ts delete mode 100644 e2e/Disabled/hardhatTransactionFlowSendAndWC.disable.js delete mode 100644 e2e/Disabled/hardhatTransactionFlowSwaps.disabled.js delete mode 100644 e2e/Disabled/hiddenTokensFlow.disabled.js delete mode 100644 e2e/Disabled/registerENSFlow.disabled.js delete mode 100644 e2e/Disabled/sendSheetFlow.disabled.ts delete mode 100644 e2e/Disabled/swapSheetFlow1.disabled.js delete mode 100644 e2e/Disabled/swapSheetFlow2.disabled.js delete mode 100644 e2e/Disabled/walletAvatarOptions.disabled.js delete mode 100644 tsconfig.jest.json create mode 100644 tsconfig.spec.json diff --git a/e2e/1_importAndWatchWalletsFlow.spec.ts b/e2e/1_importAndWatchWalletsFlow.spec.ts index 311e6ce5987..431ea1452ad 100644 --- a/e2e/1_importAndWatchWalletsFlow.spec.ts +++ b/e2e/1_importAndWatchWalletsFlow.spec.ts @@ -12,6 +12,9 @@ import { } from './helpers'; import { WALLET_VARS } from './testVariables'; +// eslint-disable-next-line @typescript-eslint/no-var-requires +require('dotenv').config(); + const android = device.getPlatform() === 'android'; describe('Import from private key flow', () => { @@ -36,7 +39,7 @@ describe('Import from private key flow', () => { }); it('with 0x - Should show the "Add wallet modal" after tapping import with a valid private key"', async () => { - await typeText('import-sheet-input', process.env.DEV_PKEY); + await typeText('import-sheet-input', WALLET_VARS.PRIVATE_KEY_WALLET.SECRET); await checkIfElementHasString('import-sheet-button-label', 'Continue'); await waitAndTap('import-sheet-button'); await checkIfVisible('wallet-info-modal'); @@ -66,7 +69,7 @@ describe('Import from private key flow', () => { }); it('without 0x - Should show the "Add wallet modal" after tapping import with a valid private key"', async () => { - await typeText('import-sheet-input', WALLET_VARS.SEED_WALLET.PK.substring(2)); + await typeText('import-sheet-input', WALLET_VARS.EMPTY_WALLET.PK.substring(2)); await checkIfElementHasString('import-sheet-button-label', 'Continue'); await waitAndTap('import-sheet-button'); await checkIfVisible('wallet-info-modal'); diff --git a/e2e/3_homeScreen.spec.ts b/e2e/3_homeScreen.spec.ts index 145ce3798a3..94fea2546f0 100644 --- a/e2e/3_homeScreen.spec.ts +++ b/e2e/3_homeScreen.spec.ts @@ -5,8 +5,9 @@ import { checkIfExists, checkIfExistsByText, swipe, - waitAndTap, afterAllcleanApp, + tap, + delayTime, } from './helpers'; const RAINBOW_TEST_WALLET = 'rainbowtestwallet.eth'; @@ -41,19 +42,20 @@ describe('Home Screen', () => { }); it('tapping "Swap" opens the swap screen', async () => { - await waitAndTap('swap-button'); - await checkIfExists('exchange-modal-input-selection-button'); - await swipe('exchange-modal-notch', 'down', 'slow'); + await tap('swap-button'); + await delayTime('long'); + await checkIfExists('swap-screen'); + await swipe('swap-screen', 'down', 'fast'); }); it('tapping "Send" opens the send screen', async () => { - await waitAndTap('send-button'); + await tap('send-button'); await checkIfVisible('send-asset-form-field'); - await swipe('send-asset-form-field', 'down'); + await swipe('send-asset-form-field', 'down', 'fast'); }); it('tapping "Copy" shows copy address toast', async () => { - await waitAndTap('receive-button'); + await tap('receive-button'); await checkIfVisible('address-copied-toast'); }); }); diff --git a/e2e/4_discoverSheetFlow.spec.ts b/e2e/4_discoverSheetFlow.spec.ts index de0ad61f37e..b77fee00377 100644 --- a/e2e/4_discoverSheetFlow.spec.ts +++ b/e2e/4_discoverSheetFlow.spec.ts @@ -12,6 +12,7 @@ import { importWalletFlow, afterAllcleanApp, } from './helpers'; +import { WALLET_VARS } from './testVariables'; const ios = device.getPlatform() === 'ios'; @@ -23,7 +24,7 @@ describe('Discover Screen Flow', () => { await afterAllcleanApp({ hardhat: false }); }); it('Should import wallet and go to wallet screen', async () => { - await importWalletFlow(); + await importWalletFlow(WALLET_VARS.EMPTY_WALLET.PK); }); it('Should navigate to Discover screen after swiping left', async () => { diff --git a/e2e/5_sendSheetFlowContacts.spec.ts b/e2e/5_sendSheetFlowContacts.spec.ts index 0e64c4ae2ba..66971f77d01 100644 --- a/e2e/5_sendSheetFlowContacts.spec.ts +++ b/e2e/5_sendSheetFlowContacts.spec.ts @@ -13,6 +13,7 @@ import { delayTime, afterAllcleanApp, } from './helpers'; +import { WALLET_VARS } from './testVariables'; const android = device.getPlatform() === 'android'; @@ -25,7 +26,7 @@ describe('Send Sheet Interaction Flow Contacts', () => { }); it('Import a wallet and go to welcome', async () => { - await importWalletFlow(); + await importWalletFlow(WALLET_VARS.EMPTY_WALLET.PK); }); it('Should send ETH to test wallet"', async () => { diff --git a/e2e/7_maliciousDappConnection.spec.ts b/e2e/7_maliciousDappConnection.spec.ts index 0b6f49fd0bf..e32a809917b 100644 --- a/e2e/7_maliciousDappConnection.spec.ts +++ b/e2e/7_maliciousDappConnection.spec.ts @@ -23,7 +23,7 @@ describe('Check malicious dapp warning', () => { }); it('Should be able to watch a wallet and load the wallet screen', async () => { - await importWalletFlow(WALLET_VARS.SEED_WALLET.PK); + await importWalletFlow(WALLET_VARS.EMPTY_WALLET.PK); }); it('Should be able to navigate to the dapp browser', async () => { diff --git a/e2e/8_swapSheetFlow1.spec.ts b/e2e/8_swapSheetFlow1.spec.ts new file mode 100644 index 00000000000..9ebe24ab26a --- /dev/null +++ b/e2e/8_swapSheetFlow1.spec.ts @@ -0,0 +1,135 @@ +/* + * // TODO: + * - fix getNonceAndPerformSwap mocking + * - fix swap input auto fill validation (cannot import worklet `findNiceIncrement`) + * + * // Other tests to consider: + * - Flip assets + * - exchange button onPress + * - disable button states once https://github.com/rainbow-me/rainbow/pull/5785 gets merged + * - swap execution + * - token search (both from userAssets and output token list) + * - custom gas panel + * - flashbots + * - slippage + * - explainer sheets + * - switching wallets inside of swap screen + */ + +import { + importWalletFlow, + sendETHtoTestWallet, + checkIfVisible, + beforeAllcleanApp, + afterAllcleanApp, + fetchElementAttributes, + tap, + delayTime, + tapByText, +} from './helpers'; + +import { expect } from '@jest/globals'; +import { WALLET_VARS } from './testVariables'; + +describe('Swap Sheet Interaction Flow', () => { + beforeAll(async () => { + await beforeAllcleanApp({ hardhat: true }); + }); + afterAll(async () => { + await afterAllcleanApp({ hardhat: true }); + }); + + it('Import a wallet and go to welcome', async () => { + await importWalletFlow(WALLET_VARS.EMPTY_WALLET.PK); + }); + + it('Should send ETH to test wallet', async () => { + // send 20 eth + await sendETHtoTestWallet(); + }); + + it('Should show Hardhat Toast after pressing Connect To Hardhat', async () => { + await tap('dev-button-hardhat'); + await checkIfVisible('testnet-toast-Hardhat'); + + // validate it has the expected funds of 20 eth + const attributes = await fetchElementAttributes('fast-coin-info'); + expect(attributes.label).toContain('Ethereum'); + expect(attributes.label).toContain('20'); + }); + + it('Should open swap screen with 50% inputAmount for inputAsset', async () => { + await tap('swap-button'); + + // currently needed due to detox hanging on swap quotes + await device.disableSynchronization(); + await tap('token-to-buy-dai-1'); + const swapInput = await fetchElementAttributes('swap-asset-input'); + + // expect inputAsset === .5 * eth balance + expect(swapInput.elements[0].label).toContain('Ethereum'); + expect(swapInput.elements[0].label).toContain('10'); + }); + + it('Should be able to go to review and execute a swap', async () => { + await tapByText('Review'); + await delayTime('long'); + const reviewActionElements = await fetchElementAttributes('swap-action-button'); + expect(reviewActionElements.elements[0].label).toContain('ETH'); + expect(reviewActionElements.elements[1].label).toContain('DAI'); + expect(reviewActionElements.elements[2].label).toContain('Tap to Swap'); + await tapByText('Tap to Swap'); + }); + + it('Should be able to see pending swap in activity', async () => { + // allow swap to execute + await delayTime('long'); + const activityListElements = await fetchElementAttributes('wallet-activity-list'); + expect(activityListElements.label).toContain('ETH'); + expect(activityListElements.label).toContain('DAI'); + await tapByText('Swapping'); + await delayTime('long'); + const transactionSheet = await checkIfVisible('transaction-details-sheet'); + expect(transactionSheet).toBeTruthy(); + }); + + it('Should open swap screen from ProfileActionRowButton with largest user asset', async () => { + /** + * tap swap button + * wait for Swap header to be visible + * grab highest user asset balance from userAssetsStore + * expect inputAsset.uniqueId === highest user asset uniqueId + */ + }); + + it('Should open swap screen from asset chart with that asset selected', async () => { + /** + * tap any user asset (store const uniqueId here) + * wait for Swap header to be visible + * expect inputAsset.uniqueId === const uniqueId ^^ + */ + }); + + it('Should open swap screen from dapp browser control panel with largest user asset', async () => { + /** + * tap swap button + * wait for Swap header to be visible + * grab highest user asset balance from userAssetsStore + * expect inputAsset.uniqueId === highest user asset uniqueId + */ + }); + + it('Should not be able to type in output amount if cross-chain quote', async () => { + /** + * tap swap button + * wait for Swap header to be visible + * select different chain in output list chain selector + * select any asset in output token list + * focus output amount + * attempt to type any number in the SwapNumberPad + * attempt to remove a character as well + * + * ^^ expect both of those to not change the outputAmount + */ + }); +}); diff --git a/e2e/Disabled/deeplinks.disabled.ts b/e2e/Disabled/deeplinks.disabled.ts deleted file mode 100644 index af449e366af..00000000000 --- a/e2e/Disabled/deeplinks.disabled.ts +++ /dev/null @@ -1,155 +0,0 @@ -import { exec } from 'child_process'; -import { device } from 'detox'; -import { - openDeeplinkColdStart, - openDeeplinkFromBackground, - checkIfVisible, - checkIfElementByTextIsVisible, - swipe, - waitAndTap, - checkIfExists, - typeText, - checkIfElementHasString, - disableSynchronization, - authenticatePin, - enableSynchronization, - tapAlertWithButton, -} from '../helpers'; - -const RAINBOW_WALLET_ADDRESS = '0x7a3d05c70581bD345fe117c06e45f9669205384f'; - -const android = device.getPlatform() === 'android'; - -const testEthereumDeeplink = async (url: string, coldStart = true) => { - coldStart ? await openDeeplinkColdStart(url) : await openDeeplinkFromBackground(url); - await checkIfVisible('send-sheet-confirm-action-button', 30000); - // Because we don't have ETH in this wallet - try { - await checkIfElementByTextIsVisible('􀕹 Review', 15000); - } catch (e) { - try { - await checkIfElementByTextIsVisible('Insufficient ETH', 15000); - } catch (e) { - await checkIfElementByTextIsVisible('Insufficient Funds', 15000); - } - } - await swipe('send-sheet', 'down'); -}; - -const escapeUrl = (url: string) => { - if (android) { - return url.replace(/&/g, '\\&'); - } else { - return url; - } -}; - -beforeAll(async () => { - if (android) { - // When opening deeplink to rainbow, Android asks if we want to do it in - // Chrome or the app. Detox is only able to control tapping within the app, - // so this blocks our tests. The only way we found to bypass this is to - // uninstall Chrome before. - exec('yarn adb-all shell pm disable-user com.android.chrome'); - } - await device.reloadReactNative(); -}); -afterAll(async () => { - await device.clearKeychain(); -}); - -describe.skip('Deeplinks spec', () => { - it('Should show the welcome screen', async () => { - await checkIfVisible('welcome-screen'); - }); - - it('Should show the "Add Wallet Sheet" after tapping on "I already have a wallet"', async () => { - await waitAndTap('already-have-wallet-button'); - await checkIfExists('add-wallet-sheet'); - }); - - it('Show the "Import Sheet" when tapping on "Restore with a recovery phrase or private key"', async () => { - await waitAndTap('restore-with-key-button'); - await checkIfExists('import-sheet'); - }); - - it('Should show the "Add wallet modal" after tapping import with a valid private key"', async () => { - await typeText('import-sheet-input', process.env.TEST_SEEDS, false); - await checkIfElementHasString('import-sheet-button-label', 'Continue'); - await waitAndTap('import-sheet-button'); - await checkIfVisible('wallet-info-modal'); - }); - - it('Should navigate to the Wallet screen after tapping on "Import Wallet"', async () => { - await disableSynchronization(); - await waitAndTap('wallet-info-submit-button'); - if (android) { - await checkIfVisible('pin-authentication-screen'); - // Set the pin - await authenticatePin('1234'); - // Confirm it - await authenticatePin('1234'); - } - await checkIfVisible('wallet-screen', 40000); - await enableSynchronization(); - }); - - it('should reject ethereum urls for assets that are not in the wallet', async () => { - const url = `ethereum:0xef2e9966eb61bb494e5375d5df8d67b7db8a780d@1/transfer?address=${RAINBOW_WALLET_ADDRESS}&uint256=1e15`; - await openDeeplinkFromBackground(url); - await checkIfElementByTextIsVisible('Ooops!', 30000); - await tapAlertWithButton('OK'); - }); - - it('should show the Profile Sheet for rainbow.me universal links with ENS names', async () => { - await openDeeplinkFromBackground('https://rainbow.me/profile/rainbowwallet.eth'); - await checkIfVisible('profile-sheet', 30000); - await checkIfElementByTextIsVisible('rainbowwallet.eth', 30000); - await swipe('profile-sheet', 'down'); - }); - - it('should show the Profile Sheet for rainbow.me universal links with 0x addresses', async () => { - await openDeeplinkFromBackground('https://rainbow.me/profile/0xE46aBAf75cFbFF815c0b7FfeD6F02B0760eA27f1'); - await checkIfVisible('profile-sheet', 30000); - await checkIfElementByTextIsVisible('0xE46aBAf75cFbFF815c0b7FfeD6F02B0760eA27f1', 30000); - await swipe('profile-sheet', 'down'); - }); - - it.skip('should be able to handle ethereum payments urls for ETH (mainnet)', async () => { - const url = escapeUrl(`ethereum:payment-${RAINBOW_WALLET_ADDRESS}@1?value=1e2`); - await testEthereumDeeplink(url, false); - }); - - it.skip('should be able to handle ethereum payments urls for ETH (optimism)', async () => { - const url = escapeUrl(`ethereum:payment-${RAINBOW_WALLET_ADDRESS}@10?value=1e15`); - await testEthereumDeeplink(url, false); - }); - - // FIXME: when doing open deeplinks with cold start, the account assets state - // comes back empty, find a fix and then change these tests to cold-start again - it('should be able to handle ethereum payments urls for DAI (mainnet)', async () => { - const url = escapeUrl(`ethereum:0x6b175474e89094c44da98b954eedeac495271d0f@1/transfer?address=${RAINBOW_WALLET_ADDRESS}&uint256=1e18`); - await testEthereumDeeplink(url, false); - }); - - // FIXME: when doing open deeplinks with cold start, the account assets state - // comes back empty, find a fix and then change these tests to cold-start again - it.skip('should be able to handle ethereum payments urls for ETH (arbitrum)', async () => { - const url = `ethereum:payment-${RAINBOW_WALLET_ADDRESS}@42161?value=1e15`; - await testEthereumDeeplink(url, false); - }); - - // FIXME: when doing open deeplinks with cold start, the account assets state - // comes back empty, find a fix and then change these tests to cold-start again - it.skip('should be able to handle ethereum payments urls for DAI (optimism)', async () => { - const url = escapeUrl(`ethereum:0xda10009cbd5d07dd0cecc66161fc93d7c9000da1@10/transfer?address=${RAINBOW_WALLET_ADDRESS}&uint256=1e15`); - await testEthereumDeeplink(url, false); - }); - - // FIXME: when doing open deeplinks with cold start, the account assets state - // comes back empty, find a fix and then change these tests to cold-start again - it.skip('should be able to handle ethereum payments urls for MATIC (polygon)', async () => { - const url = escapeUrl(`ethereum:payment-${RAINBOW_WALLET_ADDRESS}@137?value=1e15`); - await testEthereumDeeplink(url, false); - }); -}); diff --git a/e2e/Disabled/hardhatTransactionFlowSendAndWC.disable.js b/e2e/Disabled/hardhatTransactionFlowSendAndWC.disable.js deleted file mode 100644 index 078e7ef09d2..00000000000 --- a/e2e/Disabled/hardhatTransactionFlowSendAndWC.disable.js +++ /dev/null @@ -1,397 +0,0 @@ -import { Contract } from '@ethersproject/contracts'; -import WalletConnect from '@walletconnect/client'; -import { convertUtf8ToHex } from '@walletconnect/legacy-utils'; -import * as Helpers from '../helpers'; -import kittiesABI from '@/references/cryptokitties-abi.json'; -import erc20ABI from '@/references/erc20-abi.json'; -import { device } from 'detox'; - -let connector = null; -let uri = null; -let account = null; - -const ios = device.getPlatform() === 'ios'; -const android = device.getPlatform() === 'android'; - -const RAINBOW_WALLET_DOT_ETH = '0x7a3d05c70581bd345fe117c06e45f9669205384f'; -const TESTING_WALLET = '0x3Cb462CDC5F809aeD0558FBEe151eD5dC3D3f608'; - -const CRYPTOKITTIES_ADDRESS = '0x06012c8cf97BEaD5deAe237070F9587f8E7A266d'; -const ETH_ADDRESS = 'eth'; -const BAT_TOKEN_ADDRESS = '0x0d8775f648430679a709e98d2b0cb6250d2887ef'; - -const isNFTOwner = async address => { - const provider = Helpers.getProvider(); - const kittiesContract = new Contract(CRYPTOKITTIES_ADDRESS, kittiesABI, provider); - const ownerAddress = await kittiesContract.ownerOf('1368227'); - return ownerAddress?.toLowerCase() === address?.toLowerCase(); -}; - -const getOnchainBalance = async (address, tokenContractAddress) => { - const provider = Helpers.getProvider(); - if (tokenContractAddress === ETH_ADDRESS) { - const balance = await provider.getBalance(RAINBOW_WALLET_DOT_ETH); - return balance; - } else { - const tokenContract = new Contract(tokenContractAddress, erc20ABI, provider); - const balance = await tokenContract.balanceOf(address); - return balance; - } -}; - -beforeAll(async () => { - await Helpers.startHardhat(); - await Helpers.startIosSimulator(); -}); - -describe.skip('Hardhat Transaction Flow', () => { - it('Should show the welcome screen', async () => { - await Helpers.checkIfVisible('welcome-screen'); - }); - - it('Should show the "Add Wallet Sheet" after tapping on "I already have a wallet"', async () => { - await Helpers.waitAndTap('already-have-wallet-button'); - await Helpers.checkIfExists('add-wallet-sheet'); - }); - - it('show the "Import Sheet" when tapping on "Restore with a recovery phrase or private key"', async () => { - await Helpers.waitAndTap('restore-with-key-button'); - await Helpers.checkIfExists('import-sheet'); - }); - - it('Should show the "Add wallet modal" after tapping import with a valid seed"', async () => { - await Helpers.clearField('import-sheet-input'); - await Helpers.typeText('import-sheet-input', process.env.TEST_SEEDS, false); - await Helpers.checkIfElementHasString('import-sheet-button-label', 'Continue'); - await Helpers.waitAndTap('import-sheet-button'); - await Helpers.checkIfVisible('wallet-info-modal'); - }); - - it('Should navigate to the Wallet screen after tapping on "Import Wallet"', async () => { - await Helpers.disableSynchronization(); - await Helpers.waitAndTap('wallet-info-submit-button'); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - // Set the pin - await Helpers.authenticatePin('1234'); - // Confirm it - await Helpers.authenticatePin('1234'); - } - await Helpers.checkIfVisible('wallet-screen', 80000); - await Helpers.enableSynchronization(); - }); - - it('Should send ETH to test wallet"', async () => { - await Helpers.sendETHtoTestWallet(); - }); - - it('Should show Hardhat Toast after pressing Connect To Hardhat', async () => { - await Helpers.waitAndTap('dev-button-hardhat'); - await Helpers.checkIfVisible('testnet-toast-Hardhat'); - }); - - it('Should open send sheet after tapping send fab', async () => { - await Helpers.waitAndTap('send-button'); - await Helpers.checkIfVisible('send-asset-form-field'); - }); - - // FIXME: This is the problem with a review button being tapped but detox not - // registering the action and timing out and leaving the state of the app in - // a place where all following tests are failing. - it.skip('Should send (Cryptokitties)', async () => { - await Helpers.typeTextAndHideKeyboard('send-asset-form-field', RAINBOW_WALLET_DOT_ETH); - await Helpers.waitAndTap('CryptoKitties-family-header'); - await Helpers.tapByText('Arun Cattybinky'); - await Helpers.waitAndTap('gas-speed-custom'); - await Helpers.waitAndTap('speed-pill-urgent'); - await Helpers.waitAndTap('gas-speed-done-button'); - await Helpers.checkIfVisible('send-sheet-confirm-action-button'); - // FIXME: This taps in the sim, but test never picks up the action - // confirmation - await Helpers.waitAndTap('send-sheet-confirm-action-button', 20000); - await Helpers.tapAndLongPress('send-confirmation-button'); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await Helpers.checkIfVisible('profile-screen'); - const isOwnerRecipient = await isNFTOwner(RAINBOW_WALLET_DOT_ETH); - if (!isOwnerRecipient) { - throw new Error('Recepient did not recieve Cryptokitty'); - } - }); - - it.skip('Should show completed send NFT (Cryptokitties)', async () => { - try { - await Helpers.checkIfVisible('Sent-Arun Cattybinky-1.00 CryptoKitties'); - } catch (e) { - await Helpers.checkIfVisible('Sending-Arun Cattybinky-1.00 CryptoKitties'); - } - - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it.skip('Should send ERC20 (BAT)', async () => { - const preSendBalance = await getOnchainBalance(RAINBOW_WALLET_DOT_ETH, BAT_TOKEN_ADDRESS); - await Helpers.waitAndTap('send-button'); - await Helpers.typeTextAndHideKeyboard('send-asset-form-field', RAINBOW_WALLET_DOT_ETH); - await Helpers.waitAndTap('send-asset-BAT-mainnet'); - await Helpers.typeText('selected-asset-field-input', '1.02', true); - await Helpers.waitAndTap('send-sheet-confirm-action-button'); - await Helpers.tapAndLongPress('send-confirmation-button'); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await Helpers.checkIfVisible('profile-screen'); - const postSendBalance = await getOnchainBalance(RAINBOW_WALLET_DOT_ETH, BAT_TOKEN_ADDRESS); - if (!postSendBalance.gt(preSendBalance)) { - throw new Error('Recepient did not recieve BAT'); - } - }); - - it.skip('Should show completed send ERC20 (BAT)', async () => { - try { - await Helpers.checkIfVisible('Sent-Basic Attention Token-1.02 BAT'); - } catch (e) { - await Helpers.checkIfVisible('Sending-Basic Attention Token-1.02 BAT'); - } - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it.skip('Should send ETH', async () => { - await Helpers.waitAndTap('send-button'); - await Helpers.typeTextAndHideKeyboard('send-asset-form-field', RAINBOW_WALLET_DOT_ETH); - const preSendBalance = await getOnchainBalance(RAINBOW_WALLET_DOT_ETH, ETH_ADDRESS); - await Helpers.waitAndTap('send-asset-ETH-mainnet'); - await Helpers.typeText('selected-asset-field-input', '0.003', true); - await Helpers.waitAndTap('send-sheet-confirm-action-button'); - await Helpers.tapAndLongPress('send-confirmation-button'); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await Helpers.checkIfVisible('profile-screen'); - const postSendBalance = await getOnchainBalance(RAINBOW_WALLET_DOT_ETH, ETH_ADDRESS); - if (!postSendBalance.gt(preSendBalance)) { - throw new Error('Recepient did not recieve ETH'); - } - }); - - it.skip('Should show completed send ETH', async () => { - try { - await Helpers.checkIfVisible('Sent-Ethereum-0.003 ETH'); - } catch (e) { - await Helpers.checkIfVisible('Sending-Ethereum-0.003 ETH'); - } - await Helpers.checkIfVisible('profile-screen'); - }); - - // FIXME: we have converted to V2 - review and re-enable - if (ios) { - // TODO important - it('Should receive the WC connect request and approve it', async () => { - connector = new WalletConnect({ - bridge: 'https://bridge.walletconnect.org', - clientMeta: { - description: 'Connect with WalletConnect', - icons: ['https://walletconnect.org/walletconnect-logo.png'], - name: 'WalletConnect', - url: 'https://walletconnect.org', - }, - }); - - await connector.createSession(); - uri = connector.uri; - const connected = new Promise(async (resolve, reject) => { - connector.on('connect', (error, payload) => { - if (error) { - reject(error); - } - const { accounts } = payload.params[0]; - if (accounts[0] === TESTING_WALLET) { - account = accounts[0]; - resolve(true); - } else { - reject(false); - } - }); - }); - - const baseUrl = 'https://rnbwapp.com'; - const encodedUri = encodeURIComponent(uri); - const fullUrl = `${baseUrl}/wc?uri=${encodedUri}`; - - await Helpers.openDeeplinkFromBackground(fullUrl); - - await Helpers.checkIfVisible('wc-approval-sheet', 30000); - await Helpers.waitAndTap('wc-connect-action-button'); - const isConnected = await connected; - if (!isConnected) throw new Error('WC Connection failed'); - android && (await Helpers.delay(2137)); - await Helpers.checkIfVisible('wc-redirect-sheet'); - if (android) { - await device.pressBack(); - } else { - await Helpers.swipe('wc-redirect-sheet', 'down', 'fast'); - } - }); - - it('Should be able to sign personal messages via WC', async () => { - const result = connector.signPersonalMessage(['My msg', account]); - await Helpers.checkIfVisible('wc-request-sheet'); - await Helpers.waitAndTap('wc-confirm-action-button'); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - if (!result) throw new Error('WC Connection failed'); - const signature = await result; - if ( - signature !== - '0x9b08221727750e582b43e14f50069083ac6d8a2670a9f28009f14cbef7e66ba16d3370330aed5b6744027bd6a0bef32cb97bb9da3db34c67ba2237b2ef5d1ec71b' - ) { - throw new Error('WC personal sign failed'); - } - }); - - it('Should be able to sign eth_sign messages via WC', async () => { - const message = `My email is john@doe.com`; - const hexMsg = convertUtf8ToHex(message); - const msgParams = [account, hexMsg]; - const result = connector.signMessage(msgParams); - await Helpers.checkIfVisible('wc-request-sheet'); - await Helpers.waitAndTap('wc-confirm-action-button'); - - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - - if (!result) throw new Error('WC Connection failed'); - const signature = await result; - // verify signature - if ( - signature !== - '0x141d62e1aaa2202ededb07f1684ef6d3d9958d334713010ea91df3831e3a3c99303a83f334d1e5e935c4edd7146a2f3f4301c5d509ccfeffd55f5db4e971958b1c' - ) { - throw new Error('WC eth_sign failed'); - } - }); - - it('Should be able to sign typed data messages via WC', async () => { - const msg = { - types: { - EIP712Domain: [ - { name: 'name', type: 'string' }, - { name: 'version', type: 'string' }, - { name: 'verifyingContract', type: 'address' }, - ], - RelayRequest: [ - { name: 'target', type: 'address' }, - { name: 'encodedFunction', type: 'bytes' }, - { name: 'gasData', type: 'GasData' }, - { name: 'relayData', type: 'RelayData' }, - ], - GasData: [ - { name: 'gasLimit', type: 'uint256' }, - { name: 'gasPrice', type: 'uint256' }, - { name: 'pctRelayFee', type: 'uint256' }, - { name: 'baseRelayFee', type: 'uint256' }, - ], - RelayData: [ - { name: 'senderAddress', type: 'address' }, - { name: 'senderNonce', type: 'uint256' }, - { name: 'relayWorker', type: 'address' }, - { name: 'paymaster', type: 'address' }, - ], - }, - domain: { - name: 'GSN Relayed Transaction', - version: '1', - chainId: 42, - verifyingContract: '0x6453D37248Ab2C16eBd1A8f782a2CBC65860E60B', - }, - primaryType: 'RelayRequest', - message: { - target: '0x9cf40ef3d1622efe270fe6fe720585b4be4eeeff', - encodedFunction: - '0xa9059cbb0000000000000000000000002e0d94754b348d208d64d52d78bcd443afa9fa520000000000000000000000000000000000000000000000000000000000000007', - gasData: { - gasLimit: '39507', - gasPrice: '1700000000', - pctRelayFee: '70', - baseRelayFee: '0', - }, - relayData: { - senderAddress: '0x22d491bde2303f2f43325b2108d26f1eaba1e32b', - senderNonce: '3', - relayWorker: '0x3baee457ad824c94bd3953183d725847d023a2cf', - paymaster: '0x957F270d45e9Ceca5c5af2b49f1b5dC1Abb0421c', - }, - }, - }; - - const result = connector.signTypedData([account, JSON.stringify(msg)]); - await Helpers.checkIfVisible('wc-request-sheet'); - await Helpers.waitAndTap('wc-confirm-action-button'); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - - const signature = await result; - if ( - signature !== - '0xb78f17ff5779826ebfe4a7572a569a8802c02962242ff0195bd17bd4c07248b930a8c459276bc6eaa02dfb4523b8dc66d0020742d3f60a9209bde811aebb39351b' - ) { - throw new Error('WC typed data failed'); - } - }); - - it('Should be able to approve transactions via WC (Send)', async () => { - const preSendBalance = await getOnchainBalance(RAINBOW_WALLET_DOT_ETH, ETH_ADDRESS); - const result = connector.sendTransaction({ - from: account, - to: RAINBOW_WALLET_DOT_ETH, - value: '0x0000000000000000000000000000000000000000000000000de0b6b3a7640000', - data: '0x', - }); - await Helpers.checkIfVisible('wc-request-sheet'); - - await Helpers.waitAndTap('wc-confirm-action-button'); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - - await Helpers.checkIfVisible('profile-screen'); - const hash = await result; - if (!hash) { - throw new Error('WC approving tx failed'); - } - - const postSendBalance = await getOnchainBalance(RAINBOW_WALLET_DOT_ETH, ETH_ADDRESS); - if (!postSendBalance.gt(preSendBalance)) throw new Error('Recepient did not recieve ETH'); - }); - - it('Should show completed send ETH (WC)', async () => { - try { - await Helpers.checkIfVisible('Sent-Ethereum-1.00 ETH'); - } catch (e) { - await Helpers.checkIfVisible('Sending-Ethereum-1.00 ETH'); - } - }); - } - - afterAll(async () => { - // Reset the app state - await connector?.killSession(); - connector = null; - await device.clearKeychain(); - await Helpers.killHardhat(); - }); -}); diff --git a/e2e/Disabled/hardhatTransactionFlowSwaps.disabled.js b/e2e/Disabled/hardhatTransactionFlowSwaps.disabled.js deleted file mode 100644 index aa2343731d9..00000000000 --- a/e2e/Disabled/hardhatTransactionFlowSwaps.disabled.js +++ /dev/null @@ -1,419 +0,0 @@ -import * as Helpers from '../helpers'; -import { device } from 'detox'; - -let connector = null; -const ios = device.getPlatform() === 'ios'; -const android = device.getPlatform() === 'android'; - -beforeAll(async () => { - await Helpers.startHardhat(); - await Helpers.startIosSimulator(); -}); - -const acceptAlertIfGasPriceIsHigh = async () => { - // Depending on current gas prices, we might get an alert - // saying that the fees are higher than the swap amount - try { - if (await Helpers.checkIfElementByTextIsVisible('Proceed Anyway')) { - await Helpers.tapAlertWithButton('Proceed Anyway'); - } - // eslint-disable-next-line no-empty - } catch (e) {} -}; - -// eslint-disable-next-line no-unused-vars -const checkIfSwapCompleted = async (assetName, amount) => { - // Disabling this because there's a view blocking (The portal) - // await Helpers.checkIfVisible(`Swapped-${assetName}-${amount}`); - return true; -}; - -// FIXME: Mainnet DAI doesn't show up in the swap search results -// This might be related to @Jin's latest work on changes to hardhat as -// part of the addy's REST API migration -// -// marking the test as SKIP for now -describe.skip('Hardhat Transaction Flow', () => { - it('Should show the welcome screen', async () => { - await Helpers.checkIfVisible('welcome-screen'); - }); - - it('Should show the "Add Wallet Sheet" after tapping on "I already have a wallet"', async () => { - await Helpers.waitAndTap('already-have-wallet-button'); - await Helpers.checkIfExists('add-wallet-sheet'); - }); - - it('show the "Import Sheet" when tapping on "Restore with a recovery phrase or private key"', async () => { - await Helpers.waitAndTap('restore-with-key-button'); - await Helpers.checkIfExists('import-sheet'); - }); - - it('Should show the "Add wallet modal" after tapping import with a valid seed"', async () => { - await Helpers.clearField('import-sheet-input'); - await Helpers.typeText('import-sheet-input', process.env.TEST_SEEDS, false); - await Helpers.checkIfElementHasString('import-sheet-button-label', 'Continue'); - await Helpers.waitAndTap('import-sheet-button'); - await Helpers.checkIfVisible('wallet-info-modal'); - }); - - it('Should navigate to the Wallet screen after tapping on "Import Wallet"', async () => { - await Helpers.disableSynchronization(); - await Helpers.waitAndTap('wallet-info-submit-button'); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - // Set the pin - await Helpers.authenticatePin('1234'); - // Confirm it - await Helpers.authenticatePin('1234'); - } - await Helpers.checkIfVisible('wallet-screen', 80000); - await Helpers.enableSynchronization(); - }); - - it('Should send ETH to test wallet"', async () => { - await Helpers.sendETHtoTestWallet(); - }); - - it('Should show Hardhat Toast after pressing Connect To Hardhat', async () => { - await Helpers.waitAndTap('dev-button-hardhat'); - await Helpers.checkIfVisible('testnet-toast-Hardhat'); - }); - - it.skip('Should deposit DAI (via Compound)', async () => { - await Helpers.tap('Savings-list-header'); - await Helpers.waitAndTap('savings-list-row-DAI'); - await Helpers.waitAndTap('deposit-action-button'); - await Helpers.typeText('deposit-modal-input', '5', true, true); - await Helpers.tapAndLongPress('deposit-modal-confirm-button'); - await acceptAlertIfGasPriceIsHigh(); - try { - await Helpers.checkIfVisible('Deposited-Dai-5.00 DAI'); - } catch (e) { - await Helpers.checkIfVisible('Depositing-Dai-5.00 DAI'); - } - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it('Should be able to do a cross chain swap', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('exchange-modal-output-selection-button'); - await Helpers.waitAndTap('network-switcher-item-optimism'); - await Helpers.typeText('currency-select-search-input', 'USDC', true); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-USDC-optimism'); - await Helpers.typeText('exchange-modal-input', '0.001', true); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - await acceptAlertIfGasPriceIsHigh(); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - }); - - it('Should be able to do a bridge', async () => { - await Helpers.swipe('profile-screen', 'left', 'slow'); - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.typeText('currency-select-search-input', 'USDC', true); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-USDC-mainnet'); - await Helpers.waitAndTap('exchange-modal-output-selection-button'); - await Helpers.waitAndTap('network-switcher-item-optimism'); - await Helpers.typeText('currency-select-search-input', 'USDC', true); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-USDC-optimism'); - await Helpers.typeText('exchange-modal-input', '0.01', true); - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - await Helpers.tapAndLongPress('swap-details-confirm-button'); - await acceptAlertIfGasPriceIsHigh(); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it.skip('Should withdraw DAI (via Compound)', async () => { - await Helpers.waitAndTap('savings-list-row-DAI'); - await Helpers.waitAndTap('withdraw-action-button'); - await Helpers.typeText('withdraw-modal-input', '1', true, true); - await Helpers.tapAndLongPress('withdraw-modal-confirm-button'); - await acceptAlertIfGasPriceIsHigh(); - try { - await Helpers.checkIfVisible('Withdrew-Dai-1.00 DAI'); - } catch (e) { - await Helpers.checkIfVisible('Withdrawing-Dai-1.00 DAI'); - } - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it('Should be able to search random tokens (like SWYF) via address and swap them', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.waitAndTap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', '0xefa6903aa49cd539c079ac4b0a090db432615822', true); - }); - - it('Should be able to search random tokens (like SWYF) via address and swap them 2', async () => { - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-SWYF-mainnet'); - await Helpers.tapByText('Continue'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.typeText('exchange-modal-input', '0.001', true, true); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - - await acceptAlertIfGasPriceIsHigh(); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - - await checkIfSwapCompleted('Ethereum', '0.001 ETH'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it('Should be able to wrap ETH -> WETH', async () => { - await Helpers.tap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'WETH', true); - await Helpers.tap('currency-select-list-exchange-coin-row-WETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.typeText('exchange-modal-input', '0.001', true, true); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - - await acceptAlertIfGasPriceIsHigh(); - if (android) { - await Helpers.delay(3000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await checkIfSwapCompleted('Ethereum', '0.001 ETH'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - it('Should be able to unwrap WETH -> ETH', async () => { - await Helpers.tap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'WETH', true); - await Helpers.tap('currency-select-list-exchange-coin-row-WETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.typeText('exchange-modal-input', '0.0005', true, true); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - - await acceptAlertIfGasPriceIsHigh(); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await checkIfSwapCompleted('Wrapper Ether', '0.0005 WETH'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - it('Should swap WETH -> DAI including approval (via tokenToToken)', async () => { - await Helpers.tap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'WETH', true); - await Helpers.tap('currency-select-list-exchange-coin-row-WETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.typeText('exchange-modal-input', '0.0005', true, true); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - await acceptAlertIfGasPriceIsHigh(); - - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await checkIfSwapCompleted('Wrapper Ether', '0.0005 WETH'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it('Should swap DAI -> USDC (via tokenToTokenWithPermit)', async () => { - await Helpers.tap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'USDC', true); - await Helpers.tap('currency-select-list-exchange-coin-row-USDC-mainnet'); - await Helpers.typeText('exchange-modal-input', '10', true, true); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - - await acceptAlertIfGasPriceIsHigh(); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await checkIfSwapCompleted('DAI', '4 DAI'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it('Should swap DAI -> ETH (via tokenToETH)', async () => { - await Helpers.tap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.typeText('exchange-modal-input', '4', true, true); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - - await acceptAlertIfGasPriceIsHigh(); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await checkIfSwapCompleted('DAI', '4 DAI'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it('Should swap ETH -> USDC (via ethToToken)', async () => { - await Helpers.tap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'USDC', true); - await Helpers.tap('currency-select-list-exchange-coin-row-USDC-mainnet'); - await Helpers.typeText('exchange-modal-input', '0.005', true, true); - await Helpers.delay(1000); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - await acceptAlertIfGasPriceIsHigh(); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await checkIfSwapCompleted('Ethereum', '0.005 ETH'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - it('Should swap USDC -> WETH (via tokenToTokenWithPermit)', async () => { - await Helpers.tap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'USDC', true); - await Helpers.tap('currency-select-list-exchange-coin-row-USDC-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'WETH', true); - await Helpers.tap('currency-select-list-exchange-coin-row-WETH-mainnet'); - await Helpers.typeText('exchange-modal-input', '14', true, true); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - await acceptAlertIfGasPriceIsHigh(); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await checkIfSwapCompleted('USD Coin', '25 USDC'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it('Should swap USDC -> ETH (via tokenToETH)', async () => { - await Helpers.tap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'USDC', true); - await Helpers.tap('currency-select-list-exchange-coin-row-USDC-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.typeText('exchange-modal-input', '10', true, true); - await Helpers.delay(1000); - if (ios) { - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - } else { - await Helpers.tap('exchange-modal-confirm-button'); - } - await Helpers.tapAndLongPress('swap-details-confirm-button'); - await acceptAlertIfGasPriceIsHigh(); - if (android) { - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await checkIfSwapCompleted('USD Coin', '20 USDC'); - await acceptAlertIfGasPriceIsHigh(); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - afterAll(async () => { - // Reset the app state - await connector?.killSession(); - connector = null; - await device.clearKeychain(); - await Helpers.killHardhat(); - }); -}); diff --git a/e2e/Disabled/hiddenTokensFlow.disabled.js b/e2e/Disabled/hiddenTokensFlow.disabled.js deleted file mode 100644 index a0e6f2659a0..00000000000 --- a/e2e/Disabled/hiddenTokensFlow.disabled.js +++ /dev/null @@ -1,71 +0,0 @@ -import * as Helpers from '../helpers'; -import { device, element, by, waitFor } from 'detox'; - -const android = device.getPlatform() === 'android'; - -describe.skip('Hidden tokens flow', () => { - it('boots and loads wallet screen', async () => { - await Helpers.waitAndTap('already-have-wallet-button'); - await Helpers.waitAndTap('restore-with-key-button'); - await Helpers.clearField('import-sheet-input'); - await Helpers.typeText('import-sheet-input', process.env.TEST_SEEDS, false); - await Helpers.waitAndTap('import-sheet-button'); - await Helpers.disableSynchronization(); - await Helpers.waitAndTap('wallet-info-submit-button'); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - // Set the pin - await Helpers.authenticatePin('1234'); - // Confirm it - await Helpers.authenticatePin('1234'); - } - await Helpers.checkIfVisible('wallet-screen', 80000); - await Helpers.enableSynchronization(); - }); - - it('NFT is hideable', async () => { - // open ENS and tap on our ENS NFT - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.tap('token-family-header-ENS'); - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.waitAndTap('wrapped-nft-rainbowtestwallet.eth'); - await Helpers.waitAndTap('unique-mainnet-expanded-state-context-menu-button'); - - if (android) { - await waitFor(element(by.text('Hide'))) - .toBeVisible() - .withTimeout(2000); - await element(by.text('Hide')).tap(); - } else { - await waitFor(element(by.label('Hide')).atIndex(1)).toBeVisible(); - await element(by.label('Hide')).atIndex(1).tap(); - } - }); - - it('NFT shows in Hidden collection', async () => { - // open ENS and tap on our ENS NFT - await waitFor(element(by.id('token-family-header-Hidden'))).toBeVisible(); - }); - - it('NFT is unhideable', async () => { - // open ENS and tap on our ENS NFT - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.tap('token-family-header-Hidden'); - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.waitAndTap('wrapped-nft-rainbowtestwallet.eth'); - await Helpers.waitAndTap('unique-mainnet-expanded-state-context-menu-button'); - - await waitFor(element(by.text('Unhide'))) - .toBeVisible() - .withTimeout(2000); - await element(by.text('Unhide')).tap(); - - await waitFor(element(by.id('token-family-header-Hidden'))).toNotExist(); - - await Helpers.checkIfVisible('wrapped-nft-rainbowtestwallet.eth'); - }); - - afterAll(async () => { - await device.clearKeychain(); - }); -}); diff --git a/e2e/Disabled/registerENSFlow.disabled.js b/e2e/Disabled/registerENSFlow.disabled.js deleted file mode 100644 index a177ab85c65..00000000000 --- a/e2e/Disabled/registerENSFlow.disabled.js +++ /dev/null @@ -1,642 +0,0 @@ -import { hash } from '@ensdomains/eth-ens-namehash'; -import { Contract } from '@ethersproject/contracts'; -import * as Helpers from '../helpers'; -import registrarABI from '@/references/ens/ENSETHRegistrarController.json'; -import publicResolverABI from '@/references/ens/ENSPublicResolver.json'; -import registryWithFallbackABI from '@/references/ens/ENSRegistryWithFallback.json'; -import { device } from 'detox'; - -const ensETHRegistrarControllerAddress = '0x283Af0B28c62C092C9727F1Ee09c02CA627EB7F5'; -const ensPublicResolverAddress = '0x4976fb03C32e5B8cfe2b6cCB31c09Ba78EBaBa41'; -const ensRegistryAddress = '0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e'; - -const RANDOM_NAME = 'randomname321'; -const RANDOM_NAME_ETH = RANDOM_NAME + '.eth'; -const RAINBOW_TEST_WALLET_NAME = 'rainbowtestwallet.eth'; -const RAINBOW_TEST_WALLET_ADDRESS = '0x3Cb462CDC5F809aeD0558FBEe151eD5dC3D3f608'; -const RAINBOW_WALLET_NAME = 'rainbowwallet.eth'; -const RAINBOW_WALLET_ADDRESS = '0x7a3d05c70581bD345fe117c06e45f9669205384f'; -const RECORD_BIO = 'my bio'; -const RECORD_NAME = 'random'; -const RECORD_CONTENTHASH = 'ipfs://QmRAQB6YaCyidP37UdDnjFY5vQuiBrcqdyoW1CuDgwxkD4'; -const RECORD_TWITTER = 'twitter123'; -const RECORD_EMAIL = 'abc@abc.com'; -const RECORD_INSTAGRAM = 'insta123'; -const RECORD_DISCORD = 'abc#8133'; -const RECORD_GITHUB = 'github-123'; -const RECORD_SNAPCHAT = 'snapchat123'; -const RECORD_TELEGRAM = 'telegram123'; -const RECORD_REDDIT = 'reddit123'; -const RECORD_PRONOUNS = 'they/them'; -const RECORD_NOTICE = 'notice123'; -const RECORD_KEYWORDS = 'keywords123'; -const RECORD_URL = 'abc123.com'; -const EIP155_FORMATTED_AVATAR_RECORD = 'eip155:1/erc721:0x06012c8cf97bead5deae237070f9587f8e7a266d/1368227'; -const WALLET_AVATAR_COORDS = { x: 210, y: 125 }; - -const ios = device.getPlatform() === 'ios'; -const android = device.getPlatform() === 'android'; - -const address = (address, start, finish) => [address.substring(0, start), address.substring(address.length - finish)].join('...'); - -const nameIsAvailable = async name => { - const provider = Helpers.getProvider(); - const registrarContract = new Contract(ensETHRegistrarControllerAddress, registrarABI, provider); - const nameIsAvailable = await registrarContract.available(name); - return !!nameIsAvailable; -}; - -const getNameOwner = async ensName => { - const provider = Helpers.getProvider(); - const registry = new Contract(ensRegistryAddress, registryWithFallbackABI, provider); - const owner = await registry.owner(hash(ensName)); - return owner; -}; - -const getRecords = async ensName => { - const provider = Helpers.getProvider(); - const publicResolver = new Contract(ensPublicResolverAddress, publicResolverABI, provider); - const resolver = await provider.getResolver(ensName); - const hashName = hash(ensName); - const [avatar, contenthash, description, name, url, twitter, email, instagram, discord, github, snapchat, telegram, reddit] = - await Promise.all([ - publicResolver.text(hashName, 'avatar'), - resolver.getContentHash(ensName), - publicResolver.text(hashName, 'description'), - publicResolver.text(hashName, 'name'), - publicResolver.text(hashName, 'url'), - publicResolver.text(hashName, 'com.twitter'), - publicResolver.text(hashName, 'email'), - publicResolver.text(hashName, 'com.instagram'), - publicResolver.text(hashName, 'com.discord'), - publicResolver.text(hashName, 'com.github'), - publicResolver.text(hashName, 'com.snapchat'), - publicResolver.text(hashName, 'org.telegram'), - publicResolver.text(hashName, 'com.reddit'), - ]); - return { - avatar, - contenthash, - description, - discord, - email, - github, - instagram, - name, - reddit, - snapchat, - telegram, - twitter, - url, - }; -}; - -const resolveName = async ensName => { - const provider = Helpers.getProvider(); - const address = await provider.resolveName(ensName); - const primaryName = await provider.lookupAddress(address); - return { address, primaryName }; -}; - -const validatePrimaryName = async name => { - const { address: rainbowAddress, primaryName: rainbowPrimaryName } = await resolveName(RAINBOW_TEST_WALLET_NAME); - const { address: randomAddress, primaryName: randomPrimaryName } = await resolveName(RANDOM_NAME_ETH); - - if (rainbowAddress !== randomAddress || rainbowAddress !== RAINBOW_TEST_WALLET_ADDRESS || randomAddress !== RAINBOW_TEST_WALLET_ADDRESS) - throw new Error('Resolved address is wrong'); - - if (rainbowPrimaryName !== randomPrimaryName || rainbowPrimaryName !== name || randomPrimaryName !== name) - throw new Error('Resolved name is wrong'); -}; - -beforeAll(async () => { - await Helpers.startHardhat(); - await Helpers.startIosSimulator(); -}); - -describe.skip('Register ENS Flow', () => { - it('Should show the welcome screen', async () => { - await Helpers.checkIfVisible('welcome-screen'); - }); - - it('Should show the "Add Wallet Sheet" after tapping on "I already have a wallet"', async () => { - await Helpers.waitAndTap('already-have-wallet-button'); - await Helpers.checkIfExists('add-wallet-sheet'); - }); - - it('show the "Import Sheet" when tapping on "Restore with a recovery phrase or private key"', async () => { - await Helpers.waitAndTap('restore-with-key-button'); - await Helpers.checkIfExists('import-sheet'); - }); - - it('Should show the "Add wallet modal" after tapping import with a valid seed"', async () => { - await Helpers.clearField('import-sheet-input'); - await Helpers.typeText('import-sheet-input', process.env.TEST_SEEDS, false); - await Helpers.checkIfElementHasString('import-sheet-button-label', 'Continue'); - await Helpers.waitAndTap('import-sheet-button'); - await Helpers.checkIfVisible('wallet-info-modal'); - }); - - it('Should navigate to the Wallet screen after tapping on "Import Wallet"', async () => { - await Helpers.disableSynchronization(); - await Helpers.waitAndTap('wallet-info-submit-button'); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - // Set the pin - await Helpers.authenticatePin('1234'); - // Confirm it - await Helpers.authenticatePin('1234'); - } - await Helpers.checkIfVisible('wallet-screen', 80000); - await Helpers.enableSynchronization(); - }); - - it('Should send ETH to test wallet"', async () => { - await Helpers.sendETHtoTestWallet(); - }); - - it('Should show Hardhat Toast after pressing Connect To Hardhat', async () => { - await Helpers.waitAndTap('dev-button-hardhat'); - await Helpers.checkIfVisible('testnet-toast-Hardhat'); - }); - - it('Should navigate to the Discover sheet screen after swiping left', async () => { - await Helpers.swipe('wallet-screen', 'left', 'slow'); - await Helpers.checkIfVisible('discover-header'); - }); - - it('Should go to ENS search screen by pressing the ENS search banner', async () => { - await Helpers.waitAndTap('ens-register-name-banner'); - await Helpers.checkIfVisible('ens-search-input'); - await Helpers.swipe('ens-search-sheet', 'down'); - }); - - it('Should go to ENS flow pressing the ENS banner', async () => { - device.getPlatform() === 'android' && (await Helpers.delay(2000)); - await Helpers.swipe('discover-sheet', 'up', 'slow', 0.2); - await Helpers.waitAndTap('ens-create-profile-card'); - await Helpers.checkIfVisible('ens-intro-sheet'); - }); - - it('Should be able to press a profile and continue to the ENS search screen', async () => { - await Helpers.waitAndTap('ens-intro-sheet-search-new-name-button-action-button'); - }); - - it('Should be able to type a name that is not available', async () => { - await Helpers.checkIfVisible('ens-search-input'); - await Helpers.typeText('ens-search-input', 'rainbowwallet', false); - await Helpers.waitAndTap('ens-search-clear-button'); - }); - - it('Should be able to type a name that has special characters', async () => { - await Helpers.checkIfVisible('ens-search-input'); - await Helpers.typeText('ens-search-input', '/invalidname', false); - await Helpers.waitAndTap('ens-search-clear-button'); - await Helpers.typeText('ens-search-input', '&&&ivalidname', false); - await Helpers.waitAndTap('ens-search-clear-button'); - await Helpers.typeText('ens-search-input', '/invalidname/', false); - await Helpers.waitAndTap('ens-search-clear-button'); - }); - - it('Should be able to type a name that is available and wait for fees', async () => { - await Helpers.checkIfVisible('ens-search-input'); - await Helpers.typeText('ens-search-input', RANDOM_NAME, false); - }); - - it('Should be able to see network fees and name rent price', async () => { - await Helpers.checkIfVisible('ens-search-input'); - await Helpers.checkIfVisible('ens-registration-fees'); - await Helpers.checkIfVisible('ens-registration-price'); - }); - - // FIXME: This is the problem with a review button being tapped but detox not - // registering the action and timing out and leaving the state of the app in - // a place where all following tests are failing. - it('Should go to view to set records', async () => { - await Helpers.checkIfVisible('ens-search-continue-action-button'); - await Helpers.waitAndTap('ens-search-continue-action-button'); - await Helpers.checkIfVisible('ens-text-record-name'); - if (android) { - await Helpers.waitAndTap('ens-text-record-name'); - await Helpers.tapByText('Got it'); - } - await Helpers.typeText('ens-text-record-name', RECORD_NAME, false); - if (ios) { - await Helpers.tapByText('Got it'); - } - await Helpers.checkIfVisible('ens-text-record-description'); - await Helpers.typeText('ens-text-record-description', RECORD_BIO, false); - await Helpers.clearField('ens-text-record-name'); - await Helpers.waitAndTap('use-select-image-avatar'); - await Helpers.tapByText('CryptoKitties'); - await Helpers.tapByText('Arun Cattybinky'); - await Helpers.checkIfVisible('ens-assign-records-review-action-button'); - await Helpers.delay(2000); - await Helpers.waitAndTap('ens-assign-records-review-action-button'); - }); - - it('Should display change gas to Urgent', async () => { - await Helpers.waitAndTap('gas-speed-custom'); - await Helpers.waitAndTap('speed-pill-urgent'); - await Helpers.waitAndTap('gas-speed-done-button'); - }); - - it('Should go to review registration and start it', async () => { - await Helpers.delay(2000); - await Helpers.checkIfVisible(`ens-transaction-action-COMMIT`); - if (ios) { - await Helpers.waitAndTap(`ens-transaction-action-COMMIT`); - } else { - await Helpers.tapAndLongPress('ens-transaction-action-COMMIT'); - } - await Helpers.delay(3000); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - await Helpers.delay(2000); - if (ios) { - await Helpers.checkIfVisible(`ens-confirm-register-label-WAIT_ENS_COMMITMENT`); - } - await Helpers.delay(65000); - }); - - it('Should see confirm registration screen', async () => { - await Helpers.checkIfVisible(`ens-transaction-action-REGISTER`); - if (ios) { - await Helpers.waitAndTap(`ens-transaction-action-REGISTER`); - } else { - await Helpers.tapAndLongPress('ens-transaction-action-REGISTER'); - await Helpers.delay(2000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - }); - - if (ios) { - // TODO - it('Should confirm that the name is not available anymore', async () => { - const ensAvailable = await nameIsAvailable(RANDOM_NAME); - if (ensAvailable) throw new Error('ENS name is available'); - }); - - it('Should confirm that the bio record is set', async () => { - const { description, name, avatar } = await getRecords(RANDOM_NAME_ETH); - if (description !== RECORD_BIO) throw new Error('ENS description is wrong'); - if (name === RECORD_NAME) throw new Error('ENS name is wrong'); - if (typeof avatar === 'string' && avatar.toLowerCase() !== EIP155_FORMATTED_AVATAR_RECORD) throw new Error('ENS avatar is wrong'); - }); - - it('Should confirm RANDOM_NAME is primary name', async () => { - await validatePrimaryName(RANDOM_NAME_ETH); - }); - } - - it('Should check new wallet name is the new ENS on profile screen and change wallet screen', async () => { - await Helpers.swipe('profile-screen', 'left', 'slow'); - await Helpers.checkIfVisible('wallet-screen'); - await Helpers.checkIfExists(`profile-name-${RANDOM_NAME_ETH}`); - await Helpers.tap(`profile-name-${RANDOM_NAME_ETH}`); - await Helpers.checkIfVisible(`change-wallet-address-row-label-${RANDOM_NAME_ETH}`); - await Helpers.swipe('change-wallet-sheet-title', 'down', 'fast'); - await Helpers.swipe('wallet-screen', 'right', 'slow'); - await Helpers.tapAtPoint('profile-screen', { x: 210, y: 185 }); - await Helpers.checkIfVisible(`change-wallet-address-row-label-${RANDOM_NAME_ETH}`); - await Helpers.swipe('change-wallet-sheet-title', 'down', 'fast'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it('Should open ENS rainbowtestwallet.eth', async () => { - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.tapByText('CryptoKitties'); - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.waitAndTap('token-family-header-ENS'); - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.waitAndTap('wrapped-nft-rainbowtestwallet.eth'); - }); - - it('Should be able to navigate to the Edit screen', async () => { - await Helpers.waitAndTap('edit-action-button'); - await Helpers.checkIfVisible('ens-assign-records-sheet'); - await Helpers.swipe('ens-assign-records-sheet', 'down'); - }); - - it('Should use rainbowtestwallet.eth as primary name', async () => { - await Helpers.delay(2000); - await Helpers.swipe('unique-mainnet-expanded-state', 'up', 'slow'); - await Helpers.waitAndTap('ens-reverse-record-switch'); - await Helpers.checkIfVisible(`ens-transaction-action-SET_NAME`); - if (ios) { - await Helpers.waitAndTap(`ens-transaction-action-SET_NAME`); - } else { - await Helpers.tapAndLongPress('ens-transaction-action-SET_NAME'); - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - }); - - it('Should confirm rainbowtestwallet.eth is primary name', async () => { - await validatePrimaryName(RAINBOW_TEST_WALLET_NAME); - }); - - it('Should check wallet name is the new ENS set as primary on profile screen and change wallet screen', async () => { - await Helpers.swipe('profile-screen', 'left', 'slow'); - await Helpers.checkIfVisible('wallet-screen'); - await Helpers.checkIfExists(`profile-name-${RAINBOW_TEST_WALLET_NAME}`); - await Helpers.swipe('wallet-screen', 'right', 'slow'); - await Helpers.tapAtPoint('profile-screen', { x: 210, y: 185 }); - await Helpers.checkIfVisible(`change-wallet-address-row-label-${RAINBOW_TEST_WALLET_NAME}`); - await Helpers.swipe('change-wallet-sheet-title', 'down', 'fast'); - }); - - it('Should open the View Profile Sheet after tapping "View Profile"', async () => { - await Helpers.tapAtPoint('profile-screen', WALLET_AVATAR_COORDS); - await Helpers.checkIfExistsByText('View Profile'); - await Helpers.tapByText('View Profile'); - await Helpers.checkIfExists('profile-sheet'); - await Helpers.delay(2000); - await Helpers.checkIfExistsByText('rainbowtestwallet.eth'); - await Helpers.checkIfExistsByText('Test 2'); - await Helpers.swipe('profile-sheet', 'down'); - await Helpers.delay(1000); - }); - - it('Should open the Edit Profile Sheet after tapping "Edit Profile"', async () => { - await Helpers.tapAtPoint('profile-screen', WALLET_AVATAR_COORDS); - await Helpers.checkIfExistsByText('Edit Profile'); - await Helpers.tapByText('Edit Profile'); - await Helpers.checkIfExists('ens-edit-records-sheet'); - await Helpers.checkIfExistsByText('rainbowtestwallet.eth'); - await Helpers.checkIfExistsByText('Name'); - await Helpers.checkIfExistsByText('Bio'); - }); - - it('Should select ENS attributes in the Edit Profile Sheet', async () => { - // Select all the attributes - await Helpers.waitAndTap('ens-selectable-attribute-website'); - await Helpers.waitAndTap('ens-selectable-attribute-twitter'); - await Helpers.waitAndTap('ens-selectable-attribute-email'); - await Helpers.waitAndTap('ens-selectable-attribute-instagram'); - await Helpers.waitAndTap('ens-selectable-attribute-discord'); - await Helpers.waitAndTap('ens-selectable-attribute-github'); - await Helpers.waitAndTap('ens-selectable-attribute-btc'); - await Helpers.waitAndTap('ens-selectable-attribute-dots'); - await Helpers.waitAndTap('ens-selectable-attribute-snapchat'); - await Helpers.waitAndTap('ens-selectable-attribute-telegram'); - await Helpers.waitAndTap('ens-selectable-attribute-reddit'); - await Helpers.waitAndTap('ens-selectable-attribute-pronouns'); - await Helpers.waitAndTap('ens-selectable-attribute-notice'); - await Helpers.waitAndTap('ens-selectable-attribute-keywords'); - await Helpers.waitAndTap('ens-selectable-attribute-ltc'); - await Helpers.waitAndTap('ens-selectable-attribute-doge'); - await Helpers.waitAndTap('ens-selectable-attribute-contenthash'); - - // Dismiss the bottom attribute sheet - await Helpers.swipe('ens-additional-records-sheet', 'down'); - }); - - it('Should fill & validate the fields', async () => { - await Helpers.delay(2000); - // Fill "Website" field - await Helpers.checkIfVisible('ens-text-record-url'); - await Helpers.typeText('ens-text-record-url', 'abc', false); - await Helpers.waitAndTap('ens-text-record-url-error'); - await Helpers.checkIfElementByTextToExist('Invalid URL'); - await Helpers.tapByText('OK'); - await Helpers.typeText('ens-text-record-url', '123.com', false); - await Helpers.delay(1000); - await Helpers.checkIfNotVisible('ens-text-record-url-error'); - - // Fill "Twitter" field - await Helpers.typeText('ens-text-record-com.twitter', RECORD_TWITTER, false); - - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.15); - - // Fill "Email" field - await Helpers.typeText('ens-text-record-email', RECORD_EMAIL.slice(0, 3), false); - await Helpers.waitAndTap('ens-text-record-email-error'); - await Helpers.checkIfElementByTextToExist('Invalid email'); - await Helpers.tapByText('OK'); - await Helpers.typeText('ens-text-record-email', RECORD_EMAIL.slice(3), false); - await Helpers.delay(1000); - await Helpers.checkIfNotVisible('ens-text-record-email-error'); - - if (android) { - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.15, ios ? 0.15 : 0.3); - } - // Fill "Instagram" field - await Helpers.typeText('ens-text-record-com.instagram', RECORD_INSTAGRAM, false); - - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.15, ios ? 0.15 : 0.3); - - // Fill "Discord" field - await Helpers.typeText('ens-text-record-com.discord', RECORD_DISCORD.slice(0, 3), false); - await Helpers.waitAndTap('ens-text-record-com.discord-error'); - await Helpers.checkIfElementByTextToExist('Invalid Discord username'); - await Helpers.tapByText('OK'); - await Helpers.typeText('ens-text-record-com.discord', RECORD_DISCORD.slice(3), false); - await Helpers.delay(1000); - await Helpers.checkIfNotVisible('ens-text-record-com.discord-error'); - - // Fill "GitHub" field - await Helpers.typeText('ens-text-record-com.github', RECORD_GITHUB, false); - - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.15, ios ? undefined : 0.3); - }); - - it('Should fill & validate the fields 2', async () => { - // Fill "Bitcoin" field - await Helpers.typeText('ens-text-record-BTC', '1F1', false); - await Helpers.waitAndTap('ens-text-record-BTC-error'); - await Helpers.checkIfElementByTextToExist('Invalid BTC address'); - await Helpers.tapByText('OK'); - await Helpers.typeText('ens-text-record-BTC', 'tAaz5x1HUXrCNLbtMDqcw6o5GNn4xqX', false); - await Helpers.delay(3000); - await Helpers.checkIfNotVisible('ens-text-record-BTC-error'); - }); - - it('Should fill & validate the fields 3', async () => { - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.15, ios ? undefined : 0.3); - - // Fill "Snapchat" field - await Helpers.typeText('ens-text-record-com.snapchat', RECORD_SNAPCHAT, false); - - if (!ios) { - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.3, 0.3); - } - - // Fill "Telegram" field - await Helpers.typeText('ens-text-record-org.telegram', RECORD_TELEGRAM, false); - - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.15, ios ? undefined : 0.3); - - // Fill "Reddit" field - await Helpers.typeText('ens-text-record-com.reddit', RECORD_REDDIT, false); - - // Fill "Pronouns" field - await Helpers.typeText('ens-text-record-pronouns', RECORD_PRONOUNS, false); - - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.15, ios ? undefined : 0.3); - - // Fill "Notice" field - await Helpers.typeText('ens-text-record-notice', RECORD_NOTICE, false); - - // Fill "Keywords" field - await Helpers.typeText('ens-text-record-keywords', RECORD_KEYWORDS, false); - - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.15, ios ? undefined : 0.3); - await Helpers.swipe('ens-edit-records-sheet', 'up', 'slow', 0.15, ios ? undefined : 0.3); - }); - - it('Should fill & validate the fields 4', async () => { - // Fill "Litecoin" field - await Helpers.typeText('ens-text-record-LTC', 'MGx', false); - await Helpers.waitAndTap('ens-text-record-LTC-error'); - await Helpers.checkIfElementByTextToExist('Invalid LTC address'); - await Helpers.tapByText('OK'); - await Helpers.typeText('ens-text-record-LTC', 'NPPB7eBoWPUaprtX9v9CXJZoD2465zN', false); - await Helpers.delay(3000); - await Helpers.checkIfNotVisible('ens-text-record-LTC-error'); - - // Fill "Content" field - await Helpers.typeText('ens-text-record-contenthash', RECORD_CONTENTHASH.slice(0, 3), false); - await Helpers.waitAndTap('ens-text-record-contenthash-error'); - await Helpers.checkIfElementByTextToExist('Invalid content hash'); - await Helpers.tapByText('OK'); - await Helpers.typeText('ens-text-record-contenthash', RECORD_CONTENTHASH.slice(3), false); - await Helpers.delay(3000); - await Helpers.checkIfNotVisible('ens-text-record-contenthash-error'); - }); - - it('Should unselect a field', async () => { - await Helpers.swipe('ens-edit-records-sheet', 'down'); - await Helpers.waitAndTap('hide-keyboard-button'); - await Helpers.waitAndTap('ens-selectable-attribute-bio'); - await Helpers.checkIfNotVisible('ens-text-record-description'); - }); - - it('Should update a field', async () => { - await Helpers.typeText('ens-text-record-name', ' Guy', false); - await Helpers.waitAndTap('hide-keyboard-button'); - }); - - it('Should submit updated fields', async () => { - await Helpers.checkIfVisible('ens-assign-records-review-action-button'); - await Helpers.waitAndTap('ens-assign-records-review-action-button'); - await Helpers.checkIfVisible(`ens-transaction-action-EDIT`); - if (ios) { - await Helpers.waitAndTap(`ens-transaction-action-EDIT`); - } else { - await Helpers.tapAndLongPress('ens-transaction-action-EDIT'); - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - }); - - if (ios) { - // TODO - it('Should confirm the update was successful', async () => { - const { contenthash, description, discord, email, github, instagram, reddit, snapchat, telegram, twitter, url } = - await getRecords(RAINBOW_TEST_WALLET_NAME); - if (description) throw new Error('description should be empty'); - if (discord !== RECORD_DISCORD) throw new Error('discord is incorrect.', discord); - if (email !== RECORD_EMAIL) throw new Error('email is incorrect.', email); - if (github !== RECORD_GITHUB) throw new Error('github is incorrect.', github); - if (instagram !== RECORD_INSTAGRAM) throw new Error('instagram is incorrect.', instagram); - if (reddit !== RECORD_REDDIT) throw new Error('reddit is incorrect.', reddit); - if (snapchat !== RECORD_SNAPCHAT) throw new Error('snapchat is incorrect.', snapchat); - if (telegram !== RECORD_TELEGRAM) throw new Error('telegram is incorrect.', telegram); - if (twitter !== RECORD_TWITTER) throw new Error('twitter is incorrect.', twitter); - if (url !== RECORD_URL) throw new Error('url is incorrect.', url); - if (contenthash !== RECORD_CONTENTHASH) throw new Error('contenthash is incorrect.', contenthash); - }); - } - - it('Should navigate to the Wallet screen to renew', async () => { - await Helpers.swipe('profile-screen', 'left', 'slow'); - await Helpers.checkIfVisible('wallet-screen'); - }); - - it('Should open ENS rainbowtestwallet.eth to renew', async () => { - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.waitAndTap('wrapped-nft-rainbowtestwallet.eth'); - }); - - it('Should renew rainbowtestwallet.eth', async () => { - await Helpers.waitAndTap('unique-mainnet-expanded-state-extend-duration'); - await Helpers.checkIfVisible(`ens-transaction-action-RENEW`); - if (ios) { - await Helpers.waitAndTap(`ens-transaction-action-RENEW`); - } else { - await Helpers.tapAndLongPress('ens-transaction-action-RENEW'); - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - }); - - it('Should navigate to the Wallet screen to send ENS from renew tx', async () => { - await Helpers.swipe('profile-screen', 'left', 'slow'); - await Helpers.checkIfVisible('wallet-screen'); - }); - - it('Should open ENS rainbowtestwallet.eth to send ENS', async () => { - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.tapByText('CryptoKitties'); - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.swipe('wallet-screen', 'up', 'slow'); - await Helpers.waitAndTap('wrapped-nft-rainbowtestwallet.eth'); - await Helpers.waitAndTap('send-action-button'); - }); - - it('Should go to review send ENS', async () => { - await Helpers.typeText('send-asset-form-field', 'rainbowwallet.eth\n'); - await Helpers.waitAndTap('gas-speed-custom'); - await Helpers.waitAndTap('speed-pill-urgent'); - await Helpers.waitAndTap('gas-speed-done-button'); - await Helpers.waitAndTap('send-sheet-confirm-action-button'); - }); - - it('Should press all ENS options', async () => { - await Helpers.waitAndTap('clear-records'); - await Helpers.waitAndTap('set-address'); - await Helpers.waitAndTap('transfer-control'); - if (ios) { - await Helpers.waitAndTap(`send-confirmation-button`); - } else { - await Helpers.tapAndLongPress('send-confirmation-button'); - await Helpers.delay(1000); - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - } - }); - - it.skip('Should confirm the ENS was sent correctly', async () => { - await Helpers.delay(1000); - const { name } = await getRecords(RAINBOW_TEST_WALLET_NAME); - const { address, primaryName } = await resolveName(RAINBOW_TEST_WALLET_NAME); - const owner = await getNameOwner(RAINBOW_TEST_WALLET_NAME); - if (address !== RAINBOW_WALLET_ADDRESS) throw new Error('Resolved address is wrong'); - if (primaryName !== RAINBOW_WALLET_NAME) throw new Error('Resolved primary name is wrong'); - if (name) throw new Error('name is wrong'); - if (owner !== RAINBOW_WALLET_ADDRESS) throw new Error('Owner not set correctly'); - }); - - it.skip('Should check address is the new label on profile screen and change wallet screen', async () => { - const TRUNCATED_ADDRESS = address(RAINBOW_TEST_WALLET_ADDRESS, 4, 4); - const WALLET_ROW_TRUNCATED_ADDRESS = address(RAINBOW_TEST_WALLET_ADDRESS, 6, 4); - await Helpers.swipe('profile-screen', 'left', 'slow'); - await Helpers.checkIfVisible('wallet-screen'); - await Helpers.checkIfExists(`profile-name-sticky-${TRUNCATED_ADDRESS}`); - await Helpers.waitAndTap(`profile-name-sticky-${TRUNCATED_ADDRESS}`); - await Helpers.checkIfVisible(`change-wallet-address-row-label-${WALLET_ROW_TRUNCATED_ADDRESS}`); - }); - - afterAll(async () => { - // Reset the app state - await device.clearKeychain(); - await Helpers.killHardhat(); - }); -}); diff --git a/e2e/Disabled/sendSheetFlow.disabled.ts b/e2e/Disabled/sendSheetFlow.disabled.ts deleted file mode 100644 index 93b50f7091a..00000000000 --- a/e2e/Disabled/sendSheetFlow.disabled.ts +++ /dev/null @@ -1,159 +0,0 @@ -import { device } from 'detox'; -import { - startHardhat, - killHardhat, - importWalletFlow, - sendETHtoTestWallet, - waitAndTap, - checkIfVisible, - checkIfElementByTextIsVisible, - typeText, - checkIfNotVisible, - clearField, - replaceTextInField, -} from '../helpers'; - -describe.skip('Send Sheet Interaction Flow', () => { - beforeAll(async () => { - await device.reloadReactNative(); - await startHardhat(); - }); - afterAll(async () => { - await device.clearKeychain(); - await killHardhat(); - }); - - it('Import a wallet and go to welcome', async () => { - await importWalletFlow(); - }); - - it('Should send ETH to test wallet"', async () => { - await sendETHtoTestWallet(); - }); - - it('Should show Hardhat Toast after pressing Connect To Hardhat', async () => { - await waitAndTap('dev-button-hardhat'); - await checkIfVisible('testnet-toast-Hardhat'); - }); - - it('Should open send sheet after tapping send button', async () => { - await waitAndTap('send-button'); - await checkIfVisible('send-asset-form-field'); - }); - - it('Should do nothing on typing jibberish send address', async () => { - await typeText('send-asset-form-field', 'gvuabefhiwdnomks', false); - await checkIfNotVisible('send-asset-ETH-mainnet'); - }); - - // FIXME: typing in address in sim has a glitch where the asset-list doesn't - // populate - // - // SKIPPING all tests after this one, as the app is in the wrong state - it('Should show show Contact Button & Asset List on valid public address', async () => { - await clearField('send-asset-form-field'); - await checkIfVisible('send-asset-form-field'); - await replaceTextInField('send-asset-form-field', '0xF0f21ab2012731542731df194cfF6c77d29cB31A'); - await checkIfVisible('send-asset-list', 20000); - }); - - it('Should show show Contact Button & Asset List on valid ENS & Unstoppable addresses', async () => { - await clearField('send-asset-form-field'); - await checkIfVisible('send-asset-form-field'); - await typeText('send-asset-form-field', 'neverselling.wallet\n', false); - await checkIfVisible('send-asset-list'); - await clearField('send-asset-form-field'); - await device.disableSynchronization(); - await typeText('send-asset-form-field', 'rainbowwallet.eth\n', false); - await device.enableSynchronization(); - await checkIfVisible('send-asset-list'); - }); - - it('Should display Asset Form after tapping on asset', async () => { - await checkIfVisible('send-asset-DAI-mainnet'); - await waitAndTap('send-asset-DAI-mainnet'); - await checkIfVisible('selected-asset-field-input'); - }); - - it('Should display max button on asset input focus', async () => { - await checkIfVisible('selected-asset-field-input'); - await waitAndTap('selected-asset-field-input'); - await checkIfElementByTextIsVisible('Max'); - }); - - it('Should display max button on asset quantity input focus', async () => { - await checkIfVisible('selected-asset-quantity-field-input'); - await waitAndTap('selected-asset-quantity-field-input'); - await checkIfElementByTextIsVisible('Max'); - }); - - it('Should display Insufficient Funds button if exceeds asset balance', async () => { - await checkIfVisible('selected-asset-field-input'); - await waitAndTap('selected-asset-field-input'); - await typeText('selected-asset-field-input', '9999', false); - await checkIfElementByTextIsVisible('Insufficient Funds'); - }); - - it('Should prepend a 0 to quantity field on input of .', async () => { - await waitAndTap('send-asset-form-DAI-mainnet'); - await waitAndTap('send-asset-DAI-mainnet'); - await checkIfVisible('selected-asset-quantity-field-input'); - await waitAndTap('selected-asset-quantity-field-input'); - await typeText('selected-asset-quantity-field-input', '.', true); - await checkIfElementByTextIsVisible('0.'); - }); - - it('Should only show a max of 2 decimals in quantity field', async () => { - await waitAndTap('send-asset-form-DAI-mainnet'); - await waitAndTap('send-asset-ETH-mainnet'); - await checkIfVisible('selected-asset-quantity-field-input'); - await waitAndTap('selected-asset-quantity-field-input'); - await typeText('selected-asset-quantity-field-input', '8.1219', true); - await checkIfElementByTextIsVisible('8.12'); - await waitAndTap('send-asset-form-ETH-mainnet'); - }); - - it('Should display Asset Form after tapping on asset ETH', async () => { - await checkIfVisible('send-asset-ETH-mainnet'); - await waitAndTap('send-asset-ETH-mainnet'); - await checkIfVisible('selected-asset-field-input'); - }); - - it('Should display max button on asset input focus ETH', async () => { - await checkIfVisible('selected-asset-field-input'); - await waitAndTap('selected-asset-field-input'); - await checkIfElementByTextIsVisible('Max'); - }); - - it('Should display max button on asset quantity input focus ETH', async () => { - await checkIfVisible('selected-asset-quantity-field-input'); - await waitAndTap('selected-asset-quantity-field-input'); - await checkIfElementByTextIsVisible('Max'); - }); - - it('Should display Insufficient Funds button if exceeds asset balance ETH', async () => { - await checkIfVisible('selected-asset-field-input'); - await waitAndTap('selected-asset-field-input'); - await typeText('selected-asset-field-input', '9999', true); - await checkIfElementByTextIsVisible('Insufficient Funds'); - }); - - it('Should prepend a 0 to quantity field on input of . ETH', async () => { - await waitAndTap('send-asset-form-ETH-mainnet'); - await waitAndTap('send-asset-ETH-mainnet'); - await checkIfVisible('selected-asset-quantity-field-input'); - await waitAndTap('selected-asset-quantity-field-input'); - await typeText('selected-asset-quantity-field-input', '.', true); - await checkIfElementByTextIsVisible('0.'); - }); - - it('Should only show a max of 2 decimals in quantity field ETH', async () => { - await waitAndTap('send-asset-form-ETH-mainnet'); - await waitAndTap('send-asset-ETH-mainnet'); - await checkIfVisible('selected-asset-quantity-field-input'); - await waitAndTap('selected-asset-quantity-field-input'); - await typeText('selected-asset-quantity-field-input', '8.1219', true); - await checkIfElementByTextIsVisible('8.12'); - await waitAndTap('send-asset-form-ETH-mainnet'); - }); -}); diff --git a/e2e/Disabled/swapSheetFlow1.disabled.js b/e2e/Disabled/swapSheetFlow1.disabled.js deleted file mode 100644 index afb1aec1841..00000000000 --- a/e2e/Disabled/swapSheetFlow1.disabled.js +++ /dev/null @@ -1,341 +0,0 @@ -import * as Helpers from '../helpers'; -import { device } from 'detox'; - -const ios = device.getPlatform() === 'ios'; -const android = device.getPlatform() === 'android'; - -// all relevant flows skipped at the moment -// removing this test from the flow until we fix - -describe.skip('Swap Sheet Interaction Flow', () => { - beforeAll(async () => { - await Helpers.startHardhat(); - }); - afterAll(async () => { - await device.clearKeychain(); - await Helpers.killHardhat(); - }); - - it('Import a wallet and go to welcome', async () => { - await Helpers.importWalletFlow(); - }); - - it('Should send ETH to test wallet"', async () => { - await Helpers.sendETHtoTestWallet(); - }); - - it('Should show Hardhat Toast after pressing Connect To Hardhat', async () => { - await Helpers.delayTime('very-long'); - await Helpers.waitAndTap('dev-button-hardhat'); - await Helpers.checkIfVisible('testnet-toast-Hardhat'); - }); - - // FIXME: Mainnet DAI doesn't show up in the swap search results - // This might be related to @Jin's latest work on changes to hardhat as - // part of the addy's REST API migration - // - // marking the test as SKIP for now - it('Should go to swap and open review sheet on mainnet swap', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('exchange-modal-input-max'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.delay(ios ? 2000 : 5000); - await Helpers.checkIfVisible('exchange-modal-confirm-button'); - await Helpers.waitAndTap('exchange-modal-confirm-button'); - await Helpers.checkIfVisible('swaps-details-value-row'); - await Helpers.checkIfVisible('swaps-details-fee-row'); - await Helpers.waitAndTap('swaps-details-show-details-button'); - await Helpers.checkIfVisible('swaps-details-price-row'); - await Helpers.swipe(ios ? 'swap-details-sheet' : 'swap-details-header', 'down', 'fast'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - // FIXME: This test doesn't clear the "currency-select-search-input" when - // coming back from exchange modal and then fails to actually tap the review - // button - it('Should go to swap and open review sheet on optimism swap', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.typeText('currency-select-search-input', 'OP', true); - await Helpers.tap('currency-select-list-exchange-coin-row-OP-optimism'); - await Helpers.waitAndTap('exchange-modal-input-max'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.typeText('currency-select-search-input', 'ETH', true); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-optimism'); - await Helpers.delay(ios ? 2000 : 5000); - await Helpers.checkIfVisible('exchange-modal-confirm-button'); - await Helpers.waitAndTap('exchange-modal-confirm-button'); - await Helpers.checkIfVisible('swaps-details-value-row'); - await Helpers.checkIfVisible('swaps-details-fee-row'); - await Helpers.waitAndTap('swaps-details-show-details-button'); - await Helpers.checkIfVisible('swaps-details-price-row'); - await Helpers.swipe(ios ? 'swap-details-sheet' : 'swap-details-header', 'down', 'fast'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - // FIXME: This test doesn't clear the "currency-select-search-input" when - // coming back from exchange modal and then fails to actually tap the review - // button - it('Should go to swap and open review sheet on polygon swap', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-polygon'); - await Helpers.waitAndTap('exchange-modal-input-max'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.typeText('currency-select-search-input', 'WETH', true); - await Helpers.tap('currency-select-list-exchange-coin-row-WETH-polygon'); - await Helpers.delay(ios ? 2000 : 5000); - await Helpers.checkIfVisible('exchange-modal-confirm-button'); - await Helpers.waitAndTap('exchange-modal-confirm-button'); - await Helpers.checkIfVisible('swaps-details-value-row'); - await Helpers.checkIfVisible('swaps-details-fee-row'); - await Helpers.waitAndTap('swaps-details-show-details-button'); - await Helpers.checkIfVisible('swaps-details-price-row'); - await Helpers.swipe(ios ? 'swap-details-sheet' : 'swap-details-header', 'down', 'fast'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - // FIXME: This test doesn't clear the "currency-select-search-input" when - // coming back from exchange modal and then fails to actually tap the review - // button - it('Should go to swap and open review sheet on arbitrum swap', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-arbitrum'); - await Helpers.waitAndTap('exchange-modal-input-max'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.typeText('currency-select-search-input', 'ETH', true); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-arbitrum'); - await Helpers.delay(ios ? 2000 : 5000); - await Helpers.checkIfVisible('exchange-modal-confirm-button'); - await Helpers.waitAndTap('exchange-modal-confirm-button'); - await Helpers.checkIfVisible('swaps-details-value-row'); - await Helpers.checkIfVisible('swaps-details-fee-row'); - await Helpers.waitAndTap('swaps-details-show-details-button'); - await Helpers.checkIfVisible('swaps-details-price-row'); - await Helpers.swipe(ios ? 'swap-details-sheet' : 'swap-details-header', 'down', 'fast'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should display currency selection screen on swap-button press', async () => { - await Helpers.checkIfVisible('wallet-screen'); - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should toggle through token networks and show the respective tokens', async () => { - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.checkIfVisible('network-switcher-1'); - await Helpers.waitAndTap('network-switcher-item-optimism'); - await Helpers.checkIfVisible('network-switcher-10'); - await Helpers.waitAndTap('network-switcher-item-arbitrum'); - await Helpers.checkIfVisible('network-switcher-42161'); - await Helpers.waitAndTap('currency-select-header-back-button'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.checkIfVisible('network-switcher-1'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should update input value after tapping Max Button', async () => { - await Helpers.typeText('currency-select-search-input', 'BAT', true); - await Helpers.tap('currency-select-list-exchange-coin-row-BAT-mainnet'); - await Helpers.delay(ios ? 2000 : 5000); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.waitAndTap('exchange-modal-input-max'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should display Swap Asset List after tapping Input Section Button', async () => { - await Helpers.waitAndTap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - if (android) { - await device.pressBack(); - await device.pressBack(); - } else { - await Helpers.waitAndTap('currency-select-header-back-button'); - } - }); - - // FIXME: Dependent on a state from the previous test - it('Should reset all fields on selection of new input currency', async () => { - await Helpers.waitAndTap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should change Currency Select List on search entry', async () => { - await Helpers.waitAndTap('exchange-modal-input-selection-button'); - await Helpers.typeText('currency-select-search-input', 'SOCKS\n', true); - await Helpers.checkIfNotVisible('currency-select-list-exchange-coin-row-ETH-mainnet'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should reset Currency Select List on clearing search field', async () => { - await Helpers.clearField('currency-select-search-input'); - await Helpers.checkIfVisible('currency-select-list-exchange-coin-row-ETH-mainnet'); - if (android) { - await device.pressBack(); - await device.pressBack(); - } else { - await Helpers.waitAndTap('currency-select-header-back-button'); - } - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should show Choose Token Button if input & output are same token(ETH)', async () => { - if (!ios) { - // TODO - return; - } - await Helpers.waitAndTap('balance-coin-row-Ethereum'); - await Helpers.waitAndTap('swap-action-button'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.checkIfElementHasString('exchange-modal-input-selection-button-text', 'Choose Token'); - await Helpers.tap('exchange-modal-output-selection-button'); - if (android) { - await device.pressBack(); - } else { - await Helpers.waitAndTap('currency-select-header-back-button'); - } - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should clear inputs when typing a number in inputs and then clearing it', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI\n', true); - await Helpers.checkIfVisible('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - - await Helpers.checkIfElementHasString('exchange-modal-input-selection-button-text', 'DAI'); - await Helpers.checkIfElementHasString('exchange-modal-output-selection-button-text', 'ETH'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.typeText('exchange-modal-input', '24', true); - await Helpers.clearField('exchange-modal-input-24'); - await Helpers.checkIfVisible('exchange-modal-output'); - await Helpers.typeText('exchange-modal-output', '24', true); - await Helpers.clearField('exchange-modal-output-24'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.typeText('exchange-modal-input-native', '24', true); - await Helpers.clearField('exchange-modal-input-native-24'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.checkIfVisible('exchange-modal-output'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should clear inputs when typing a number in inputs and then clearing it optimism', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'ETH\n', true); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-optimism'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('network-switcher-10'); - await Helpers.tap('currency-select-list-exchange-coin-row-OP-optimism'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.typeText('exchange-modal-input', '24', false); - await Helpers.clearField('exchange-modal-input-24'); - await Helpers.checkIfVisible('exchange-modal-output'); - await Helpers.typeText('exchange-modal-output', '24', false); - await Helpers.clearField('exchange-modal-output-24'); - await Helpers.checkIfVisible('exchange-modal-input'); - if (ios) { - await Helpers.checkForElementByLabel('Enter an Amount'); - } - await Helpers.typeText('exchange-modal-input-native', '24', false); - await Helpers.clearField('exchange-modal-input-native-24'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.checkIfVisible('exchange-modal-output'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should show settings routes picker but not flashbots on Optimism', async () => { - await Helpers.waitAndTap('exchange-settings-button'); - await Helpers.checkIfVisible('swap-settings-header'); - await Helpers.checkIfVisible('swap-settings-routes-label'); - await Helpers.checkIfNotVisible('swap-settings-flashbots-label'); - await Helpers.swipe('swap-settings-header', 'down', 'fast'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should clear inputs when typing a number in inputs and then clearing it arbitrum', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'ETH\n', true); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-arbitrum'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('network-switcher-42161'); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-arbitrum'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.typeText('exchange-modal-input', '24\n', false); - await Helpers.clearField('exchange-modal-input-24'); - await Helpers.checkIfVisible('exchange-modal-output'); - await Helpers.typeText('exchange-modal-input-native', '24\n', false); - await Helpers.clearField('exchange-modal-input-native-24'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.checkIfVisible('exchange-modal-output'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should clear inputs when typing a number in inputs and then clearing it polygon', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'WETH', true); - await Helpers.tap('currency-select-list-exchange-coin-row-WETH-polygon'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('network-switcher-137'); - await Helpers.tap('currency-select-list-exchange-coin-row-MATIC-polygon'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.typeText('exchange-modal-input', '24', false); - await Helpers.clearField('exchange-modal-input-24'); - await Helpers.checkIfVisible('exchange-modal-output'); - await Helpers.typeText('exchange-modal-output', '24', false); - await Helpers.clearField('exchange-modal-output-24'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.typeText('exchange-modal-input-native', '24', false); - await Helpers.clearField('exchange-modal-input-native-24'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.checkIfVisible('exchange-modal-output'); - }); - - // FIXME: Dependent on a state from the previous test - it('Should show settings routes picker but notflashbots on Polygon', async () => { - await Helpers.waitAndTap('exchange-settings-button'); - await Helpers.checkIfVisible('swap-settings-header'); - await Helpers.checkIfVisible('swap-settings-routes-label'); - await Helpers.checkIfNotVisible('swap-settings-flashbots-label'); - await Helpers.swipe('swap-settings-header', 'down', 'fast'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); -}); diff --git a/e2e/Disabled/swapSheetFlow2.disabled.js b/e2e/Disabled/swapSheetFlow2.disabled.js deleted file mode 100644 index 0a86a585faa..00000000000 --- a/e2e/Disabled/swapSheetFlow2.disabled.js +++ /dev/null @@ -1,479 +0,0 @@ -import * as Helpers from '../helpers'; -import { device } from 'detox'; - -beforeAll(async () => { - await Helpers.startHardhat(); -}); - -const ios = device.getPlatform() === 'ios'; -const android = device.getPlatform() === 'android'; - -// FIXME: Mainnet DAI doesn't show up in the swap search results -// This might be related to @Jin's latest work on changes to hardhat as -// part of the addy's REST API migration -// -// marking the test as SKIP for now -describe.skip('Swap Sheet Interaction Flow', () => { - it('Should show the welcome screen', async () => { - await Helpers.checkIfVisible('welcome-screen'); - }); - - it('Should show the "Add Wallet Sheet" after tapping on "I already have a wallet"', async () => { - await Helpers.waitAndTap('already-have-wallet-button'); - await Helpers.checkIfExists('add-wallet-sheet'); - }); - - it('show the "Import Sheet" when tapping on "Restore with a recovery phrase or private key"', async () => { - await Helpers.waitAndTap('restore-with-key-button'); - await Helpers.checkIfExists('import-sheet'); - }); - - it('Should show the "Add wallet modal" after tapping import with a valid seed"', async () => { - await Helpers.clearField('import-sheet-input'); - await Helpers.typeText('import-sheet-input', process.env.TEST_SEEDS, false); - await Helpers.checkIfElementHasString('import-sheet-button-label', 'Continue'); - await Helpers.waitAndTap('import-sheet-button'); - await Helpers.checkIfVisible('wallet-info-modal'); - }); - - it('Should navigate to the Wallet screen after tapping on "Import Wallet"', async () => { - await Helpers.disableSynchronization(); - await Helpers.waitAndTap('wallet-info-submit-button'); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - // Set the pin - await Helpers.authenticatePin('1234'); - // Confirm it - await Helpers.authenticatePin('1234'); - } - await Helpers.checkIfVisible('wallet-screen', 40000); - await Helpers.enableSynchronization(); - }); - - it('Should send ETH to test wallet"', async () => { - await Helpers.sendETHtoTestWallet(); - }); - - it('Should show Hardhat Toast after pressing Connect To Hardhat', async () => { - // need to wait for balances to be fetched - await Helpers.delay(10000); - await Helpers.waitAndTap('dev-button-hardhat'); - await Helpers.checkIfVisible('testnet-toast-Hardhat'); - }); - - it('Should connect to hardhat', async () => { - await Helpers.swipe('wallet-screen', 'right', 'slow'); - await Helpers.checkIfVisible('profile-screen'); - await Helpers.waitAndTap('settings-button'); - await Helpers.checkIfVisible('settings-sheet'); - await Helpers.scrollTo('settings-menu-container', 'bottom'); - await Helpers.waitAndTap('developer-section'); - await Helpers.swipeUntilVisible('alert-section', 'developer-settings-sheet', 'up'); - await Helpers.waitAndTap('hardhat-section'); - await Helpers.checkIfVisible('testnet-toast-Hardhat'); - await Helpers.swipe('profile-screen', 'left', 'slow'); - }); - - it('Should go to swap and try different cross chain swaps', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('exchange-modal-input-max'); - await Helpers.checkIfVisible(`exchange-modal-input-DAI-mainnet`); - await Helpers.checkIfVisible(`exchange-modal-output-empty-empty`); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.tap('network-switcher-item-optimism'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-optimism'); - await Helpers.checkIfVisible(`exchange-modal-input-DAI-mainnet`); - await Helpers.checkIfVisible(`exchange-modal-output-DAI-optimism`); - - await Helpers.swipe('exchange-modal-notch', 'down', 'slow'); - }); - - it('Should show explainer sheet when selecting output input for cross chain swaps', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.typeText('currency-select-search-input', 'DAI', true); - await Helpers.tap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('exchange-modal-input-max'); - await Helpers.checkIfVisible(`exchange-modal-input-DAI-mainnet`); - await Helpers.checkIfVisible(`exchange-modal-output-empty-empty`); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.tap('network-switcher-item-optimism'); - await Helpers.typeText('currency-select-search-input', 'USDC', true); - await Helpers.tap('currency-select-list-exchange-coin-row-USDC-optimism'); - await Helpers.checkIfVisible(`exchange-modal-input-DAI-mainnet`); - await Helpers.checkIfVisible(`exchange-modal-output-USDC-optimism`); - await Helpers.waitAndTap('exchange-modal-output-USDC-optimism'); - await Helpers.waitAndTap('explainer-sheet-accent-action-button'); - await Helpers.tapAndLongPress('exchange-modal-confirm-button'); - await Helpers.checkIfVisible('swaps-details-value-row'); - await Helpers.checkIfNotVisible('swaps-details-refuel-row'); - await Helpers.waitAndTap('swaps-details-protocols-row'); - await Helpers.waitAndTap('swaps-details-protocols-row'); - await Helpers.checkIfVisible('swaps-details-fee-row'); - await Helpers.swipe('swap-details-header', 'down', 'slow'); - await Helpers.swipe('exchange-modal-notch', 'down', 'slow'); - }); - - it('Should swap input & output and clear form on ETH -> ERC20 when selecting ETH as output', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI\n', true); - await Helpers.checkIfVisible('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfElementHasString('exchange-modal-input-selection-button-text', 'DAI'); - await Helpers.checkIfElementHasString('exchange-modal-output-selection-button-text', 'ETH'); - await Helpers.swipe('exchange-modal-notch', 'down', 'slow'); - }); - - it('Should swap input & output and clear form on ETH -> ERC20 when selecting ERC20 as input', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI\n', true); - await Helpers.checkIfVisible('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.checkIfElementHasString('exchange-modal-input-selection-button-text', 'DAI'); - await Helpers.checkIfElementHasString('exchange-modal-output-selection-button-text', 'ETH'); - await Helpers.delay(4000); - }); - - it('Should display Enter an Amount Button once input & output currencies are selected', async () => { - if (ios) { - // TODO - await Helpers.checkForElementByLabel('Enter an Amount'); - } - await Helpers.swipe('exchange-modal-notch', 'down', 'slow'); - }); - - it('Should update native input & output after input field change', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'ZRX\n', false); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-ZRX-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input-native'); - await Helpers.checkIfVisible('exchange-modal-output'); - await Helpers.typeText('exchange-modal-input', '0.246\n', false); - await Helpers.checkIfVisible('exchange-modal-input-0.246'); - await Helpers.checkIfNotVisible('exchange-modal-input-native'); - if (ios) { - // TODO - await Helpers.checkIfNotVisible('exchange-modal-output'); - } - await Helpers.swipe('exchange-modal-notch', 'down', 'slow'); - }); - - it('Should update input & output after native input field change', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'ZRX', false); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-ZRX-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.checkIfVisible('exchange-modal-output'); - await Helpers.typeText('exchange-modal-input-native', '0.246', false); - await Helpers.checkIfVisible('exchange-modal-input-native-0.24'); - if (ios) { - // TODO - await Helpers.checkIfNotVisible('exchange-modal-input'); - await Helpers.checkIfNotVisible('exchange-modal-output'); - } - await Helpers.swipe('exchange-modal-notch', 'down', 'slow'); - }); - - it('Should update input & output after native input field change and output DAI', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI', false); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.checkIfVisible('exchange-modal-output'); - await Helpers.typeText('exchange-modal-input-native', '246', false); - await Helpers.checkIfVisible('exchange-modal-input-native-246'); - if (ios) { - // TODO - await Helpers.checkIfNotVisible('exchange-modal-input'); - await Helpers.checkIfNotVisible('exchange-modal-output'); - } - }); - - it('Should show Hold to Swap Button & Swap Info Button on completion of all input fields', async () => { - await Helpers.checkIfVisible('exchange-modal-confirm-button'); - await Helpers.checkIfVisible('exchange-settings-button'); - }); - - it('Should show Swap Settings State on Settings Button press', async () => { - await Helpers.waitAndTap('exchange-settings-button'); - await Helpers.checkIfVisible('swap-settings-header'); - }); - - it('Should show and toggle swap routes on Mainnet', async () => { - await Helpers.waitAndTap('swap-settings-routes-label'); - await Helpers.checkIfVisible('explain-sheet-routeSwaps'); - await Helpers.swipe('explain-sheet-routeSwaps', 'down', 'fast'); - await Helpers.waitAndTap('swap-settings-routes-current-rainbow'); - await Helpers.tapByText('0x'); - await Helpers.checkIfVisible('swap-settings-routes-current-0x'); - }); - - // skipping until flashbots is enabled again after the merge - it.skip('Should show and toggle flashbots on Mainnet', async () => { - await Helpers.waitAndTap('swap-settings-flashbots-switch-false'); - await Helpers.checkIfVisible('swap-settings-flashbots-switch-true'); - await Helpers.waitAndTap('swap-settings-flashbots-label'); - // await Helpers.checkIfVisible('explain-sheet-flashbots'); - await Helpers.swipe('explain-sheet-flashbots', 'down', 'fast'); - }); - - it('Should show and update slippage on Mainnet', async () => { - if (ios) { - // TODO - await Helpers.clearField('swap-slippage-input-2'); - await Helpers.typeText('swap-slippage-input-', '10', false); - await Helpers.checkIfVisible('swap-slippage-input-10'); - await Helpers.waitAndTap('swap-slippage-label'); - await Helpers.checkIfVisible('explain-sheet-slippage'); - await Helpers.swipe('explain-sheet-slippage', 'down', 'fast'); - } - }); - - it('Should restore swap setting defaults on Mainnet', async () => { - await Helpers.waitAndTap('swap-settings-defaults-button'); - await Helpers.checkIfVisible('swap-settings-routes-current-rainbow'); - // restore after merge etc. - // await Helpers.checkIfVisible('swap-settings-flashbots-switch-false'); - if (ios) { - // TODO - await Helpers.checkIfVisible('swap-slippage-input-2'); - } - - await Helpers.swipe('swap-settings-header', 'down', 'fast'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - it('Should update input & native input after output field change', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'ZRX', false); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-ZRX-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.checkIfVisible('exchange-modal-input-native'); - await Helpers.typeText('exchange-modal-output', '0.246', false); - await Helpers.checkIfVisible('exchange-modal-output-0.246'); - if (ios) { - // TODO - await Helpers.checkIfNotVisible('exchange-modal-input'); - await Helpers.checkIfNotVisible('exchange-modal-input-native'); - } - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - it('Should show Insufficient Funds on input greater than balance', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'ZRX', false); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-ZRX-mainnet'); - if (ios) { - // TODO - await Helpers.typeText('exchange-modal-input', '500000000000', false); - await Helpers.checkForElementByLabel('Insufficient Funds'); - } - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - it('Should prepend 0. to input field on typing .', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI\n', true); - await Helpers.checkIfVisible('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.typeText('exchange-modal-input', '.', false); - await Helpers.checkIfVisible('exchange-modal-input-0.'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - it('Should prepend 0. to native input field on typing .', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI\n', true); - await Helpers.checkIfVisible('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.typeText('exchange-modal-input-native', '.', false); - await Helpers.checkIfVisible('exchange-modal-input-native-0.'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - it('Should prepend 0. to output field on typing .', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'DAI\n', true); - await Helpers.checkIfVisible('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-DAI-mainnet'); - await Helpers.typeText('exchange-modal-output', '.', false); - await Helpers.checkIfVisible('exchange-modal-output-0.'); - await Helpers.swipe('exchange-modal-notch', 'down', 'fast'); - }); - - it('Should display Gas Button on Fast by default', async () => { - await Helpers.waitAndTap('swap-button'); - await Helpers.tap('exchange-modal-input-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.tap('currency-select-list-exchange-coin-row-ETH-mainnet'); - await Helpers.checkIfVisible('exchange-modal-input'); - await Helpers.tap('exchange-modal-output-selection-button'); - await Helpers.checkIfVisible('currency-select-list'); - await Helpers.typeText('currency-select-search-input', 'ZRX\n', false); - await Helpers.waitAndTap('currency-select-list-exchange-coin-row-ZRX-mainnet'); - await Helpers.checkIfVisible('exchange-modal-gas'); - await Helpers.checkIfElementByTextIsVisible('Fast'); - }); - - it('Should display warning on invalid custom gas price', async () => { - await Helpers.waitAndTap('gas-speed-custom'); - await Helpers.checkIfVisible('speed-pill-fast'); - await Helpers.checkIfVisible('speed-pill-custom'); - await Helpers.clearField('max-base-fee-input'); - await Helpers.typeText('max-base-fee-input', '\n', false); - if (ios) { - // TODO - await Helpers.checkIfElementByTextIsVisible('Low · likely to fail'); - } - }); - - it('Should rotate between Normal, Fast, Urgent, & Custom', async () => { - await Helpers.waitAndTap('speed-pill-fast'); - await Helpers.waitAndTap('speed-pill-urgent'); - await Helpers.waitAndTap('speed-pill-custom'); - await Helpers.waitAndTap('speed-pill-normal'); - }); - - it.skip('Should display warning on high custom base fee price', async () => { - await Helpers.clearField('max-base-fee-input'); - await Helpers.typeText('max-base-fee-input', '9999\n', false); - await Helpers.checkIfElementByTextToExist('High · overpaying'); - await Helpers.waitAndTap('speed-pill-normal'); - }); - - it.skip('Should display alert on high custom base fee price', async () => { - await Helpers.waitAndTap('speed-pill-custom'); - await Helpers.waitAndTap('gas-speed-done-button'); - await Helpers.checkIfElementByTextToExist('High max base fee!'); - await Helpers.tapByText('Edit Max Base Fee'); - await Helpers.waitAndTap('speed-pill-normal'); - await Helpers.clearField('max-base-fee-input'); - await Helpers.typeText('max-base-fee-input', `200\n`, false); - await Helpers.waitAndTap('speed-pill-normal'); - }); - - it('Should display warning on low custom base fee price', async () => { - await Helpers.clearField('max-base-fee-input'); - await Helpers.typeText('max-base-fee-input', '1\n', false); - await Helpers.checkIfElementByTextToExist('Low · likely to fail'); - }); - - it('Should display alert on low custom base fee price', async () => { - await Helpers.waitAndTap('gas-speed-done-button'); - await Helpers.checkIfElementByTextToExist('Low max base fee–transaction may get stuck!'); - await Helpers.tapByText('Edit Max Base Fee'); - await Helpers.clearField('max-base-fee-input'); - await Helpers.typeText('max-base-fee-input', '200\n', false); - }); - - it.skip('Should display warning on high custom priority fee price', async () => { - await Helpers.clearField('max-priority-fee-input'); - await Helpers.typeText('max-priority-fee-input', '999\n', false); - await Helpers.checkIfElementByTextToExist('High · overpaying'); - await Helpers.waitAndTap('speed-pill-normal'); - }); - - it.skip('Should display alert on high custom priority fee price', async () => { - await Helpers.waitAndTap('speed-pill-custom'); - await Helpers.waitAndTap('gas-speed-done-button'); - await Helpers.checkIfElementByTextToExist('High miner tip!'); - await Helpers.tapByText('Edit Miner Tip'); - await Helpers.waitAndTap('speed-pill-normal'); - await Helpers.clearField('max-base-fee-input'); - await Helpers.typeText('max-base-fee-input', '200\n', false); - await Helpers.clearField('max-priority-fee-input'); - await Helpers.typeText('max-priority-fee-input', `2\n`, false); - await Helpers.waitAndTap('speed-pill-normal'); - }); - - it.skip('Should display warning on low custom priority fee price', async () => { - await Helpers.clearField('max-base-fee-input'); - await Helpers.typeText('max-base-fee-input', '200\n', false); - await Helpers.clearField('max-priority-fee-input'); - await Helpers.typeText('max-priority-fee-input', '0.01\n', false); - await Helpers.checkIfElementByTextToExist('Low · likely to fail'); - }); - - it.skip('Should display alert on low custom priority fee price', async () => { - await Helpers.swipe('custom-gas-header', 'down', 'fast'); - await Helpers.checkIfElementByTextToExist('Low miner tip–transaction may get stuck!'); - await Helpers.tapByText('Edit Miner Tip'); - await Helpers.clearField('max-priority-fee-input'); - await Helpers.typeText('max-priority-fee-input', '2\n', false); - }); - - afterAll(async () => { - // Reset the app state - await device.clearKeychain(); - await Helpers.killHardhat(); - }); -}); diff --git a/e2e/Disabled/walletAvatarOptions.disabled.js b/e2e/Disabled/walletAvatarOptions.disabled.js deleted file mode 100644 index f6720fcf9b5..00000000000 --- a/e2e/Disabled/walletAvatarOptions.disabled.js +++ /dev/null @@ -1,163 +0,0 @@ -import * as Helpers from '../helpers'; -import { device, element, by } from 'detox'; - -const WALLET_AVATAR_COORDS = { x: 210, y: 125 }; -const WALLET_ADDRESS_COORDS = { x: 210, y: 185 }; -const PROFILE_AVATAR_COORDS = { x: 210, y: 125 }; -const PROFILE_ADDRESS_COORDS = { x: 210, y: 185 }; -const DISMISS_AVATAR_BUILDER_COORDS = { x: 20, y: 90 }; -const RAINBOW_TEST_WALLET = 'rainbowtestwallet.eth'; -const RAINBOW_WALLET = 'rainbowwallet.eth'; -const EMPTY_WALLET = '0x6791da9CCd95405e73d6a1117d02Dc81c4E58775'; - -const android = device.getPlatform() === 'android'; - -describe('Wallet avatar options', () => { - it('watch wallet without ENS', async () => { - await Helpers.checkIfVisible('welcome-screen'); - await Helpers.waitAndTap('already-have-wallet-button'); - await Helpers.waitAndTap('watch-address-button'); - await Helpers.typeText('import-sheet-input', EMPTY_WALLET, false); - await Helpers.waitAndTap('import-sheet-button'); - await Helpers.waitAndTap('wallet-info-submit-button'); - await Helpers.checkIfVisible('wallet-screen', 40000); - await Helpers.swipe('wallet-screen', 'left', 'slow'); - await Helpers.swipe('discover-home', 'left', 'slow'); - await Helpers.checkIfVisible('profile-screen', 40000); - }); - - it('test watched wallet without ENS', async () => { - // TODO: verify that wallet address matches the EMPTY_WALLET. - - await Helpers.tapAtPoint('profile-screen', WALLET_AVATAR_COORDS); - await Helpers.checkIfExistsByText('Choose from Library'); - - if (android) { - await Helpers.checkIfExistsByText('Shuffle Emoji'); - await element(by.text('Shuffle Emoji')).tap(); - } else { - await Helpers.checkIfExistsByText('Pick an Emoji'); - await Helpers.tapByText('Pick an Emoji'); - await Helpers.checkIfVisible('avatar-builder'); - await Helpers.tapAtPoint('avatar-builder', DISMISS_AVATAR_BUILDER_COORDS); - } - }); - - it('import wallet without ENS', async () => { - await Helpers.tapAtPoint('profile-screen', WALLET_ADDRESS_COORDS); - await Helpers.waitAndTap('add-another-wallet-button'); - await Helpers.waitAndTap('create-new-button'); - await Helpers.waitAndTap('wallet-info-submit-button'); - if (android) { - await Helpers.checkIfVisible('pin-authentication-screen'); - await Helpers.authenticatePin('1234'); - await Helpers.authenticatePin('1234'); - } - // Remove this once https://github.com/rainbow-me/rainbow/pull/4115 is merged. - await Helpers.relaunchApp(); - await Helpers.swipe('wallet-screen', 'left', 'slow'); - await Helpers.swipe('discover-home', 'left', 'slow'); - await Helpers.checkIfVisible('profile-screen', 40000); - - // TODO: check that wallet has different address (otherwise it means that creating wallet failed!). - }); - - it('test imported wallet without ENS', async () => { - await Helpers.tapAtPoint('profile-screen', WALLET_AVATAR_COORDS); - await Helpers.checkIfExistsByText('Choose from Library'); - if (android) { - await Helpers.checkIfExistsByText('Shuffle Emoji'); - await element(by.text('Shuffle Emoji')).tap(); - } else { - await Helpers.checkIfExistsByText('Pick an Emoji'); - await Helpers.tapByText('Pick an Emoji'); - await Helpers.tapAtPoint('avatar-builder', DISMISS_AVATAR_BUILDER_COORDS); - } - }); - - it('watch wallet with ENS but without ENS avatar', async () => { - await Helpers.tapAtPoint('profile-screen', WALLET_ADDRESS_COORDS); - await Helpers.waitAndTap('add-another-wallet-button'); - await Helpers.waitAndTap('watch-address-button'); - await Helpers.typeText('import-sheet-input', RAINBOW_TEST_WALLET, false); - await Helpers.waitAndTap('import-sheet-button'); - await Helpers.waitAndTap('wallet-info-submit-button'); - await Helpers.relaunchApp(); - }); - - it('test watched wallet with ens but without ens avatar', async () => { - await Helpers.tapAtPoint('wallet-screen', PROFILE_AVATAR_COORDS); - await Helpers.checkIfExistsByText('Choose from Library'); - if (android) { - await Helpers.checkIfExistsByText('Shuffle Emoji'); - } else { - await Helpers.checkIfExistsByText('Pick an Emoji'); - } - await Helpers.checkIfExistsByText('View Profile'); - if (!android) { - await Helpers.tapByText('Pick an Emoji'); - await Helpers.checkIfVisible('avatar-builder'); - await Helpers.tapAtPoint('avatar-builder', DISMISS_AVATAR_BUILDER_COORDS); - await Helpers.tapAtPoint('wallet-screen', PROFILE_AVATAR_COORDS); - } - await Helpers.tapByText('View Profile'); - await Helpers.checkIfVisible('profile-sheet'); - await Helpers.swipe('profile-sheet', 'down', 'slow'); - }); - - it('import wallet with ens but without ens avatar', async () => { - await Helpers.tapAtPoint('wallet-screen', PROFILE_ADDRESS_COORDS); - await Helpers.waitAndTap('add-another-wallet-button'); - await Helpers.waitAndTap('restore-with-key-button'); - await Helpers.typeText('import-sheet-input', process.env.TEST_SEEDS, false); - await Helpers.waitAndTap('import-sheet-button'); - await Helpers.waitAndTap('wallet-info-submit-button'); - await Helpers.relaunchApp(); - }); - - it('test imported wallet with ens but without ens avatar', async () => { - await Helpers.tapAtPoint('wallet-screen', PROFILE_AVATAR_COORDS); - await Helpers.checkIfExistsByText('Choose from Library'); - if (android) { - await Helpers.checkIfExistsByText('Shuffle Emoji'); - } else { - await Helpers.checkIfExistsByText('Pick an Emoji'); - } - await Helpers.checkIfExistsByText('View Profile'); - await Helpers.checkIfExistsByText('Edit Profile'); - if (!android) { - await Helpers.tapByText('Pick an Emoji'); - await Helpers.checkIfVisible('avatar-builder'); - await Helpers.tapAtPoint('avatar-builder', DISMISS_AVATAR_BUILDER_COORDS); - await Helpers.tapAtPoint('wallet-screen', PROFILE_AVATAR_COORDS); - } - await Helpers.tapByText('View Profile'); - await Helpers.checkIfVisible('profile-sheet'); - await Helpers.waitAndSwipe('profile-sheet', 'down'); - await Helpers.tapAtPoint('wallet-screen', PROFILE_AVATAR_COORDS); - await Helpers.tapByText('Edit Profile'); - await Helpers.checkIfExists('ens-edit-records-sheet'); - await Helpers.swipe('ens-edit-records-sheet', 'down', 'slow'); - }); - - it('import wallet with ens avatar', async () => { - await Helpers.tapAtPoint('wallet-screen', PROFILE_ADDRESS_COORDS); - await Helpers.waitAndTap('add-another-wallet-button'); - await Helpers.waitAndTap('watch-address-button'); - await Helpers.typeText('import-sheet-input', RAINBOW_WALLET, false); - await Helpers.waitAndTap('import-sheet-button'); - await Helpers.waitAndTap('wallet-info-submit-button'); - await Helpers.relaunchApp(); - }); - - it('test watched wallet with ens avatar', async () => { - await Helpers.tapAtPoint('wallet-screen', PROFILE_AVATAR_COORDS); - await Helpers.checkIfVisible('profile-sheet'); - }); - - // missing case: imported wallet with ENS avatar - - afterAll(async () => { - await device.clearKeychain(); - }); -}); diff --git a/e2e/helpers.ts b/e2e/helpers.ts index 55344f6052c..69cdde81e99 100644 --- a/e2e/helpers.ts +++ b/e2e/helpers.ts @@ -5,7 +5,7 @@ import { Wallet } from '@ethersproject/wallet'; import { expect, device, element, by, waitFor } from 'detox'; import { parseEther } from '@ethersproject/units'; -const TESTING_WALLET = '0x3Cb462CDC5F809aeD0558FBEe151eD5dC3D3f608'; +const TESTING_WALLET = '0x3637f053D542E6D00Eee42D656dD7C59Fa33a62F'; const DEFAULT_TIMEOUT = 20_000; const android = device.getPlatform() === 'android'; @@ -59,6 +59,7 @@ export async function beforeAllcleanApp({ hardhat }: { hardhat?: boolean }) { export async function afterAllcleanApp({ hardhat }: { hardhat?: boolean }) { await device.clearKeychain(); hardhat && (await killHardhat()); + jest.resetAllMocks(); } export async function tap(elementId: string | RegExp) { diff --git a/e2e/init.js b/e2e/init.js index a6d016ad6b6..234eef3d4ca 100644 --- a/e2e/init.js +++ b/e2e/init.js @@ -4,6 +4,8 @@ import { device } from 'detox'; require('dotenv').config({ path: '.env' }); +// jest.mock('src/__swaps__/utils/swap.ts', () => require('./mocks/worklets.mock.js')); + beforeAll(async () => { if (device.getPlatform() === 'android') { // connecting to metro diff --git a/e2e/jest.e2e.config.js b/e2e/jest.e2e.config.js index cdd8d0519cd..dfdf939e292 100644 --- a/e2e/jest.e2e.config.js +++ b/e2e/jest.e2e.config.js @@ -1,24 +1,7 @@ -/* eslint-disable @typescript-eslint/no-var-requires */ -/** @type {import('ts-jest/dist/types').JestConfigWithTsJest} */ -const { pathsToModuleNameMapper } = require('ts-jest'); -const { compilerOptions } = require('../tsconfig'); +const baseConfig = require('../jest.config'); +/** @type {import('@jest/types').Config.InitialOptions} */ module.exports = { - setupFilesAfterEnv: ['./init.js'], - testEnvironment: './environment', - - globalSetup: 'detox/runners/jest/globalSetup', - globalTeardown: 'detox/runners/jest/globalTeardown', - reporters: ['detox/runners/jest/reporter'], - - testTimeout: 300_000, - testRegex: '\\.spec\\.[jt]sx?$', - verbose: false, - transform: { - '\\.[jt]sx?$': 'ts-jest', - }, - moduleNameMapper: pathsToModuleNameMapper(compilerOptions.paths, { - prefix: '../', - }), - setupFiles: ['dotenv/config'], + ...baseConfig, + testMatch: ['/**/*.spec.ts'], }; diff --git a/jest.config.js b/jest.config.js index bbaecbd2a99..c82393941e5 100644 --- a/jest.config.js +++ b/jest.config.js @@ -1,24 +1,25 @@ -/** @type {import('ts-jest/dist/types').InitialOptionsTsJest} */ -const { pathsToModuleNameMapper } = require('ts-jest'); -const { compilerOptions } = require('./tsconfig'); - +/** @type {import('@jest/types').Config.InitialOptions} */ module.exports = { - preset: 'react-native', - setupFiles: ['./config/test/jest-setup.js'], - testPathIgnorePatterns: ['node_modules', 'e2e'], - globals: { - 'ts-jest': { - tsconfig: 'tsconfig.jest.json', - }, - }, + preset: 'ts-jest', transform: { - // https://kulshekhar.github.io/ts-jest/docs/28.0/guides/react-native - '\\.tsx?$': 'ts-jest', + '^.+\\.tsx?$': 'ts-jest', + '^.+\\.jsx?$': 'ts-jest', + '^.+\\.js$': 'ts-jest', + }, + testEnvironment: 'node', + testTimeout: 120_000, + maxWorkers: 1, + globalSetup: 'detox/runners/jest/globalSetup', + globalTeardown: 'detox/runners/jest/globalTeardown', + reporters: ['detox/runners/jest/reporter'], + testEnvironment: 'detox/runners/jest/testEnvironment', + verbose: true, + moduleNameMapper: { + '^@/__swaps__/(.*)$': '/../src/__swaps__/$1', + '^@/(.*)$': '/../src/$1', }, + setupFiles: ['dotenv/config'], transformIgnorePatterns: [ 'node_modules/(?!((jest-)?react-native|react-native-keyboard-area|imgix-core-js|react-native-payments|@react-native-firebase|@react-native(-community)?)/)', ], - moduleNameMapper: pathsToModuleNameMapper(compilerOptions.paths, { - prefix: '', - }), }; diff --git a/package.json b/package.json index fee4475140a..1d8f601ab67 100644 --- a/package.json +++ b/package.json @@ -22,8 +22,9 @@ "nuke": "./scripts/nuke.sh", "detox:android": "detox build -c android.emu.debug && detox test -c android.emu.debug --loglevel verbose", "detox:android:release": "detox build -c android.emu.release && detox test -c android.emu.release", + "detox:ios:build": "detox build -c ios.sim.debug | xcpretty --color ", "detox:ios:tests": "detox test -c ios.sim.debug --maxWorkers 2 -- --bail 1", - "detox:ios": "detox build -c ios.sim.debug | xcpretty --color && yarn detox:ios:tests", + "detox:ios": "yarn detox:ios:build && yarn detox:ios:tests", "detox:ios:release": "detox build -c ios.sim.release && detox test -c ios.sim.release --maxWorkers 2 -- --bail 1", "ds:install": "yarn install --cwd src/design-system/docs", "ds": "cd src/design-system/docs && yarn dev", diff --git a/src/__swaps__/screens/Swap/components/SearchInput.tsx b/src/__swaps__/screens/Swap/components/SearchInput.tsx index f4d9086bfb6..564b0060f7f 100644 --- a/src/__swaps__/screens/Swap/components/SearchInput.tsx +++ b/src/__swaps__/screens/Swap/components/SearchInput.tsx @@ -136,6 +136,7 @@ export const SearchInput = ({ { diff --git a/src/__swaps__/screens/Swap/components/SwapActionButton.tsx b/src/__swaps__/screens/Swap/components/SwapActionButton.tsx index f447a42eff8..3219599cfc2 100644 --- a/src/__swaps__/screens/Swap/components/SwapActionButton.tsx +++ b/src/__swaps__/screens/Swap/components/SwapActionButton.tsx @@ -108,6 +108,7 @@ export const SwapActionButton = ({ }} > state.associatedWalletAddress); const isSwapsOpen = useSwapsStore(state => state.isSwapsOpen); @@ -18,6 +21,7 @@ export const UserAssetsSync = memo(function UserAssetsSync() { { address: currentAddress as Address, currency: currentCurrency, + testnetMode: connectedToHardhat, }, { enabled: !isSwapsOpen || userAssetsWalletAddress !== currentAddress, @@ -41,4 +45,4 @@ export const UserAssetsSync = memo(function UserAssetsSync() { ); return null; -}); +}; diff --git a/src/__swaps__/screens/Swap/hooks/useAssetsToSell.ts b/src/__swaps__/screens/Swap/hooks/useAssetsToSell.ts index 13f6d54e02d..d5c6e57f2f8 100644 --- a/src/__swaps__/screens/Swap/hooks/useAssetsToSell.ts +++ b/src/__swaps__/screens/Swap/hooks/useAssetsToSell.ts @@ -10,6 +10,7 @@ import { useUserAssets } from '@/__swaps__/screens/Swap/resources/assets'; import { ParsedAssetsDictByChain, ParsedSearchAsset, UserAssetFilter } from '@/__swaps__/types/assets'; import { useAccountSettings, useDebounce } from '@/hooks'; import { userAssetsStore } from '@/state/assets/userAssets'; +import { getCachedProviderForNetwork, isHardHat } from '@/handlers/web3'; const sortBy = (by: UserAssetFilter) => { switch (by) { @@ -21,7 +22,11 @@ const sortBy = (by: UserAssetFilter) => { }; export const useAssetsToSell = () => { - const { accountAddress: currentAddress, nativeCurrency: currentCurrency } = useAccountSettings(); + const { accountAddress: currentAddress, nativeCurrency: currentCurrency, network: currentNetwork } = useAccountSettings(); + + const provider = getCachedProviderForNetwork(currentNetwork); + const providerUrl = provider?.connection?.url ?? ''; + const connectedToHardhat = isHardHat(providerUrl); const filter = userAssetsStore(state => state.filter); const searchQuery = userAssetsStore(state => state.inputSearchQuery); @@ -32,6 +37,7 @@ export const useAssetsToSell = () => { { address: currentAddress as Address, currency: currentCurrency, + testnetMode: connectedToHardhat, }, { select: data => diff --git a/src/__swaps__/screens/Swap/hooks/useSwapInputsController.ts b/src/__swaps__/screens/Swap/hooks/useSwapInputsController.ts index 48ec9effda2..aa8d8e9cd12 100644 --- a/src/__swaps__/screens/Swap/hooks/useSwapInputsController.ts +++ b/src/__swaps__/screens/Swap/hooks/useSwapInputsController.ts @@ -489,6 +489,8 @@ export function useSwapInputsController({ }), ]); + console.log(quoteResponse); + const quotedInputAmount = lastTypedInputParam === 'outputAmount' ? Number( diff --git a/src/__swaps__/types/chains.ts b/src/__swaps__/types/chains.ts index c61c29adbdd..feaea2a5c11 100644 --- a/src/__swaps__/types/chains.ts +++ b/src/__swaps__/types/chains.ts @@ -100,6 +100,7 @@ export enum ChainName { celo = 'celo', degen = 'degen', gnosis = 'gnosis', + goerli = 'goerli', linea = 'linea', manta = 'manta', optimism = 'optimism', @@ -169,6 +170,7 @@ export const chainNameToIdMapping: { [ChainName.celo]: ChainId.celo, [ChainName.degen]: ChainId.degen, [ChainName.gnosis]: ChainId.gnosis, + [ChainName.goerli]: chain.goerli.id, [ChainName.linea]: ChainId.linea, [ChainName.manta]: ChainId.manta, [ChainName.optimism]: ChainId.optimism, @@ -208,6 +210,7 @@ export const chainIdToNameMapping: { [ChainId.celo]: ChainName.celo, [ChainId.degen]: ChainName.degen, [ChainId.gnosis]: ChainName.gnosis, + [chain.goerli.id]: ChainName.goerli, [ChainId.linea]: ChainName.linea, [ChainId.manta]: ChainName.manta, [ChainId.optimism]: ChainName.optimism, @@ -249,6 +252,7 @@ export const ChainNameDisplay = { [ChainId.scroll]: chain.scroll.name, [ChainId.zora]: 'Zora', [ChainId.mainnet]: 'Ethereum', + [chain.goerli.id]: 'Goerli', [ChainId.hardhat]: 'Hardhat', [ChainId.hardhatOptimism]: chainHardhatOptimism.name, [ChainId.sepolia]: chain.sepolia.name, diff --git a/src/components/activity-list/ActivityList.js b/src/components/activity-list/ActivityList.js index 4367a80af1a..98df923fbd2 100644 --- a/src/components/activity-list/ActivityList.js +++ b/src/components/activity-list/ActivityList.js @@ -125,6 +125,7 @@ const ActivityList = ({ nativeCurrency, pendingTransactionsCount, }} + testID={'wallet-activity-list'} getItemLayout={getItemLayout} initialNumToRender={12} keyExtractor={keyExtractor} diff --git a/src/components/asset-list/RecyclerAssetList2/FastComponents/FastBalanceCoinRow.tsx b/src/components/asset-list/RecyclerAssetList2/FastComponents/FastBalanceCoinRow.tsx index 942fc40a041..08d6b42844e 100644 --- a/src/components/asset-list/RecyclerAssetList2/FastComponents/FastBalanceCoinRow.tsx +++ b/src/components/asset-list/RecyclerAssetList2/FastComponents/FastBalanceCoinRow.tsx @@ -91,7 +91,7 @@ const MemoizedBalanceCoinRow = React.memo( const valueColor = nativeDisplay ? theme.colors.dark : theme.colors.blueGreyLight; return ( - + diff --git a/src/references/chain-assets.json b/src/references/chain-assets.json index 44548600043..8e14b5ac633 100644 --- a/src/references/chain-assets.json +++ b/src/references/chain-assets.json @@ -9,7 +9,7 @@ }, "decimals": 18, "icon_url": "https://s3.amazonaws.com/icons.assets/ETH.png", - "name": "Ether", + "name": "Goerli", "network": "goerli", "price": { "changed_at": 1582568575, @@ -31,7 +31,7 @@ }, "decimals": 18, "icon_url": "https://s3.amazonaws.com/icons.assets/ETH.png", - "name": "Ether", + "name": "Ethereum", "network": "mainnet", "price": { "changed_at": 1582568575, diff --git a/src/references/index.ts b/src/references/index.ts index b0fa576c50d..ae5b3378c9d 100644 --- a/src/references/index.ts +++ b/src/references/index.ts @@ -227,21 +227,10 @@ export const SUPPORTED_MAINNET_CHAINS: Chain[] = [mainnet, polygon, optimism, ar name: ChainNameDisplay[chain.id], })); -export const SUPPORTED_CHAINS = ({ testnetMode = false }: { testnetMode?: boolean }): Chain[] => - [ - // In default order of appearance - mainnet, - base, - optimism, - arbitrum, - polygon, - zora, - blast, - degen, - avalanche, - bsc, +export const SUPPORTED_CHAINS = ({ testnetMode = false }: { testnetMode?: boolean }): Chain[] => { + const mainnetChains: Chain[] = [mainnet, base, optimism, arbitrum, polygon, zora, blast, degen, avalanche, bsc]; - // Testnets + const testnetChains: Chain[] = [ goerli, holesky, sepolia, @@ -253,12 +242,12 @@ export const SUPPORTED_CHAINS = ({ testnetMode = false }: { testnetMode?: boolea zoraSepolia, avalancheFuji, bscTestnet, - ].reduce((chainList, chain) => { - if (testnetMode || !chain.testnet) { - chainList.push({ ...chain, name: ChainNameDisplay[chain.id] }); - } - return chainList; - }, [] as Chain[]); + ]; + + const allChains = mainnetChains.concat(testnetMode ? testnetChains : []); + + return allChains.map(chain => ({ ...chain, name: ChainNameDisplay[chain.id] ?? chain.name })); +}; export const SUPPORTED_CHAIN_IDS = ({ testnetMode = false }: { testnetMode?: boolean }) => SUPPORTED_CHAINS({ testnetMode }).map(chain => chain.id); diff --git a/src/screens/transaction-details/TransactionDetails.tsx b/src/screens/transaction-details/TransactionDetails.tsx index e81de10c8b3..54b61dca03d 100644 --- a/src/screens/transaction-details/TransactionDetails.tsx +++ b/src/screens/transaction-details/TransactionDetails.tsx @@ -62,7 +62,7 @@ export const TransactionDetails = () => { deferredHeight={IS_ANDROID} showsVerticalScrollIndicator={false} > - + diff --git a/tsconfig.jest.json b/tsconfig.jest.json deleted file mode 100644 index ec83611f0c5..00000000000 --- a/tsconfig.jest.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "extends": "./tsconfig.json", - "compilerOptions": { - "jsx": "react" - } -} diff --git a/tsconfig.spec.json b/tsconfig.spec.json new file mode 100644 index 00000000000..50975ba4a82 --- /dev/null +++ b/tsconfig.spec.json @@ -0,0 +1,15 @@ +{ + "extends": "./tsconfig.json", + "baseUrl": ".", + "paths": { + "@/*": ["src/*"], + "@/__swaps__/*": ["src/__swaps__/*"] + }, + "compilerOptions": { + "jsx": "react", + "module": "commonjs", + "types": ["jest", "node"], + "noEmit": true + }, + "include": ["src/**/*.ts", "src/**/*.tsx", "e2e/**/*.ts"] +}