diff options
Diffstat (limited to 'ui/app/ducks/tests/confirm-transaction.duck.test.js')
| -rw-r--r-- | ui/app/ducks/tests/confirm-transaction.duck.test.js | 70 | 
1 files changed, 50 insertions, 20 deletions
| diff --git a/ui/app/ducks/tests/confirm-transaction.duck.test.js b/ui/app/ducks/tests/confirm-transaction.duck.test.js index 111674e33..1bab0add0 100644 --- a/ui/app/ducks/tests/confirm-transaction.duck.test.js +++ b/ui/app/ducks/tests/confirm-transaction.duck.test.js @@ -1,6 +1,7 @@  import assert from 'assert'  import configureMockStore from 'redux-mock-store'  import thunk from 'redux-thunk' +import sinon from 'sinon'  import ConfirmTransactionReducer, * as actions from '../confirm-transaction.duck.js' @@ -20,7 +21,8 @@ const initialState = {    ethTransactionTotal: '',    hexGasTotal: '',    nonce: '', -  fetchingMethodData: false, +  toSmartContract: false, +  fetchingData: false,  }  const UPDATE_TX_DATA = 'metamask/confirm-transaction/UPDATE_TX_DATA' @@ -35,8 +37,9 @@ const UPDATE_TRANSACTION_TOTALS = 'metamask/confirm-transaction/UPDATE_TRANSACTI  const UPDATE_HEX_GAS_TOTAL = 'metamask/confirm-transaction/UPDATE_HEX_GAS_TOTAL'  const UPDATE_TOKEN_PROPS = 'metamask/confirm-transaction/UPDATE_TOKEN_PROPS'  const UPDATE_NONCE = 'metamask/confirm-transaction/UPDATE_NONCE' -const FETCH_METHOD_DATA_START = 'metamask/confirm-transaction/FETCH_METHOD_DATA_START' -const FETCH_METHOD_DATA_END = 'metamask/confirm-transaction/FETCH_METHOD_DATA_END' +const UPDATE_TO_SMART_CONTRACT = 'metamask/confirm-transaction/UPDATE_TO_SMART_CONTRACT' +const FETCH_DATA_START = 'metamask/confirm-transaction/FETCH_DATA_START' +const FETCH_DATA_END = 'metamask/confirm-transaction/FETCH_DATA_END'  const CLEAR_CONFIRM_TRANSACTION = 'metamask/confirm-transaction/CLEAR_CONFIRM_TRANSACTION'  describe('Confirm Transaction Duck', () => { @@ -64,7 +67,8 @@ describe('Confirm Transaction Duck', () => {          ethTransactionTotal: '469.27',          hexGasTotal: '0x1319718a5000',          nonce: '0x0', -        fetchingMethodData: false, +        toSmartContract: false, +        fetchingData: false,        },      } @@ -271,30 +275,43 @@ describe('Confirm Transaction Duck', () => {        )      }) -    it('should set fetchingMethodData to true when receiving a FETCH_METHOD_DATA_START action', () => { +    it('should update nonce when receiving an UPDATE_TO_SMART_CONTRACT action', () => {        assert.deepEqual(          ConfirmTransactionReducer(mockState, { -          type: FETCH_METHOD_DATA_START, +          type: UPDATE_TO_SMART_CONTRACT, +          payload: true,          }),          {            ...mockState.confirmTransaction, -          fetchingMethodData: true, +          toSmartContract: true,          }        )      }) -    it('should set fetchingMethodData to false when receiving a FETCH_METHOD_DATA_END action', () => { +    it('should set fetchingData to true when receiving a FETCH_DATA_START action', () => {        assert.deepEqual( -        ConfirmTransactionReducer({ confirmTransaction: { fetchingMethodData: true } }, { -          type: FETCH_METHOD_DATA_END, +        ConfirmTransactionReducer(mockState, { +          type: FETCH_DATA_START,          }),          { -          fetchingMethodData: false, +          ...mockState.confirmTransaction, +          fetchingData: true,          }        )      }) -    it('should clear confirmTransaction when receiving a FETCH_METHOD_DATA_END action', () => { +    it('should set fetchingData to false when receiving a FETCH_DATA_END action', () => { +      assert.deepEqual( +        ConfirmTransactionReducer({ confirmTransaction: { fetchingData: true } }, { +          type: FETCH_DATA_END, +        }), +        { +          fetchingData: false, +        } +      ) +    }) + +    it('should clear confirmTransaction when receiving a FETCH_DATA_END action', () => {        assert.deepEqual(          ConfirmTransactionReducer(mockState, {            type: CLEAR_CONFIRM_TRANSACTION, @@ -460,24 +477,24 @@ describe('Confirm Transaction Duck', () => {        )      }) -    it('should create an action to set fetchingMethodData to true', () => { +    it('should create an action to set fetchingData to true', () => {        const expectedAction = { -        type: FETCH_METHOD_DATA_START, +        type: FETCH_DATA_START,        }        assert.deepEqual( -        actions.setFetchingMethodData(true), +        actions.setFetchingData(true),          expectedAction        )      }) -    it('should create an action to set fetchingMethodData to false', () => { +    it('should create an action to set fetchingData to false', () => {        const expectedAction = { -        type: FETCH_METHOD_DATA_END, +        type: FETCH_DATA_END,        }        assert.deepEqual( -        actions.setFetchingMethodData(false), +        actions.setFetchingData(false),          expectedAction        )      }) @@ -495,6 +512,18 @@ describe('Confirm Transaction Duck', () => {    })    describe('Thunk actions', done => { +    beforeEach(() => { +      global.eth = { +        getCode: sinon.stub().callsFake( +          address => Promise.resolve(address && address.match(/isContract/) ? 'not-0x' : '0x') +        ), +      } +    }) + +    afterEach(() => { +      global.eth.getCode.resetHistory() +    }) +      it('updates txData and gas on an existing transaction in confirmTransaction', () => {        const mockState = {          metamask: { @@ -505,7 +534,7 @@ describe('Confirm Transaction Duck', () => {            ethTransactionAmount: '1',            ethTransactionFee: '0.000021',            ethTransactionTotal: '1.000021', -          fetchingMethodData: false, +          fetchingData: false,            fiatTransactionAmount: '469.26',            fiatTransactionFee: '0.01',            fiatTransactionTotal: '469.27', @@ -581,7 +610,7 @@ describe('Confirm Transaction Duck', () => {            ethTransactionAmount: '1',            ethTransactionFee: '0.000021',            ethTransactionTotal: '1.000021', -          fetchingMethodData: false, +          fetchingData: false,            fiatTransactionAmount: '469.26',            fiatTransactionFee: '0.01',            fiatTransactionTotal: '469.27', @@ -667,6 +696,7 @@ describe('Confirm Transaction Duck', () => {          .then(() => {            const storeActions = store.getActions()            assert.equal(storeActions.length, expectedActions.length) +            storeActions.forEach((action, index) => assert.equal(action.type, expectedActions[index]))            done()          }) | 
