1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

Got test failing nearly correctly

This commit is contained in:
Dan Finlay 2017-05-15 15:07:38 -07:00
parent c4be4c7195
commit 4b341e6a95
3 changed files with 45 additions and 15 deletions

18
test/lib/mock-store.js Normal file
View File

@ -0,0 +1,18 @@
const createStore = require('redux').createStore
const applyMiddleware = require('redux').applyMiddleware
const thunkMiddleware = require('redux-thunk')
const createLogger = require('redux-logger')
const rootReducer = function() {}
module.exports = configureStore
const loggerMiddleware = createLogger()
const createStoreWithMiddleware = applyMiddleware(
thunkMiddleware,
loggerMiddleware
)(createStore)
function configureStore (initialState) {
return createStoreWithMiddleware(rootReducer, initialState)
}

View File

@ -1,11 +1,10 @@
const assert = require('assert') const assert = require('assert')
const additions = require('react-testutils-additions') const additions = require('react-testutils-additions')
const h = require('react-hyperscript') const h = require('react-hyperscript')
var PendingTx = require('../../../ui/app/components/pending-tx') const PendingTx = require('../../../ui/app/components/pending-tx')
const createReactFactory = require('create-react-factory').createReactFactory const createReactFactory = require('create-react-factory').createReactFactory
const React = require('react') const React = require('react')
console.dir(createReactFactory) const shallow = require('react-test-renderer/shallow')
const shallow = require('enzyme').shallow
const Factory = createReactFactory(PendingTx) const Factory = createReactFactory(PendingTx)
const ReactTestUtils = require('react-addons-test-utils') const ReactTestUtils = require('react-addons-test-utils')
@ -53,23 +52,27 @@ describe.only('PendingTx', function () {
} }
const pendingTxComponent = h(PendingTx, props) const pendingTxComponent = h(PendingTx, props)
var component = additions.renderIntoDocument(pendingTxComponent); const component = additions.renderIntoDocument(pendingTxComponent);
renderer.render(pendingTxComponent) renderer.render(pendingTxComponent)
const result = renderer.getRenderOutput() const result = renderer.getRenderOutput()
const form = result.props.children const form = result.props.children
console.log('FORM children')
console.dir(form.props.children)
const children = form.props.children[form.props.children.length - 1] const children = form.props.children[form.props.children.length - 1]
assert.equal(result.type, 'div', 'should create a div') assert.equal(result.type, 'div', 'should create a div')
console.dir(children)
console.log('finding input')
try{ try{
const input = additions.find(component, '.cell.row input[type="number"]') const input = additions.find(component, '.cell.row input[type="number"]')[1]
console.log('input') ReactTestUtils.Simulate.change(input, {
console.dir(input) target: {
value: 2,
checkValidity() { return true },
}
})
let form = additions.find(component, 'form')[0]
form.checkValidity = () => true
form.getFormEl = () => { return { checkValidity() { return true } } }
ReactTestUtils.Simulate.submit(form, { preventDefault() {}, target: { checkValidity() {return true} } })
} catch (e) { } catch (e) {
console.log("WHAAAA") console.log("WHAAAA")
@ -79,7 +82,6 @@ describe.only('PendingTx', function () {
const noop = () => {} const noop = () => {}
setTimeout(() => { setTimeout(() => {
console.log('timeout finished')
// Get the gas price input // Get the gas price input
// Set it to the newGasPrice value // Set it to the newGasPrice value
@ -91,7 +93,6 @@ describe.only('PendingTx', function () {
}, 200) }, 200)
console.log('calling render')
}) })
}) })

View File

@ -380,11 +380,22 @@ PendingTx.prototype.onSubmit = function (event) {
} }
PendingTx.prototype.checkValidity = function() { PendingTx.prototype.checkValidity = function() {
const form = document.querySelector('form#pending-tx-form') const form = this.getFormEl()
console.log("check validity got form el:")
console.dir(form)
const valid = form.checkValidity() const valid = form.checkValidity()
return valid return valid
} }
PendingTx.prototype.getFormEl = function() {
const form = document.querySelector('form#pending-tx-form')
// Stub out form for unit tests:
if (!form) {
return { checkValidity() { return true } }
}
return form
}
// After a customizable state value has been updated, // After a customizable state value has been updated,
PendingTx.prototype.gatherTxMeta = function () { PendingTx.prototype.gatherTxMeta = function () {
log.debug(`pending-tx gatherTxMeta`) log.debug(`pending-tx gatherTxMeta`)