mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
c757366355
* Add metametrics provider and util. * Add backend api and state for participating in metametrics. * Add frontend action for participating in metametrics. * Add metametrics opt-in screen. * Add metametrics events to first time flow. * Add metametrics events for route changes * Add metametrics events for send and confirm screens * Add metametrics events to dropdowns, transactions, log in and out, settings, sig requests and main screen * Ensures each log in is measured as a new visit by metametrics. * Ensure metametrics is called with an empty string for dimensions params if specified * Adds opt in metametrics modal after unlock for existing users * Adds settings page toggle for opting in and out of MetaMetrics * Switch metametrics dimensions to page level scope * Lint, test and translation fixes for metametrics. * Update design for metametrics opt-in screen * Complete responsive styling of metametrics-opt-in modal * Use new chart image on metrics opt in screens * Incorporate the metametrics opt-in screen into the new onboarding flow * Update e2e tests to accomodate metametrics changes * Mock out metametrics network requests in integration tests * Fix tx-list integration test to support metametrics provider. * Send number of tokens and accounts data with every metametrics event. * Update metametrics event descriptor schema and add new events. * Fix import tos bug and send gas button bug due to metametrics changes. * Various small fixes on the metametrics branch. * Add origin custom variable type to metametrics.util * Fix names of onboarding complete actions (metametrics). * Fix names of Metrics Options actions (metametrics). * Clean up code related to metametrics. * Fix bad merge conflict resolution and improve promise handling in sendMetaMetrics event and confrim tx base * Don't send a second metrics event if user has gone back during first time flow. * Collect metametrics on going back from onboarding create/import. * Add missing custom variable constants for metametrics * Fix metametrics provider * Make height of opt-in modal responsive. * Adjust text content for opt-in modal. * Update metametrics event names and clean up code in opt-in-modal * Put phishing warning step next to last in onboarding flow * Link terms of service on create and import screens of first time flow * Add subtext to options on the onboarding select action screen. * Fix styling of bullet points on end of onboarding screen. * Combine phishing warning and congratulations screens. * Fix placement of users if unlocking after an incomplete onboarding import flow. * Fix capitalization in opt-in screen * Fix last onboarding screen translations * Add link to 'Learn More' on the last screen of onboarding * Code clean up: metametrics branch * Update e2e tests for phishing warning step removal * e2e tests passing on metametrics branch * Different tracking urls for metametrics on development and prod
153 lines
6.5 KiB
JavaScript
153 lines
6.5 KiB
JavaScript
const reactTriggerChange = require('../../lib/react-trigger-change')
|
|
const {
|
|
timeout,
|
|
queryAsync,
|
|
findAsync,
|
|
} = require('../../lib/util')
|
|
const fetchMockResponses = require('../../e2e/beta/fetch-mocks.js')
|
|
|
|
QUnit.module('new ui send flow')
|
|
|
|
QUnit.test('successful send flow', (assert) => {
|
|
const done = assert.async()
|
|
runSendFlowTest(assert).then(done).catch((err) => {
|
|
assert.notOk(err, `Error was thrown: ${err.stack}`)
|
|
done()
|
|
})
|
|
})
|
|
|
|
global.ethQuery = {
|
|
sendTransaction: () => {},
|
|
}
|
|
|
|
global.ethereumProvider = {}
|
|
|
|
async function runSendFlowTest (assert, done) {
|
|
const tempFetch = global.fetch
|
|
|
|
global.fetch = (...args) => {
|
|
if (args[0] === 'https://ethgasstation.info/json/ethgasAPI.json') {
|
|
return Promise.resolve({ json: () => Promise.resolve(JSON.parse(fetchMockResponses.ethGasBasic)) })
|
|
} else if (args[0] === 'https://ethgasstation.info/json/predictTable.json') {
|
|
return Promise.resolve({ json: () => Promise.resolve(JSON.parse(fetchMockResponses.ethGasPredictTable)) })
|
|
} else if (args[0] === 'https://dev.blockscale.net/api/gasexpress.json') {
|
|
return Promise.resolve({ json: () => Promise.resolve(JSON.parse(fetchMockResponses.gasExpress)) })
|
|
} else if (args[0].match(/chromeextensionmm/)) {
|
|
return Promise.resolve({ json: () => Promise.resolve(JSON.parse(fetchMockResponses.metametrics)) })
|
|
}
|
|
return window.fetch(...args)
|
|
}
|
|
|
|
console.log('*** start runSendFlowTest')
|
|
const selectState = await queryAsync($, 'select')
|
|
selectState.val('send new ui')
|
|
reactTriggerChange(selectState[0])
|
|
|
|
const sendScreenButton = await queryAsync($, 'button.btn-primary.transaction-view-balance__button')
|
|
assert.ok(sendScreenButton[1], 'send screen button present')
|
|
sendScreenButton[1].click()
|
|
|
|
const sendTitle = await queryAsync($, '.page-container__title')
|
|
assert.equal(sendTitle[0].textContent, 'Send ETH', 'Send screen title is correct')
|
|
|
|
const sendCopy = await queryAsync($, '.page-container__subtitle')
|
|
assert.equal(sendCopy[0].textContent, 'Only send ETH to an Ethereum address.', 'Send screen has copy')
|
|
|
|
const sendFromField = await queryAsync($, '.send-v2__form-field')
|
|
assert.ok(sendFromField[0], 'send screen has a from field')
|
|
|
|
const sendFromFieldItemAddress = await queryAsync($, '.account-list-item__account-name')
|
|
assert.equal(sendFromFieldItemAddress[0].textContent, 'Send Account 2', 'send from field shows correct account name')
|
|
|
|
const sendToFieldInput = await queryAsync($, '.send-v2__to-autocomplete__input')
|
|
sendToFieldInput[0].focus()
|
|
|
|
await timeout(1000)
|
|
|
|
const sendToDropdownList = await queryAsync($, '.send-v2__from-dropdown__list')
|
|
assert.equal(sendToDropdownList.children().length, 5, 'send to dropdown shows all accounts and address book accounts')
|
|
|
|
sendToDropdownList.children()[2].click()
|
|
|
|
const sendToAccountAddress = sendToFieldInput.val()
|
|
assert.equal(sendToAccountAddress, '0x2f8D4a878cFA04A6E60D46362f5644DeAb66572D', 'send to dropdown selects the correct address')
|
|
|
|
const sendAmountField = await queryAsync($, '.send-v2__form-row:eq(2)')
|
|
sendAmountField.find('.unit-input')[0].click()
|
|
|
|
const sendAmountFieldInput = await findAsync(sendAmountField, '.unit-input__input')
|
|
sendAmountFieldInput.val('5.1')
|
|
reactTriggerChange(sendAmountField.find('input')[0])
|
|
|
|
let errorMessage = await queryAsync($, '.send-v2__error')
|
|
assert.equal(errorMessage[0].textContent, 'Insufficient funds.', 'send should render an insufficient fund error message')
|
|
|
|
sendAmountFieldInput.val('2.0')
|
|
reactTriggerChange(sendAmountFieldInput[0])
|
|
await timeout()
|
|
errorMessage = $('.send-v2__error')
|
|
assert.equal(errorMessage.length, 0, 'send should stop rendering amount error message after amount is corrected')
|
|
|
|
const sendButton = await queryAsync($, 'button.btn-primary.btn--large.page-container__footer-button')
|
|
assert.equal(sendButton[0].textContent, 'Next', 'next button rendered')
|
|
sendButton[0].click()
|
|
await timeout()
|
|
|
|
selectState.val('send edit')
|
|
reactTriggerChange(selectState[0])
|
|
|
|
const confirmFromName = (await queryAsync($, '.sender-to-recipient__name')).first()
|
|
assert.equal(confirmFromName[0].textContent, 'Send Account 2', 'confirm screen should show correct from name')
|
|
|
|
const confirmToName = (await queryAsync($, '.sender-to-recipient__name')).last()
|
|
assert.equal(confirmToName[0].textContent, 'Send Account 3', 'confirm screen should show correct to name')
|
|
|
|
const confirmScreenRowFiats = await queryAsync($, '.confirm-detail-row__secondary')
|
|
const confirmScreenGas = confirmScreenRowFiats[0]
|
|
assert.equal(confirmScreenGas.textContent, '$3.60', 'confirm screen should show correct gas')
|
|
const confirmScreenTotal = confirmScreenRowFiats[1]
|
|
assert.equal(confirmScreenTotal.textContent, '$2,405.37', 'confirm screen should show correct total')
|
|
|
|
const confirmScreenBackButton = await queryAsync($, '.confirm-page-container-header__back-button')
|
|
confirmScreenBackButton[0].click()
|
|
|
|
const sendToFieldInputInEdit = await queryAsync($, '.send-v2__to-autocomplete__input')
|
|
sendToFieldInputInEdit[0].focus()
|
|
sendToFieldInputInEdit.val('0xd85a4b6a394794842887b8284293d69163007bbb')
|
|
|
|
const sendAmountFieldInEdit = await queryAsync($, '.send-v2__form-row:eq(2)')
|
|
sendAmountFieldInEdit.find('.unit-input')[0].click()
|
|
|
|
const sendAmountFieldInputInEdit = sendAmountFieldInEdit.find('.unit-input__input')
|
|
sendAmountFieldInputInEdit.val('1.0')
|
|
reactTriggerChange(sendAmountFieldInputInEdit[0])
|
|
|
|
const sendButtonInEdit = await queryAsync($, '.btn-primary.btn--large.page-container__footer-button')
|
|
assert.equal(sendButtonInEdit[0].textContent, 'Next', 'next button in edit rendered')
|
|
|
|
selectState.val('send new ui')
|
|
reactTriggerChange(selectState[0])
|
|
|
|
const cancelButtonInEdit = await queryAsync($, '.btn-default.btn--large.page-container__footer-button')
|
|
cancelButtonInEdit[0].click()
|
|
|
|
global.fetch = tempFetch
|
|
// sendButtonInEdit[0].click()
|
|
|
|
// // TODO: Need a way to mock background so that we can test correct transition from editing to confirm
|
|
// selectState.val('confirm new ui')
|
|
// reactTriggerChange(selectState[0])
|
|
|
|
|
|
// const confirmScreenConfirmButton = await queryAsync($, '.btn-confirm.page-container__footer-button')
|
|
// console.log(`+++++++++++++++++++++++++++++++= confirmScreenConfirmButton[0]`, confirmScreenConfirmButton[0]);
|
|
// confirmScreenConfirmButton[0].click()
|
|
|
|
// await timeout(10000000)
|
|
|
|
// const txView = await queryAsync($, '.tx-view')
|
|
// console.log(`++++++++++++++++++++++++++++++++ txView[0]`, txView[0]);
|
|
|
|
// assert.ok(txView[0], 'Should return to the account details screen after confirming')
|
|
}
|