mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-12 03:54:13 +00:00
67b2e6491c
* Refactor BaseNode to be an interface INode * Initial contract commit * Remove redundant fallback ABI function * First working iteration of Contract generator to be used in ENS branch * Hide abi to clean up logging output * Strip 0x prefix from output decode * Handle unnamed output params * Implement ability to supply output mappings to ABI functions * Fix null case in outputMapping * Add flow typing * Add .call method to functions * Partial commit for type refactor * Temp contract type fix -- waiting for NPM modularization * Remove empty files * Cleanup contract * Add call request to node interface * Fix output mapping types * Revert destructuring overboard * Add sendCallRequest to rpcNode class and add typing * Use enum for selecting ABI methods * Add transaction capability to contracts * Cleanup privaite/public members * Remove broadcasting step from a contract transaction * Cleanup uneeded types * Refactor ens-base to typescript and add typings for ENS smart contracts * Migrate ens-name-search to TS * Add IResolveDomainRequest * Fix rest of TSC errors * Add definition file for bn.js * Remove types-bn * Fix some typings * make isBN a static property * progress commit -- swap out bignumber.js for bn.js * Swap out bignumber for bn in vendor * Change modn to number return * Start to strip out units lib for a string manipulation based lib * Convert codebase to only base units * Get rid of useless component * Handle only wei in values * Use unit conversion in sidebar * Automatically strip hex prefix, and handle decimal edge case * Handle base 16 wei in transactions * Make a render callback component for dealing with unit conversion * Switch contracts to use bn.js, and get transaction values from signedTx instead of state * Get send transaction working with bn.js * Remove redundant hex stripping, return base value of tokens * Cleanup unit file * Re-implement toFixed for strings * Use formatNumber in codebase * Cleanup code * Undo package test changes * Update snapshot and remove console logs * Use TokenValue / Wei more consistently where applicable * Add typing to deterministicWallets, fix confirmation modal, make UnitDisplay more flexible * Split different ENS modes into their own components * Fix Abi typedef * Remove redundant moment type package * Add Aux helper component * Split out resolve components * Make 'to' parameter optional * Change import type * Change typing to be base domain request * Split handling of resolving into object handler * Fix countdown component * Adjust element spacing * Implement reveal search functionality * Add unit display for highest bidder * Fill out forbidden/NYA modes * ENS wallet component skeleton * Clean up prop handling in UnitDisplay * Change instanceof to typeof check, change boolean of displayBalance * Add ENS wallet component * Cleanup spacing * Convert ConfModal for bidding in ENS * Make ui component for placing bids * Fix destructure in placeBid * Pass through entire wallet * Remove text center * Display inline notification ENS isValid & add some ENS tests * Add export of Aux * Reformat with prettier * progress... * Add ENSUnlockLayout * Add RevealBid component * organize NameResolve components * Merge ENS with transaction-refactor changes * Fix address resolution * Update styles * convert ens name to lowercase before checking * Add overflow-y:scroll to table * update ens snapshots & tests * cast 'undefined' state argument as any for testing * clean up components * Connect unitconverter to redux state * remove unnecessary type assertion * fix spinner size * remove old bidmodal * validate bidmask before opening modal * progress... * Update styles * Add saga / actions for placing a bid * Update types & clean up dead code * Delete old test * Dispatch PlaceBidRequested acitons * Progress commit -- get ENS bidding ready for tx generation via sagas * Seperate ENS action creators and types * Add reducer & actions for ENS fields * Add preliminary sagas for bid mask and bid value * Initial commit * Add loading indicator * Remove some bidding components * Revert bidding files * Remove more bidding code * Remove rest of bidding code * Fix ENS error message * Revert value saga changes * Remove error param from setting 'To' field * Fix existing ENS test * Cleanup address resolution, remove dead code * Remove error messages from unimplemented ENS * Fix last character being not set bug * Remove error state from Meta * Rename isGenesisAddress to isCreationAddress
65 lines
1.6 KiB
TypeScript
65 lines
1.6 KiB
TypeScript
import { deterministicWallets, INITIAL_STATE } from 'reducers/deterministicWallets';
|
|
import * as dWalletActions from 'actions/deterministicWallets';
|
|
import { TokenValue } from 'libs/units';
|
|
|
|
describe('deterministicWallets reducer', () => {
|
|
const tokenValues: dWalletActions.ITokenValues = {
|
|
OMG: {
|
|
value: TokenValue('0'),
|
|
decimal: 16
|
|
}
|
|
};
|
|
|
|
const wallet: dWalletActions.DeterministicWalletData = {
|
|
index: 0,
|
|
address: 'address',
|
|
value: TokenValue('0'),
|
|
tokenValues
|
|
};
|
|
|
|
it('should handle DW_SET_WALLETS', () => {
|
|
const wallets = [wallet];
|
|
expect(
|
|
deterministicWallets(undefined, dWalletActions.setDeterministicWallets(wallets))
|
|
).toEqual({
|
|
...INITIAL_STATE,
|
|
wallets
|
|
});
|
|
});
|
|
|
|
it('should handle DW_SET_DESIRED_TOKEN', () => {
|
|
const desiredToken = 'OMG';
|
|
expect(deterministicWallets(undefined, dWalletActions.setDesiredToken(desiredToken))).toEqual({
|
|
...INITIAL_STATE,
|
|
desiredToken
|
|
});
|
|
});
|
|
|
|
it('should handle DW_UPDATE_WALLET', () => {
|
|
const wallet1 = {
|
|
...wallet,
|
|
address: 'wallet1'
|
|
};
|
|
const wallet2 = {
|
|
...wallet,
|
|
address: 'wallet2'
|
|
};
|
|
const wallets = [wallet1, wallet2];
|
|
const state = deterministicWallets(undefined, dWalletActions.setDeterministicWallets(wallets));
|
|
|
|
const wallet2Update = {
|
|
...wallet,
|
|
index: 100,
|
|
address: 'wallet2',
|
|
value: TokenValue('100')
|
|
};
|
|
|
|
expect(
|
|
deterministicWallets(state, dWalletActions.updateDeterministicWallet(wallet2Update))
|
|
).toEqual({
|
|
...INITIAL_STATE,
|
|
wallets: [wallet1, wallet2Update]
|
|
});
|
|
});
|
|
});
|