2019-12-07 21:02:00 +02:00
|
|
|
import expect from 'app/test/unexpected';
|
2016-10-30 14:12:49 +02:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
import { updateToken } from './actions';
|
2020-01-17 23:37:52 +03:00
|
|
|
import { add, remove, activate, reset } from './actions/pure-actions';
|
|
|
|
import { AccountsState } from './index';
|
2019-12-07 13:28:52 +02:00
|
|
|
import accounts, { Account } from './reducer';
|
2016-10-30 14:12:49 +02:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
const account: Account = {
|
2019-11-27 11:03:32 +02:00
|
|
|
id: 1,
|
|
|
|
username: 'username',
|
|
|
|
email: 'email@test.com',
|
|
|
|
token: 'foo',
|
2019-12-07 13:28:52 +02:00
|
|
|
} as Account;
|
2016-10-30 14:12:49 +02:00
|
|
|
|
|
|
|
describe('Accounts reducer', () => {
|
2020-01-17 23:37:52 +03:00
|
|
|
let initial: AccountsState;
|
2016-10-30 14:12:49 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
beforeEach(() => {
|
2019-12-07 13:28:52 +02:00
|
|
|
initial = accounts(undefined, {} as any);
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2016-10-30 14:12:49 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should be empty', () =>
|
2019-12-07 13:28:52 +02:00
|
|
|
expect(accounts(undefined, {} as any), 'to equal', {
|
2019-11-27 11:03:32 +02:00
|
|
|
active: null,
|
|
|
|
available: [],
|
2016-10-30 14:12:49 +02:00
|
|
|
}));
|
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should return last state if unsupported action', () =>
|
2019-12-07 13:28:52 +02:00
|
|
|
expect(accounts({ state: 'foo' } as any, {} as any), 'to equal', {
|
|
|
|
state: 'foo',
|
|
|
|
}));
|
2016-11-05 12:11:41 +02:00
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
describe('accounts:activate', () => {
|
2019-11-27 11:03:32 +02:00
|
|
|
it('sets active account', () => {
|
|
|
|
expect(accounts(initial, activate(account)), 'to satisfy', {
|
|
|
|
active: account.id,
|
|
|
|
});
|
2016-10-30 14:12:49 +02:00
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
describe('accounts:add', () => {
|
2019-11-27 11:03:32 +02:00
|
|
|
it('adds an account', () =>
|
|
|
|
expect(accounts(initial, add(account)), 'to satisfy', {
|
|
|
|
available: [account],
|
|
|
|
}));
|
|
|
|
|
|
|
|
it('should replace if account was added for the second time', () => {
|
|
|
|
const outdatedAccount = {
|
|
|
|
...account,
|
|
|
|
someShit: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
const updatedAccount = {
|
|
|
|
...account,
|
|
|
|
token: 'newToken',
|
|
|
|
};
|
|
|
|
|
|
|
|
expect(
|
|
|
|
accounts(
|
|
|
|
{ ...initial, available: [outdatedAccount] },
|
|
|
|
add(updatedAccount),
|
|
|
|
),
|
|
|
|
'to satisfy',
|
|
|
|
{
|
|
|
|
available: [updatedAccount],
|
|
|
|
},
|
|
|
|
);
|
2016-10-30 14:12:49 +02:00
|
|
|
});
|
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should sort accounts by username', () => {
|
|
|
|
const newAccount = {
|
|
|
|
...account,
|
|
|
|
id: 2,
|
|
|
|
username: 'abc',
|
|
|
|
};
|
|
|
|
|
|
|
|
expect(
|
|
|
|
accounts({ ...initial, available: [account] }, add(newAccount)),
|
|
|
|
'to satisfy',
|
|
|
|
{
|
|
|
|
available: [newAccount, account],
|
|
|
|
},
|
|
|
|
);
|
2016-11-05 12:11:41 +02:00
|
|
|
});
|
2016-10-30 14:12:49 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('throws, when account is invalid', () => {
|
|
|
|
expect(
|
2019-12-07 13:28:52 +02:00
|
|
|
() =>
|
|
|
|
accounts(
|
|
|
|
initial,
|
|
|
|
// @ts-ignore
|
|
|
|
add(),
|
|
|
|
),
|
2019-11-27 11:03:32 +02:00
|
|
|
'to throw',
|
|
|
|
'Invalid or empty payload passed for accounts.add',
|
|
|
|
);
|
2016-11-14 07:28:25 +02:00
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
describe('accounts:remove', () => {
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should remove an account', () =>
|
|
|
|
expect(
|
|
|
|
accounts({ ...initial, available: [account] }, remove(account)),
|
|
|
|
'to equal',
|
|
|
|
initial,
|
|
|
|
));
|
|
|
|
|
|
|
|
it('throws, when account is invalid', () => {
|
|
|
|
expect(
|
2019-12-07 13:28:52 +02:00
|
|
|
() =>
|
|
|
|
accounts(
|
|
|
|
initial,
|
|
|
|
// @ts-ignore
|
|
|
|
remove(),
|
|
|
|
),
|
2019-11-27 11:03:32 +02:00
|
|
|
'to throw',
|
|
|
|
'Invalid or empty payload passed for accounts.remove',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
describe('actions:reset', () => {
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should reset accounts state', () =>
|
|
|
|
expect(
|
|
|
|
accounts({ ...initial, available: [account] }, reset()),
|
|
|
|
'to equal',
|
|
|
|
initial,
|
|
|
|
));
|
|
|
|
});
|
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
describe('accounts:updateToken', () => {
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should update token', () => {
|
|
|
|
const newToken = 'newToken';
|
|
|
|
|
|
|
|
expect(
|
|
|
|
accounts(
|
|
|
|
{ active: account.id, available: [account] },
|
|
|
|
updateToken(newToken),
|
|
|
|
),
|
|
|
|
'to satisfy',
|
|
|
|
{
|
|
|
|
active: account.id,
|
|
|
|
available: [
|
|
|
|
{
|
|
|
|
...account,
|
|
|
|
token: newToken,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
);
|
2016-10-30 14:12:49 +02:00
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2016-10-30 14:12:49 +02:00
|
|
|
});
|