mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
552ea136b7
The bug with our onboarding library integration was introduced in #8873 because of a change in when `completeOnboarding` was called. We hadn't realized at the time that the onboarding integration relied upon the onboarding completing event to know when the onboarding state should be cleared. Because onboarding is now marked as completed earlier, the state was cleared just as it was intended to be used. The onboarding completed event has been moved back to where it was before: after the user exits the "end of flow" page. The original problem that #8873 was addressing was a routing issue, where the user would be redirected back to the seed phrase confirmation page despite already having confirmed their seed phrase. This was fixed in a different way here, by updating the routing in the first time flow switch to skip straight to the end of flow page if the seed phrase has already been confirmed. This does involve one user-facing change in behavior; if the user opens any MetaMask UI before navigating away from the end-of-flow screen, they will still be considered mid-onboarding so it'll redirect to the end-of-flow screen. But we do mark onboarding as completed if the user closes the tab/window while on the end of flow screen, which was another goal of #8873.
138 lines
3.4 KiB
JavaScript
138 lines
3.4 KiB
JavaScript
import assert from 'assert'
|
|
import React from 'react'
|
|
import { mountWithRouter } from '../../../../../../test/lib/render-helpers'
|
|
import {
|
|
DEFAULT_ROUTE,
|
|
LOCK_ROUTE,
|
|
INITIALIZE_WELCOME_ROUTE,
|
|
INITIALIZE_UNLOCK_ROUTE,
|
|
INITIALIZE_END_OF_FLOW_ROUTE,
|
|
} from '../../../../helpers/constants/routes'
|
|
import FirstTimeFlowSwitch from '..'
|
|
|
|
describe('FirstTimeFlowSwitch', function () {
|
|
it('redirects to /welcome route with null props', function () {
|
|
const props = {
|
|
completedOnboarding: null,
|
|
isInitialized: null,
|
|
isUnlocked: null,
|
|
seedPhraseBackedUp: null,
|
|
}
|
|
const wrapper = mountWithRouter(
|
|
<FirstTimeFlowSwitch.WrappedComponent {...props} />,
|
|
)
|
|
assert.equal(
|
|
wrapper
|
|
.find('Lifecycle')
|
|
.find({ to: { pathname: INITIALIZE_WELCOME_ROUTE } }).length,
|
|
1,
|
|
)
|
|
})
|
|
|
|
it('redirects to / route when completedOnboarding is true', function () {
|
|
const props = {
|
|
completedOnboarding: true,
|
|
}
|
|
const wrapper = mountWithRouter(
|
|
<FirstTimeFlowSwitch.WrappedComponent {...props} />,
|
|
)
|
|
|
|
assert.equal(
|
|
wrapper.find('Lifecycle').find({ to: { pathname: DEFAULT_ROUTE } })
|
|
.length,
|
|
1,
|
|
)
|
|
})
|
|
|
|
it('redirects to end of flow route when seedPhraseBackedUp is true', function () {
|
|
const props = {
|
|
completedOnboarding: false,
|
|
seedPhraseBackedUp: true,
|
|
}
|
|
const wrapper = mountWithRouter(
|
|
<FirstTimeFlowSwitch.WrappedComponent {...props} />,
|
|
)
|
|
|
|
assert.equal(
|
|
wrapper
|
|
.find('Lifecycle')
|
|
.find({ to: { pathname: INITIALIZE_END_OF_FLOW_ROUTE } }).length,
|
|
1,
|
|
)
|
|
})
|
|
|
|
it('redirects to end of flow route when seedPhraseBackedUp is false', function () {
|
|
const props = {
|
|
completedOnboarding: false,
|
|
seedPhraseBackedUp: false,
|
|
}
|
|
const wrapper = mountWithRouter(
|
|
<FirstTimeFlowSwitch.WrappedComponent {...props} />,
|
|
)
|
|
|
|
assert.equal(
|
|
wrapper
|
|
.find('Lifecycle')
|
|
.find({ to: { pathname: INITIALIZE_END_OF_FLOW_ROUTE } }).length,
|
|
1,
|
|
)
|
|
})
|
|
|
|
it('redirects to /lock route when isUnlocked is true ', function () {
|
|
const props = {
|
|
completedOnboarding: false,
|
|
isUnlocked: true,
|
|
seedPhraseBackedUp: null,
|
|
}
|
|
|
|
const wrapper = mountWithRouter(
|
|
<FirstTimeFlowSwitch.WrappedComponent {...props} />,
|
|
)
|
|
|
|
assert.equal(
|
|
wrapper.find('Lifecycle').find({ to: { pathname: LOCK_ROUTE } }).length,
|
|
1,
|
|
)
|
|
})
|
|
|
|
it('redirects to /welcome route when isInitialized is false', function () {
|
|
const props = {
|
|
completedOnboarding: false,
|
|
isUnlocked: false,
|
|
isInitialized: false,
|
|
seedPhraseBackedUp: null,
|
|
}
|
|
|
|
const wrapper = mountWithRouter(
|
|
<FirstTimeFlowSwitch.WrappedComponent {...props} />,
|
|
)
|
|
|
|
assert.equal(
|
|
wrapper
|
|
.find('Lifecycle')
|
|
.find({ to: { pathname: INITIALIZE_WELCOME_ROUTE } }).length,
|
|
1,
|
|
)
|
|
})
|
|
|
|
it('redirects to /unlock route when isInitialized is true', function () {
|
|
const props = {
|
|
completedOnboarding: false,
|
|
isUnlocked: false,
|
|
isInitialized: true,
|
|
seedPhraseBackedUp: null,
|
|
}
|
|
|
|
const wrapper = mountWithRouter(
|
|
<FirstTimeFlowSwitch.WrappedComponent {...props} />,
|
|
)
|
|
|
|
assert.equal(
|
|
wrapper
|
|
.find('Lifecycle')
|
|
.find({ to: { pathname: INITIALIZE_UNLOCK_ROUTE } }).length,
|
|
1,
|
|
)
|
|
})
|
|
})
|