1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/app/pages/unlock-page/tests/unlock-page.test.js
Thomas Huang 5d1c9313db
Various component tests and some conditional statements (#7765)
* Various component tests and some conditional statements

Conditional in account-menu in removeAccount when keyring sometimes is not initially provideed
Conditional on unlock-page when there is no target.getBoundingClientRect on the element.

* Update helpers

* Remove component debugging

* Add default params for render helpers

* Remove stubComponent for old Mascot
Changes in https://github.com/MetaMask/metamask-extension/pull/7893 has prevented the need to stub it out.

Change logout to lock in account-menu test
2020-01-30 11:34:45 -08:00

70 lines
1.6 KiB
JavaScript

import React from 'react'
import assert from 'assert'
import sinon from 'sinon'
import { mount } from 'enzyme'
import UnlockPage from '../index'
describe('Unlock Page', () => {
let wrapper
const props = {
history: {
push: sinon.spy(),
},
isUnlocked: false,
onImport: sinon.spy(),
onRestore: sinon.spy(),
onSubmit: sinon.spy(),
forceUpdateMetamaskState: sinon.spy(),
showOptInModal: sinon.spy(),
}
beforeEach(() => {
wrapper = mount(
<UnlockPage.WrappedComponent{...props} />, {
context: {
t: str => str,
},
}
)
})
after(() => {
sinon.restore()
})
it('renders', () => {
assert.equal(wrapper.length, 1)
})
it('changes password and submits', () => {
const passwordField = wrapper.find({ type: 'password', id: 'password' })
const loginButton = wrapper.find({ type: 'submit' }).last()
const event = { target: { value: 'password' } }
assert.equal(wrapper.instance().state.password, '')
passwordField.last().simulate('change', event)
assert.equal(wrapper.instance().state.password, 'password')
loginButton.simulate('click')
assert(props.onSubmit.calledOnce)
})
it('clicks imports seed button', () => {
const importSeedButton = wrapper.find('.unlock-page__link--import')
importSeedButton.simulate('click')
assert(props.onImport.calledOnce)
})
it('clicks restore', () => {
const restoreFromSeedButton = wrapper.find('.unlock-page__link').at(0)
restoreFromSeedButton.simulate('click')
assert(props.onRestore.calledOnce)
})
})