From 03d4182dfbb7b6611dca05416115a05c9c51f201 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABtan=20Renaudeau?= Date: Sat, 26 May 2018 13:16:33 +0200 Subject: [PATCH] add Debug modal to stress-test things / display useful data for devs --- src/components/TopBar/index.js | 12 ++++ src/components/modals/Debug.js | 103 +++++++++++++++++++++++++++++++++ src/components/modals/index.js | 1 + 3 files changed, 116 insertions(+) create mode 100644 src/components/modals/Debug.js diff --git a/src/components/TopBar/index.js b/src/components/TopBar/index.js index 57f2edab..76452029 100644 --- a/src/components/TopBar/index.js +++ b/src/components/TopBar/index.js @@ -13,6 +13,7 @@ import type { T } from 'types/common' import { rgba } from 'styles/helpers' import { lock } from 'reducers/application' import { hasPassword } from 'reducers/settings' +import { openModal } from 'reducers/modals' import IconDevices from 'icons/Devices' import IconLock from 'icons/Lock' @@ -57,6 +58,7 @@ const mapStateToProps = state => ({ const mapDispatchToProps = { lock, + openModal, } type Props = { @@ -64,9 +66,12 @@ type Props = { history: RouterHistory, location: Location, lock: Function, + openModal: string => void, t: T, } +let settingsClickTimes = [] + class TopBar extends PureComponent { handleLock = () => this.props.lock() @@ -74,6 +79,13 @@ class TopBar extends PureComponent { const { location, history } = this.props const url = '/settings' + const now = Date.now() + settingsClickTimes = settingsClickTimes.filter(t => now - t < 3000).concat(now) + if (settingsClickTimes.length === 7) { + settingsClickTimes = [] + this.props.openModal('MODAL_DEBUG') + } + if (location.pathname !== url) { history.push(url) } diff --git a/src/components/modals/Debug.js b/src/components/modals/Debug.js new file mode 100644 index 00000000..ae6769e0 --- /dev/null +++ b/src/components/modals/Debug.js @@ -0,0 +1,103 @@ +// @flow +import { getCryptoCurrencyById } from '@ledgerhq/live-common/lib/helpers/currencies' +import last from 'lodash/last' +import React, { Component } from 'react' +import Modal, { ModalBody, ModalTitle, ModalContent } from 'components/base/Modal' +import Button from 'components/base/Button' +import Box from 'components/base/Box' +import EnsureDevice from 'components/ManagerPage/EnsureDevice' +import { getDerivations } from 'helpers/derivations' +import getAddress from 'commands/getAddress' + +class Debug extends Component<*, *> { + state = { + logs: [], + } + + onClickStressDevice = (device: *) => async () => { + try { + const currency = getCryptoCurrencyById('bitcoin') + const derivation = last(getDerivations(currency)) + for (let x = 0; x < 20; x++) { + const obj = { + path: derivation({ currency, segwit: true, x }), + currencyId: currency.id, + devicePath: device.path, + } + + // we start one in parallel just to stress device even more. this test race condition! + getAddress.send(obj) + getAddress.send(obj) + + const { address, path } = await getAddress.send(obj).toPromise() + + this.log(`derivated ${path} = ${address}`) + } + } catch (e) { + this.error(e) + } + } + + onHide = () => { + this.setState({ logs: [] }) + } + + log = (txt: string) => { + this.setState(({ logs }) => ({ logs: logs.concat({ txt, type: 'log' }) })) + } + + error = (e: Error) => { + this.setState(({ logs }) => ({ + logs: logs.concat({ txt: String((e && e.message) || e), type: 'error' }), + })) + } + + render() { + const { logs } = this.state + return ( + ( + + DEBUG utils + + + {device => ( + + + + )} + + + {logs.map(log => ( + + {log.txt} + + ))} + + + + )} + /> + ) + } +} + +export default Debug diff --git a/src/components/modals/index.js b/src/components/modals/index.js index 47c450cc..5f286eef 100644 --- a/src/components/modals/index.js +++ b/src/components/modals/index.js @@ -1,3 +1,4 @@ +export Debug from './Debug' export AddAccount from './AddAccount' export OperationDetails from './OperationDetails' export Receive from './Receive'