Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Increase unit test coverage of reducers - Closes #456 #501

Merged
merged 12 commits into from
Mar 6, 2018
3 changes: 0 additions & 3 deletions karma.conf.js
Original file line number Diff line number Diff line change
Expand Up @@ -58,9 +58,6 @@ module.exports = function (config) {
'src/components/setting/index.js',
'src/components/setting/setting.js',
'src/components/menuBar/menuBar.js',
'src/store/reducers/voting.js',
'src/store/reducers/transactions.js',
'src/store/reducers/savedAccounts.js',
'src/store/middlewares/account.js',
'src/store/middlewares/login.js',
'src/store/middlewares/peers.js',
Expand Down
38 changes: 38 additions & 0 deletions src/store/reducers/savedAccounts.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,28 @@ describe('Reducer: savedAccounts(state, action)', () => {
expect(changedState).to.deep.equal(action.data);
});

it('should update corresponding account phassprasse when saving account', () => {
const state = { accounts: [account, account2], lastActive: [] };
const action = {
type: actionTypes.accountSaved,
data: {
...account,
passphrase: accounts.genesis.passphrase,
balance: 0,
},
};
const accountUpdatedWithPassphrase = { ...state };
accountUpdatedWithPassphrase.accounts[0] = {
...accountUpdatedWithPassphrase.accounts[0],
passphrase: accounts.genesis.passphrase,
balance: 0,
};
accountUpdatedWithPassphrase.lastActive = accountUpdatedWithPassphrase.accounts[0];

const changedState = savedAccounts(state, action);
expect(changedState).to.deep.equal(accountUpdatedWithPassphrase);
});

it('should return action.data with address if action.type = actionTypes.accountSaved', () => {
const state = { accounts: [] };
const action = {
Expand Down Expand Up @@ -59,5 +81,21 @@ describe('Reducer: savedAccounts(state, action)', () => {
delete account2WithoutPassphrase.passphrase;
expect(changedState).to.deep.equal({ accounts: [account, account2WithoutPassphrase] });
});

it('should update corresponding account passprasse when a passphrase is used', () => {
const state = {
accounts: [account, account2],
lastActive: account2,
};
const action = {
type: actionTypes.passphraseUsed,
data: accounts.genesis.passphrase,
};
const accountsUpdated = savedAccounts(state, action);
const accountPreserved = accountsUpdated.accounts[0];
const accountsWithPassphraseUpdated = accountsUpdated.accounts[1];
expect(accountPreserved).to.deep.equal(account);
expect(accountsWithPassphraseUpdated.passphrase).to.deep.equal(accounts.genesis.passphrase);
});
});

16 changes: 16 additions & 0 deletions src/store/reducers/transactions.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,22 @@ describe('Reducer: transactions(state, action)', () => {
expect(changedState).to.deep.equal({ ...state, failed: { errorMessage } });
});

it('should filter out failed transactions from pending', () => {
const state = {
...defaultState,
pending: [mockTransactions[1]],
};
const data = {
failed: [mockTransactions[1]],
};
const action = {
data,
type: actionTypes.transactionsFailed,
};
const pendingTransactionsFiltered = transactions(state, action);
const stateWithNoPendingTransactions = { ...defaultState };
expect(pendingTransactionsFiltered).to.deep.equal(stateWithNoPendingTransactions);
});

it('should concat action.data to state.confirmed if action.type = actionTypes.transactionsLoaded', () => {
const state = { ...defaultState };
Expand Down
119 changes: 119 additions & 0 deletions src/store/reducers/voting.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,12 @@ import voting from './voting';

describe('Reducer: voting(state, action)', () => {
const initialState = { votes: {}, delegates: [], refresh: true };
const defaultVoteUserData = {
confirmed: true,
unconfirmed: true,
pending: false,
publicKey: 'sample_key',
};
const cleanVotes = {
username1: { confirmed: false, unconfirmed: false, publicKey: 'sample_key' },
username2: { confirmed: true, unconfirmed: true, publicKey: 'sample_key' },
Expand All @@ -19,6 +25,7 @@ describe('Reducer: voting(state, action)', () => {
username2: { confirmed: true, unconfirmed: true, pending: false, publicKey: 'sample_key' },
username3: { confirmed: false, unconfirmed: false, pending: false, publicKey: 'sample_key' },
};

const restoredVotes = {
username1: { confirmed: false, unconfirmed: false, pending: false, publicKey: 'sample_key' },
username2: { confirmed: true, unconfirmed: true, pending: false, publicKey: 'sample_key' },
Expand Down Expand Up @@ -182,6 +189,118 @@ describe('Reducer: voting(state, action)', () => {
expect(changedState).to.be.deep.equal(expectedState);
});

it('should update new username in votes when we\'ve voted but it\'s not in the new list', () => {
const action = {
type: actionTypes.votesUpdated,
data: {
list: [{ username: 'username5', publicKey: 'sample_key' }],
},
};
const votedButNotYetInList = {
username1: { confirmed: true, unconfirmed: true, pending: true, publicKey: 'sample_key' },
};
const state = {
votes: { ...votedButNotYetInList },
};
const newUserNameRegisteredInVotes = {
votes: {
...votedButNotYetInList,
username5: { ...defaultVoteUserData },
},
refresh: false,
};
const saveNewUserInVotes = voting(state, action);
expect(saveNewUserInVotes).to.be.deep.equal(newUserNameRegisteredInVotes);
});

it('should not change votes, when we\'ve un-voted but user still exists in the new list', () => {
const updateVotesWithExistingUsernameAction = {
type: actionTypes.votesUpdated,
data: {
list: [{ username: 'username1', publicKey: 'sample_key' }],
},
};
const updateVotesUnvotedWithExistingUsername = {
username1: { confirmed: true, unconfirmed: false, pending: true, publicKey: 'sample_key' },
};
const state = {
votes: { ...updateVotesUnvotedWithExistingUsername },
};
const notChangedVotesRecords = {
votes: { ...updateVotesUnvotedWithExistingUsername },
refresh: false,
};

const changedState = voting(state, updateVotesWithExistingUsernameAction);
expect(changedState).to.be.deep.equal(notChangedVotesRecords);
});

it('should add new record of username in votes, when dirty and not voted for and username not yet in the new list', () => {
const action = {
type: actionTypes.votesUpdated,
data: {
list: [{ username: 'username5', publicKey: 'sample_key' }],
},
};
const updateVotesDirtyNotVotedNotExistingUsername = {
username1: { confirmed: true, unconfirmed: false, pending: false, publicKey: 'sample_key' },
};
const state = {
votes: { ...updateVotesDirtyNotVotedNotExistingUsername },
};
const newUsernameAddedToVotes = {
votes: {
...updateVotesDirtyNotVotedNotExistingUsername,
username5: { ...defaultVoteUserData },
},
refresh: false,
};
const changedState = voting(state, action);
expect(changedState).to.be.deep.equal(newUsernameAddedToVotes);
});

it('should keep record of username in votes, when dirty and not voted for and username is already in the new list', () => {
const action = {
type: actionTypes.votesUpdated,
data: {
list: [{ username: 'username1', publicKey: 'sample_key' }],
},
};
const updateVotesDirtyNotVotedExistingUsername = {
username1: { confirmed: true, unconfirmed: false, pending: false, publicKey: 'sample_key' },
};
const state = {
votes: { ...updateVotesDirtyNotVotedExistingUsername },
};
const votesRecordsUnchanged = {
votes: { ...updateVotesDirtyNotVotedExistingUsername },
refresh: false,
};
const changedState = voting(state, action);
expect(changedState).to.be.deep.equal(votesRecordsUnchanged);
});

it('should set default (confirmed, unconfirmed, pending) values on username vote records, when non of previous cases are met', () => {
const action = {
type: actionTypes.votesUpdated,
data: {
list: [{ username: 'username1', publicKey: 'sample_key' }],
},
};
const updateVotesNonConditionsMet = {
username1: { confirmed: true, unconfirmed: true, pending: true, publicKey: 'sample_key' },
};
const state = {
votes: { ...updateVotesNonConditionsMet },
};
const votesRecordsWithDefaultFlags = {
votes: { username1: { ...defaultVoteUserData } },
refresh: false,
};
const changedState = voting(state, action);
expect(changedState).to.be.deep.equal(votesRecordsWithDefaultFlags);
});

it('should set voteLookupStatus of given username to given status, with action: voteLookupStatusUpdated', () => {
const action = {
type: actionTypes.voteLookupStatusUpdated,
Expand Down