111 lines
3.3 KiB
JavaScript
111 lines
3.3 KiB
JavaScript
import reducer from '../auth';
|
|
import { Map as ImmutableMap, fromJS } from 'immutable';
|
|
import {
|
|
AUTH_APP_CREATED,
|
|
AUTH_LOGGED_IN,
|
|
VERIFY_CREDENTIALS_FAIL,
|
|
} from 'soapbox/actions/auth';
|
|
|
|
describe('auth reducer', () => {
|
|
it('should return the initial state', () => {
|
|
expect(reducer(undefined, {})).toEqual(ImmutableMap({
|
|
app: ImmutableMap(),
|
|
users: ImmutableMap(),
|
|
tokens: ImmutableMap(),
|
|
me: null,
|
|
}));
|
|
});
|
|
|
|
describe('AUTH_APP_CREATED', () => {
|
|
it('should copy in the app', () => {
|
|
const token = { token_type: 'Bearer', access_token: 'ABCDEFG' };
|
|
const action = { type: AUTH_APP_CREATED, app: token };
|
|
|
|
const result = reducer(undefined, action);
|
|
const expected = fromJS(token);
|
|
|
|
expect(result.get('app')).toEqual(expected);
|
|
});
|
|
});
|
|
|
|
describe('AUTH_LOGGED_IN', () => {
|
|
it('should import the token', () => {
|
|
const token = { token_type: 'Bearer', access_token: 'ABCDEFG' };
|
|
const action = { type: AUTH_LOGGED_IN, token };
|
|
|
|
const result = reducer(undefined, action);
|
|
const expected = fromJS({ 'ABCDEFG': token });
|
|
|
|
expect(result.get('tokens')).toEqual(expected);
|
|
});
|
|
|
|
it('should merge the token with existing state', () => {
|
|
const state = fromJS({
|
|
tokens: { 'ABCDEFG': { token_type: 'Bearer', access_token: 'ABCDEFG' } },
|
|
});
|
|
|
|
const expected = fromJS({
|
|
'ABCDEFG': { token_type: 'Bearer', access_token: 'ABCDEFG' },
|
|
'HIJKLMN': { token_type: 'Bearer', access_token: 'HIJKLMN' },
|
|
});
|
|
|
|
const action = {
|
|
type: AUTH_LOGGED_IN,
|
|
token: { token_type: 'Bearer', access_token: 'HIJKLMN' },
|
|
};
|
|
|
|
const result = reducer(state, action);
|
|
expect(result.get('tokens')).toEqual(expected);
|
|
});
|
|
});
|
|
|
|
describe('VERIFY_CREDENTIALS_FAIL', () => {
|
|
it('should delete the failed token', () => {
|
|
const state = fromJS({
|
|
tokens: {
|
|
'ABCDEFG': { token_type: 'Bearer', access_token: 'ABCDEFG' },
|
|
'HIJKLMN': { token_type: 'Bearer', access_token: 'HIJKLMN' },
|
|
},
|
|
});
|
|
|
|
const expected = fromJS({
|
|
'HIJKLMN': { token_type: 'Bearer', access_token: 'HIJKLMN' },
|
|
});
|
|
|
|
const action = { type: VERIFY_CREDENTIALS_FAIL, token: 'ABCDEFG' };
|
|
const result = reducer(state, action);
|
|
expect(result.get('tokens')).toEqual(expected);
|
|
});
|
|
|
|
it('should delete any users associated with the failed token', () => {
|
|
const state = fromJS({
|
|
users: {
|
|
'1234': { id: '1234', access_token: 'ABCDEFG' },
|
|
'5678': { id: '5678', access_token: 'HIJKLMN' },
|
|
},
|
|
});
|
|
|
|
const expected = fromJS({
|
|
'5678': { id: '5678', access_token: 'HIJKLMN' },
|
|
});
|
|
|
|
const action = { type: VERIFY_CREDENTIALS_FAIL, token: 'ABCDEFG' };
|
|
const result = reducer(state, action);
|
|
expect(result.get('users')).toEqual(expected);
|
|
});
|
|
|
|
it('should reassign `me` to the next in line', () => {
|
|
const state = fromJS({
|
|
me: '1234',
|
|
users: {
|
|
'1234': { id: '1234', access_token: 'ABCDEFG' },
|
|
'5678': { id: '5678', access_token: 'HIJKLMN' },
|
|
},
|
|
});
|
|
|
|
const action = { type: VERIFY_CREDENTIALS_FAIL, token: 'ABCDEFG' };
|
|
const result = reducer(state, action);
|
|
expect(result.get('me')).toEqual('5678');
|
|
});
|
|
});
|
|
});
|