Anastasia Poupeney 7 years ago
parent
commit
418bdcea61
  1. 9
      src/bridge/index.js
  2. 31
      src/bridge/makeMockBridge.js
  3. 9
      src/config/constants.js

9
src/bridge/index.js

@ -1,17 +1,24 @@
// @flow // @flow
import type { Currency } from '@ledgerhq/live-common/lib/types' import type { Currency } from '@ledgerhq/live-common/lib/types'
import invariant from 'invariant' import invariant from 'invariant'
import { USE_MOCK_DATA } from 'config/constants'
import { WalletBridge } from './types' import { WalletBridge } from './types'
import LibcoreBridge from './LibcoreBridge' import LibcoreBridge from './LibcoreBridge'
import EthereumJSBridge from './EthereumJSBridge' import EthereumJSBridge from './EthereumJSBridge'
import RippleJSBridge from './RippleJSBridge' import RippleJSBridge from './RippleJSBridge'
import makeMockBridge from './makeMockBridge'
const perFamily = { const perFamily = {
bitcoin: LibcoreBridge, bitcoin: LibcoreBridge,
ripple: RippleJSBridge, ripple: RippleJSBridge,
ethereum: EthereumJSBridge, ethereum: EthereumJSBridge,
} }
if (USE_MOCK_DATA) {
const mockBridge = makeMockBridge()
perFamily.bitcoin = mockBridge
perFamily.ethereum = mockBridge
perFamily.ripple = mockBridge
}
export const getBridgeForCurrency = (currency: Currency): WalletBridge<any> => { export const getBridgeForCurrency = (currency: Currency): WalletBridge<any> => {
const bridge = perFamily[currency.family] const bridge = perFamily[currency.family]
invariant(bridge, `${currency.id} currency is not supported`) invariant(bridge, `${currency.id} currency is not supported`)

31
src/bridge/makeMockBridge.js

@ -8,14 +8,19 @@ import {
} from '@ledgerhq/live-common/lib/mock/account' } from '@ledgerhq/live-common/lib/mock/account'
import { getOperationAmountNumber } from '@ledgerhq/live-common/lib/helpers/operation' import { getOperationAmountNumber } from '@ledgerhq/live-common/lib/helpers/operation'
import Prando from 'prando' import Prando from 'prando'
import { BigNumber } from 'bignumber.js'
import type { Operation } from '@ledgerhq/live-common/lib/types' import type { Operation } from '@ledgerhq/live-common/lib/types'
import { validateNameEdition } from 'helpers/accountName'
import { MOCK_DATA_SEED } from 'config/constants'
import type { WalletBridge } from './types' import type { WalletBridge } from './types'
const defaultOpts = { const defaultOpts = {
syncSuccessRate: 0.8,
scanAccountDeviceSuccessRate: 0.8, scanAccountDeviceSuccessRate: 0.8,
transactionsSizeTarget: 100, transactionsSizeTarget: 100,
extraInitialTransactionProps: () => null, extraInitialTransactionProps: () => null,
checkCanBeSpent: () => Promise.resolve(),
getTotalSpent: (a, t) => Promise.resolve(t.amount),
getMaxAmount: a => Promise.resolve(a.balance),
} }
const delay = ms => new Promise(success => setTimeout(success, ms)) const delay = ms => new Promise(success => setTimeout(success, ms))
@ -24,7 +29,6 @@ type Opts = *
function makeMockBridge(opts?: Opts): WalletBridge<*> { function makeMockBridge(opts?: Opts): WalletBridge<*> {
const { const {
syncSuccessRate,
transactionsSizeTarget, transactionsSizeTarget,
EditFees, EditFees,
EditAdvancedOptions, EditAdvancedOptions,
@ -42,6 +46,9 @@ function makeMockBridge(opts?: Opts): WalletBridge<*> {
const syncTimeouts = {} const syncTimeouts = {}
const substractOneYear = date =>
new Date(new Date(date).setFullYear(new Date(date).getFullYear() - 1))
return { return {
synchronize: initialAccount => synchronize: initialAccount =>
Observable.create(o => { Observable.create(o => {
@ -51,11 +58,11 @@ function makeMockBridge(opts?: Opts): WalletBridge<*> {
logger.warn('synchronize was called multiple pending time for same accounts!!!') logger.warn('synchronize was called multiple pending time for same accounts!!!')
} }
syncTimeouts[accountId] = setTimeout(() => { syncTimeouts[accountId] = setTimeout(() => {
if (Math.random() < syncSuccessRate) {
const ops = broadcasted[accountId] || [] const ops = broadcasted[accountId] || []
broadcasted[accountId] = [] broadcasted[accountId] = []
o.next(account => { o.next(account => {
account = { ...account } account = { ...account }
account.lastSyncDate = new Date()
account.blockHeight++ account.blockHeight++
for (const op of ops) { for (const op of ops) {
account.balance = account.balance.plus(getOperationAmountNumber(op)) account.balance = account.balance.plus(getOperationAmountNumber(op))
@ -63,11 +70,8 @@ function makeMockBridge(opts?: Opts): WalletBridge<*> {
return account return account
}) })
o.complete() o.complete()
} else {
o.error(new Error('Sync Failed'))
}
syncTimeouts[accountId] = null syncTimeouts[accountId] = null
}, 20000) }, 2000)
return () => { return () => {
clearTimeout(syncTimeouts[accountId]) clearTimeout(syncTimeouts[accountId])
@ -78,7 +82,6 @@ function makeMockBridge(opts?: Opts): WalletBridge<*> {
scanAccountsOnDevice: currency => scanAccountsOnDevice: currency =>
Observable.create(o => { Observable.create(o => {
let unsubscribed = false let unsubscribed = false
async function job() { async function job() {
if (Math.random() > scanAccountDeviceSuccessRate) { if (Math.random() > scanAccountDeviceSuccessRate) {
await delay(1000) await delay(1000)
@ -88,11 +91,19 @@ function makeMockBridge(opts?: Opts): WalletBridge<*> {
const nbAccountToGen = 3 const nbAccountToGen = 3
for (let i = 0; i < nbAccountToGen && !unsubscribed; i++) { for (let i = 0; i < nbAccountToGen && !unsubscribed; i++) {
await delay(500) await delay(500)
const account = genAccount(String(Math.random()), { const account = genAccount(`${MOCK_DATA_SEED}_${currency.id}_${i}`, {
operationsSize: 0, operationsSize: 0,
currency, currency,
}) })
account.unit = currency.units[0] account.unit = currency.units[0]
account.index = i
account.operations = account.operations.map(operation => ({
...operation,
date: substractOneYear(operation.date),
}))
account.name = ''
account.name = validateNameEdition(account)
if (!unsubscribed) o.next(account) if (!unsubscribed) o.next(account)
} }
if (!unsubscribed) o.complete() if (!unsubscribed) o.complete()
@ -120,7 +131,7 @@ function makeMockBridge(opts?: Opts): WalletBridge<*> {
isRecipientValid: (currency, recipient) => Promise.resolve(recipient.length > 0), isRecipientValid: (currency, recipient) => Promise.resolve(recipient.length > 0),
createTransaction: () => ({ createTransaction: () => ({
amount: 0, amount: BigNumber(0),
recipient: '', recipient: '',
...extraInitialTransactionProps(), ...extraInitialTransactionProps(),
}), }),

9
src/config/constants.js

@ -5,6 +5,13 @@ const intFromEnv = (key: string, def: number): number => {
if (!isNaN(v)) return parseInt(v, 10) if (!isNaN(v)) return parseInt(v, 10)
return def return def
} }
const floatFromEnv = (key: string, def: number): number => {
const v = process.env[key]
if (!isNaN(v)) return parseFloat(v)
return def
}
const boolFromEnv = (key: string, def: boolean = false): boolean => { const boolFromEnv = (key: string, def: boolean = false): boolean => {
const v = process.env[key] const v = process.env[key]
if (typeof v === 'string') return !(v === '0' || v === 'false') if (typeof v === 'string') return !(v === '0' || v === 'false')
@ -87,6 +94,7 @@ export const EXPERIMENTAL_TOOLS_SETTINGS = boolFromEnv('EXPERIMENTAL_TOOLS_SETTI
export const EXPERIMENTAL_MARKET_INDICATOR_SETTINGS = boolFromEnv( export const EXPERIMENTAL_MARKET_INDICATOR_SETTINGS = boolFromEnv(
'EXPERIMENTAL_MARKET_INDICATOR_SETTINGS', 'EXPERIMENTAL_MARKET_INDICATOR_SETTINGS',
) )
export const USE_MOCK_DATA = boolFromEnv('USE_MOCK_DATA')
// Other constants // Other constants
@ -103,3 +111,4 @@ export const MODAL_TECHNICAL_DATA = 'MODAL_TECHNICAL_DATA'
export const MODAL_DISCLAIMER = 'MODAL_DISCLAIMER' export const MODAL_DISCLAIMER = 'MODAL_DISCLAIMER'
export const MODAL_DISCLAIMER_DELAY = 1 * 1000 export const MODAL_DISCLAIMER_DELAY = 1 * 1000
export const MOCK_DATA_SEED = floatFromEnv('MOCK_DATA_SEED', Math.random())

Loading…
Cancel
Save