-
Notifications
You must be signed in to change notification settings - Fork 97
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
test: re-enable secure send e2e test #4507
Changes from all commits
4f5ec38
c410d94
422e4ef
6d39db7
67cd20a
f685772
9584050
de6885c
e8ee85f
8688c23
c9e5224
f8bcb0a
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,11 @@ | ||
import { E2E_TEST_WALLET } from './consts' | ||
import { E2E_TEST_WALLET, E2E_TEST_WALLET_SECURE_SEND } from './consts' | ||
import { checkBalance, getBalance } from './utils' | ||
;(async () => { | ||
console.log(E2E_TEST_WALLET) | ||
console.table(await getBalance(E2E_TEST_WALLET)) | ||
await checkBalance(E2E_TEST_WALLET) | ||
|
||
console.log(E2E_TEST_WALLET_SECURE_SEND) | ||
console.table(await getBalance(E2E_TEST_WALLET_SECURE_SEND)) | ||
await checkBalance(E2E_TEST_WALLET_SECURE_SEND) | ||
})() |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,4 @@ | ||
export const E2E_TEST_WALLET = '0x6131a6d616a4be3737b38988847270a64bc10caa' | ||
export const E2E_TEST_WALLET_SECURE_SEND = '0x86b8f44386cb2d457db79c3dab8cf42f9d8a3fc0' | ||
export const E2E_TEST_FAUCET = '0xe5F5363e31351C38ac82DBAdeaD91Fd5a7B08846' | ||
export const REFILL_TOKENS = ['CELO', 'cUSD', 'cEUR'] |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,13 +1,19 @@ | ||
import { REFILL_TOKENS } from './consts' | ||
|
||
export const Web3 = require('web3') | ||
export const ContractKit = require('@celo/contractkit') | ||
export const dotenv = require('dotenv') | ||
export const web3 = new Web3('https://alfajores-forno.celo-testnet.org') | ||
export const kit = ContractKit.newKitFromWeb3(web3) | ||
|
||
export async function checkBalance(address: string, minBalance = 10) { | ||
let balanceObject = await getBalance(address) | ||
for (const balance in balanceObject) { | ||
if (balanceObject[balance as keyof typeof balanceObject] < minBalance) { | ||
export async function checkBalance( | ||
address: string, | ||
minBalance = 10, | ||
tokenSymbols: string[] = REFILL_TOKENS | ||
) { | ||
const balance = (await getBalance(address)) ?? {} | ||
for (const [tokenSymbol, tokenBalance] of Object.entries(balance)) { | ||
if (tokenSymbols.includes(tokenSymbol) && tokenBalance < minBalance) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. use |
||
throw new Error( | ||
`${balance} balance of ${address} is below ${minBalance}. Please refill from the faucet https://celo.org/developers/faucet or run ./fund-e2e-accounts.ts if a Valora Dev.` | ||
) | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,13 +1,7 @@ | ||
import SecureSend from './usecases/SecureSend' | ||
import Send from './usecases/Send' | ||
import { quickOnboarding } from './utils/utils' | ||
|
||
describe('Given', () => { | ||
beforeAll(async () => { | ||
await quickOnboarding() | ||
}) | ||
|
||
describe('Send', Send) | ||
// TODO: unskip this test if we enable CPV in CI | ||
describe.skip('SecureSend cUSD', SecureSend) | ||
describe('SecureSend with CPV', SecureSend) | ||
}) |
Original file line number | Diff line number | Diff line change | ||||||||
---|---|---|---|---|---|---|---|---|---|---|
@@ -1,86 +1,92 @@ | ||||||||||
import { reloadReactNative } from '../utils/retries' | ||||||||||
import { | ||||||||||
SAMPLE_BACKUP_KEY_VERIFIED, | ||||||||||
VERIFIED_PHONE_NUMBER, | ||||||||||
SAMPLE_WALLET_ADDRESS_VERIFIED_2, | ||||||||||
} from '../utils/consts' | ||||||||||
import { launchApp } from '../utils/retries' | ||||||||||
import { | ||||||||||
addComment, | ||||||||||
enterPinUiIfNecessary, | ||||||||||
inputNumberKeypad, | ||||||||||
scrollIntoView, | ||||||||||
sleep, | ||||||||||
quickOnboarding, | ||||||||||
} from '../utils/utils' | ||||||||||
const faker = require('@faker-js/faker') | ||||||||||
|
||||||||||
const PHONE_NUMBER = '+12057368924' | ||||||||||
const LAST_ACCOUNT_CHARACTERS = 'FD08' | ||||||||||
const AMOUNT_TO_SEND = '0.1' | ||||||||||
const AMOUNT_TO_SEND = '0.01' | ||||||||||
|
||||||||||
export default SecureSend = () => { | ||||||||||
beforeEach(async () => { | ||||||||||
await reloadReactNative() | ||||||||||
}) | ||||||||||
|
||||||||||
it('Send cUSD to phone number with multiple mappings', async () => { | ||||||||||
let randomContent = faker.lorem.words() | ||||||||||
await waitFor(element(by.id('HomeAction-Send'))) | ||||||||||
.toBeVisible() | ||||||||||
.withTimeout(30000) | ||||||||||
await element(by.id('HomeAction-Send')).tap() | ||||||||||
|
||||||||||
// Look for an address and tap on it. | ||||||||||
await element(by.id('SearchInput')).tap() | ||||||||||
await element(by.id('SearchInput')).replaceText(PHONE_NUMBER) | ||||||||||
await element(by.id('RecipientItem')).tap() | ||||||||||
describe.each([{ web3Library: 'contract-kit' }, { web3Library: 'viem' }])( | ||||||||||
'Secure send flow with phone number lookup (with $web3Library)', | ||||||||||
({ web3Library }) => { | ||||||||||
beforeAll(async () => { | ||||||||||
// uninstall the app to remove secure send mapping | ||||||||||
await device.uninstallApp() | ||||||||||
await device.installApp() | ||||||||||
await launchApp({ | ||||||||||
newInstance: true, | ||||||||||
permissions: { notifications: 'YES', contacts: 'YES' }, | ||||||||||
launchArgs: { | ||||||||||
statsigGateOverrides: `use_new_send_flow=false,use_viem_for_send=${ | ||||||||||
web3Library === 'viem' | ||||||||||
}`, | ||||||||||
}, | ||||||||||
}) | ||||||||||
await quickOnboarding(SAMPLE_BACKUP_KEY_VERIFIED) | ||||||||||
}) | ||||||||||
|
||||||||||
// Select the currency | ||||||||||
await waitFor(element(by.id('cUSDBalance'))) | ||||||||||
.toBeVisible() | ||||||||||
.withTimeout(30 * 1000) | ||||||||||
await element(by.id('cUSDBalance')).tap() | ||||||||||
it('Send cUSD to phone number with multiple mappings', async () => { | ||||||||||
let randomContent = faker.lorem.words() | ||||||||||
await waitFor(element(by.id('HomeAction-Send'))) | ||||||||||
.toBeVisible() | ||||||||||
.withTimeout(30000) | ||||||||||
await element(by.id('HomeAction-Send')).tap() | ||||||||||
await waitFor(element(by.id('SendSearchInput'))).toBeVisible() | ||||||||||
|
||||||||||
// Enter the amount and review | ||||||||||
await inputNumberKeypad(AMOUNT_TO_SEND) | ||||||||||
await element(by.id('Review')).tap() | ||||||||||
await element(by.id('SearchInput')).tap() | ||||||||||
await element(by.id('SearchInput')).replaceText(VERIFIED_PHONE_NUMBER) | ||||||||||
await element(by.id('RecipientItem')).tap() | ||||||||||
|
||||||||||
// hack: we shouldn't need this but the test fails without | ||||||||||
await sleep(3000) | ||||||||||
// Select the currency | ||||||||||
await waitFor(element(by.id('cUSDTouchable'))).toBeVisible() | ||||||||||
await element(by.id('cUSDTouchable')).tap() | ||||||||||
|
||||||||||
// Click Edit if confirm account isn't served | ||||||||||
try { | ||||||||||
await element(by.id('accountEditButton')).tap() | ||||||||||
} catch {} | ||||||||||
// Enter the amount and review | ||||||||||
await inputNumberKeypad(AMOUNT_TO_SEND) | ||||||||||
await element(by.id('Review')).tap() | ||||||||||
|
||||||||||
// Use the last digits of the account to confirm the sender. | ||||||||||
await waitFor(element(by.id('confirmAccountButton'))) | ||||||||||
.toBeVisible() | ||||||||||
.withTimeout(30000) | ||||||||||
await element(by.id('confirmAccountButton')).tap() | ||||||||||
for (let index = 0; index < 4; index++) { | ||||||||||
const character = LAST_ACCOUNT_CHARACTERS[index] | ||||||||||
await element(by.id(`SingleDigitInput/digit${index}`)).replaceText(character) | ||||||||||
} | ||||||||||
|
||||||||||
// Scroll to see submit button | ||||||||||
await scrollIntoView('Submit', 'KeyboardAwareScrollView', 50) | ||||||||||
await element(by.id('ConfirmAccountButton')).tap() | ||||||||||
// Use the last digits of the account to confirm the sender. | ||||||||||
await waitFor(element(by.id('confirmAccountButton'))).toBeVisible() | ||||||||||
await element(by.id('confirmAccountButton')).tap() | ||||||||||
// TODO: test case for AddressValidationType.PARTIAL but relies on mapping phone number to another address with unique last 4 digits | ||||||||||
// for (let index = 0; index < 4; index++) { | ||||||||||
// const character = LAST_ACCOUNT_CHARACTERS[index] | ||||||||||
// await element(by.id(`SingleDigitInput/digit${index}`)).replaceText(character) | ||||||||||
// } | ||||||||||
await element(by.id('ValidateRecipientAccount/TextInput')).replaceText( | ||||||||||
SAMPLE_WALLET_ADDRESS_VERIFIED_2 | ||||||||||
) | ||||||||||
Comment on lines
+66
to
+68
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why doesn't it need just the last 4 digits? We'd need 2 other verified accounts, to another number to test that case. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. if i understand correctly, the secure send screen either asks for the full address or the last 4 digits but this is depending on how "different" the possible addresses are. unfortunately we've mapped to 2 wallets and they both have a "0" in the last 4 digits of the address, so we've got the full text input. idk if it is too important to test both the full text input and the 4 digits, i have 90% confidence that both flows are working if i know one of them is working. we can try to remap to another address, but this is Tom's burner number and he's out all week so would need to wait till he's back There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yes the current test is fine for now. For posterity, the check for uniqueness of the last 4 digits is done as a whole, but also includes the user's own address: wallet/src/identity/secureSend.ts Lines 59 to 62 in 2b28b69
It's not the fact that there are chars in common between them that causes |
||||||||||
|
||||||||||
// Write a comment. | ||||||||||
await addComment(randomContent) | ||||||||||
// Scroll to see submit button | ||||||||||
await scrollIntoView('Submit', 'KeyboardAwareScrollView', 50) | ||||||||||
await element(by.id('ConfirmAccountButton')).tap() | ||||||||||
|
||||||||||
// Wait for the confirm button to be clickable. If it takes too long this test | ||||||||||
// will be flaky :( | ||||||||||
await sleep(3000) | ||||||||||
// Write a comment. | ||||||||||
await addComment(randomContent) | ||||||||||
|
||||||||||
// Confirm and input PIN if necessary. | ||||||||||
await element(by.id('ConfirmButton')).tap() | ||||||||||
await enterPinUiIfNecessary() | ||||||||||
// Confirm and input PIN if necessary. | ||||||||||
await element(by.id('ConfirmButton')).tap() | ||||||||||
await enterPinUiIfNecessary() | ||||||||||
|
||||||||||
// Return to home screen. | ||||||||||
await waitFor(element(by.id('HomeAction-Send'))) | ||||||||||
.toBeVisible() | ||||||||||
.withTimeout(30 * 1000) | ||||||||||
// Return to home screen. | ||||||||||
await waitFor(element(by.id('HomeAction-Send'))) | ||||||||||
.toBeVisible() | ||||||||||
.withTimeout(30 * 1000) | ||||||||||
|
||||||||||
// TODO: See why these are taking so long in e2e tests to appear | ||||||||||
// Look for the latest transaction and assert | ||||||||||
// await waitFor(element(by.text(`${randomContent}`))) | ||||||||||
// .toBeVisible() | ||||||||||
// .withTimeout(60000) | ||||||||||
}) | ||||||||||
await waitFor(element(by.text(`${randomContent}`))) | ||||||||||
.toBeVisible() | ||||||||||
.withTimeout(60000) | ||||||||||
}) | ||||||||||
} | ||||||||||
) | ||||||||||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
not strictly necessary, but without this we'd proceed for tokens like cREAL and TT only to hit the default case in the switch statement (no transaction created)