dispatch/client/src/js/state/__tests__/reducer-servers.test.js

256 lines
5.2 KiB
JavaScript
Raw Normal View History

import reducer, { connect, setServerName } from '../servers';
2017-04-25 03:13:57 +00:00
import * as actions from '../actions';
describe('server reducer', () => {
2017-04-25 03:13:57 +00:00
it('adds the server on CONNECT', () => {
let state = reducer(undefined, connect('127.0.0.1:1337', 'nick', {}));
2018-04-25 03:36:27 +00:00
expect(state).toEqual({
2017-04-25 03:13:57 +00:00
'127.0.0.1': {
name: '127.0.0.1',
nick: 'nick',
editedNick: null,
status: {
connected: false,
error: null
}
2017-04-25 03:13:57 +00:00
}
});
state = reducer(state, connect('127.0.0.1:1337', 'nick', {}));
2018-04-25 03:36:27 +00:00
expect(state).toEqual({
2017-04-25 03:13:57 +00:00
'127.0.0.1': {
name: '127.0.0.1',
nick: 'nick',
editedNick: null,
status: {
connected: false,
error: null
}
2017-04-25 03:13:57 +00:00
}
});
2018-04-05 23:46:22 +00:00
state = reducer(
state,
connect('127.0.0.2:1337', 'nick', {
name: 'srv'
})
);
2017-04-25 03:13:57 +00:00
2018-04-25 03:36:27 +00:00
expect(state).toEqual({
2017-04-25 03:13:57 +00:00
'127.0.0.1': {
name: '127.0.0.1',
nick: 'nick',
editedNick: null,
status: {
connected: false,
error: null
}
2017-04-25 03:13:57 +00:00
},
'127.0.0.2': {
name: 'srv',
nick: 'nick',
editedNick: null,
status: {
connected: false,
error: null
}
2017-04-25 03:13:57 +00:00
}
});
});
it('removes the server on DISCONNECT', () => {
2018-04-25 03:36:27 +00:00
let state = {
2017-04-25 03:13:57 +00:00
srv: {},
srv2: {}
2018-04-25 03:36:27 +00:00
};
2017-04-25 03:13:57 +00:00
state = reducer(state, {
type: actions.DISCONNECT,
server: 'srv2'
});
2018-04-25 03:36:27 +00:00
expect(state).toEqual({
2017-04-25 03:13:57 +00:00
srv: {}
});
});
it('handles SET_SERVER_NAME', () => {
2018-04-25 03:36:27 +00:00
let state = {
srv: {
name: 'cake'
}
2018-04-25 03:36:27 +00:00
};
state = reducer(state, setServerName('pie', 'srv'));
2018-04-25 03:36:27 +00:00
expect(state).toEqual({
srv: {
name: 'pie'
}
});
});
it('sets editedNick when editing the nick', () => {
let state = reducer(undefined, connect('127.0.0.1:1337', 'nick', {}));
state = reducer(state, {
type: actions.SET_NICK,
server: '127.0.0.1',
nick: 'nick2',
editing: true
});
2018-04-25 03:36:27 +00:00
expect(state).toMatchObject({
'127.0.0.1': {
name: '127.0.0.1',
nick: 'nick',
editedNick: 'nick2'
}
});
});
it('clears editedNick when receiving an empty nick after editing finishes', () => {
let state = reducer(undefined, connect('127.0.0.1:1337', 'nick', {}));
state = reducer(state, {
type: actions.SET_NICK,
server: '127.0.0.1',
nick: 'nick2',
editing: true
});
state = reducer(state, {
type: actions.SET_NICK,
server: '127.0.0.1',
nick: ''
});
2018-04-25 03:36:27 +00:00
expect(state).toMatchObject({
'127.0.0.1': {
name: '127.0.0.1',
nick: 'nick',
editedNick: null
}
});
});
2017-04-25 03:13:57 +00:00
it('updates the nick on SOCKET_NICK', () => {
let state = reducer(undefined, connect('127.0.0.1:1337', 'nick', {}));
state = reducer(state, {
type: actions.socket.NICK,
2017-04-25 03:13:57 +00:00
server: '127.0.0.1',
oldNick: 'nick',
newNick: 'nick2'
});
2018-04-25 03:36:27 +00:00
expect(state).toMatchObject({
'127.0.0.1': {
name: '127.0.0.1',
nick: 'nick2',
editedNick: null
}
});
});
it('clears editedNick on SOCKET_NICK_FAIL', () => {
let state = reducer(undefined, connect('127.0.0.1:1337', 'nick', {}));
state = reducer(state, {
type: actions.SET_NICK,
server: '127.0.0.1',
nick: 'nick2',
editing: true
});
state = reducer(state, {
type: actions.socket.NICK_FAIL,
server: '127.0.0.1'
2017-04-25 03:13:57 +00:00
});
2018-04-25 03:36:27 +00:00
expect(state).toMatchObject({
2017-04-25 03:13:57 +00:00
'127.0.0.1': {
name: '127.0.0.1',
nick: 'nick',
editedNick: null
2017-04-25 03:13:57 +00:00
}
});
});
it('adds the servers on SOCKET_SERVERS', () => {
let state = reducer(undefined, {
type: actions.socket.SERVERS,
2017-04-25 03:13:57 +00:00
data: [
{
host: '127.0.0.1',
name: 'stuff',
nick: 'nick',
status: {
connected: true
}
2017-04-25 03:13:57 +00:00
},
{
host: '127.0.0.2',
name: 'stuffz',
nick: 'nick2',
status: {
connected: false
}
2018-04-05 23:46:22 +00:00
}
2017-04-25 03:13:57 +00:00
]
});
2018-04-25 03:36:27 +00:00
expect(state).toEqual({
2017-04-25 03:13:57 +00:00
'127.0.0.1': {
name: 'stuff',
nick: 'nick',
status: {
2018-04-25 03:36:27 +00:00
connected: true
}
2017-04-25 03:13:57 +00:00
},
'127.0.0.2': {
name: 'stuffz',
nick: 'nick2',
status: {
2018-04-25 03:36:27 +00:00
connected: false
}
2017-04-25 03:13:57 +00:00
}
});
});
it('updates connection status on SOCKET_CONNECTION_UPDATE', () => {
let state = reducer(undefined, connect('127.0.0.1:1337', 'nick', {}));
state = reducer(state, {
type: actions.socket.CONNECTION_UPDATE,
server: '127.0.0.1',
connected: true
});
2018-04-25 03:36:27 +00:00
expect(state).toEqual({
'127.0.0.1': {
name: '127.0.0.1',
nick: 'nick',
editedNick: null,
status: {
2018-04-25 03:36:27 +00:00
connected: true
}
}
});
state = reducer(state, {
type: actions.socket.CONNECTION_UPDATE,
server: '127.0.0.1',
connected: false,
error: 'Bad stuff happened'
2017-04-25 03:13:57 +00:00
});
2018-04-25 03:36:27 +00:00
expect(state).toEqual({
2017-04-25 03:13:57 +00:00
'127.0.0.1': {
name: '127.0.0.1',
nick: 'nick',
editedNick: null,
status: {
connected: false,
error: 'Bad stuff happened'
}
2017-04-25 03:13:57 +00:00
}
});
});
});