From 1aa1d29d97ba2796b2167a2a5cfbce034d621dd1 Mon Sep 17 00:00:00 2001 From: Alejandro Celaya Date: Sat, 12 Jan 2019 23:59:03 +0100 Subject: [PATCH] Removed direct calls between actions without DI --- src/servers/reducers/server.js | 15 ++++---- src/servers/services/provideServices.js | 6 ++-- test/servers/reducers/server.test.js | 47 +++++++++++++------------ 3 files changed, 33 insertions(+), 35 deletions(-) diff --git a/src/servers/reducers/server.js b/src/servers/reducers/server.js index 06bdc482..44837d15 100644 --- a/src/servers/reducers/server.js +++ b/src/servers/reducers/server.js @@ -14,23 +14,20 @@ export const listServers = (serversService) => () => ({ servers: serversService.listServers(), }); -// FIXME listServers action should be injected and not directly invoked -export const createServer = (serversService) => (server) => { +export const createServer = (serversService, listServers) => (server) => { serversService.createServer(server); - return listServers(serversService)(); + return listServers(); }; -// FIXME listServers action should be injected and not directly invoked -export const deleteServer = (serversService) => (server) => { +export const deleteServer = (serversService, listServers) => (server) => { serversService.deleteServer(server); - return listServers(serversService)(); + return listServers(); }; -// FIXME listServers action should be injected and not directly invoked -export const createServers = (serversService) => (servers) => { +export const createServers = (serversService, listServers) => (servers) => { serversService.createServers(servers); - return listServers(serversService)(); + return listServers(); }; diff --git a/src/servers/services/provideServices.js b/src/servers/services/provideServices.js index ff18b1b5..7821e168 100644 --- a/src/servers/services/provideServices.js +++ b/src/servers/services/provideServices.js @@ -35,9 +35,9 @@ const provideServices = (bottle, connect, withRouter) => { // Actions bottle.serviceFactory('selectServer', selectServer, 'ServersService'); - bottle.serviceFactory('createServer', createServer, 'ServersService'); - bottle.serviceFactory('createServers', createServers, 'ServersService'); - bottle.serviceFactory('deleteServer', deleteServer, 'ServersService'); + bottle.serviceFactory('createServer', createServer, 'ServersService', 'listServers'); + bottle.serviceFactory('createServers', createServers, 'ServersService', 'listServers'); + bottle.serviceFactory('deleteServer', deleteServer, 'ServersService', 'listServers'); bottle.serviceFactory('listServers', listServers, 'ServersService'); bottle.serviceFactory('resetSelectedServer', () => resetSelectedServer); diff --git a/test/servers/reducers/server.test.js b/test/servers/reducers/server.test.js index 9e87236b..99cf30b7 100644 --- a/test/servers/reducers/server.test.js +++ b/test/servers/reducers/server.test.js @@ -13,6 +13,7 @@ describe('serverReducer', () => { abc123: { id: 'abc123' }, def456: { id: 'def456' }, }; + const expectedFetchServersResult = { type: FETCH_SERVERS, servers }; const ServersServiceMock = { listServers: sinon.fake.returns(servers), createServer: sinon.fake(), @@ -40,38 +41,38 @@ describe('serverReducer', () => { it('fetches servers and returns them as part of the action', () => { const result = listServers(ServersServiceMock)(); - expect(result).toEqual({ type: FETCH_SERVERS, servers }); - expect(ServersServiceMock.listServers.callCount).toEqual(1); - expect(ServersServiceMock.createServer.callCount).toEqual(0); - expect(ServersServiceMock.deleteServer.callCount).toEqual(0); - expect(ServersServiceMock.createServers.callCount).toEqual(0); + expect(result).toEqual(expectedFetchServersResult); + expect(ServersServiceMock.listServers.calledOnce).toEqual(true); + expect(ServersServiceMock.createServer.called).toEqual(false); + expect(ServersServiceMock.deleteServer.called).toEqual(false); + expect(ServersServiceMock.createServers.called).toEqual(false); }); }); describe('createServer', () => { it('adds new server and then fetches servers again', () => { const serverToCreate = { id: 'abc123' }; - const result = createServer(ServersServiceMock)(serverToCreate); + const result = createServer(ServersServiceMock, () => expectedFetchServersResult)(serverToCreate); - expect(result).toEqual({ type: FETCH_SERVERS, servers }); - expect(ServersServiceMock.listServers.callCount).toEqual(1); - expect(ServersServiceMock.createServer.callCount).toEqual(1); + expect(result).toEqual(expectedFetchServersResult); + expect(ServersServiceMock.createServer.calledOnce).toEqual(true); expect(ServersServiceMock.createServer.firstCall.calledWith(serverToCreate)).toEqual(true); - expect(ServersServiceMock.deleteServer.callCount).toEqual(0); - expect(ServersServiceMock.createServers.callCount).toEqual(0); + expect(ServersServiceMock.listServers.called).toEqual(false); + expect(ServersServiceMock.deleteServer.called).toEqual(false); + expect(ServersServiceMock.createServers.called).toEqual(false); }); }); describe('deleteServer', () => { it('deletes a server and then fetches servers again', () => { const serverToDelete = { id: 'abc123' }; - const result = deleteServer(ServersServiceMock)(serverToDelete); + const result = deleteServer(ServersServiceMock, () => expectedFetchServersResult)(serverToDelete); - expect(result).toEqual({ type: FETCH_SERVERS, servers }); - expect(ServersServiceMock.listServers.callCount).toEqual(1); - expect(ServersServiceMock.createServer.callCount).toEqual(0); - expect(ServersServiceMock.createServers.callCount).toEqual(0); - expect(ServersServiceMock.deleteServer.callCount).toEqual(1); + expect(result).toEqual(expectedFetchServersResult); + expect(ServersServiceMock.listServers.called).toEqual(false); + expect(ServersServiceMock.createServer.called).toEqual(false); + expect(ServersServiceMock.createServers.called).toEqual(false); + expect(ServersServiceMock.deleteServer.calledOnce).toEqual(true); expect(ServersServiceMock.deleteServer.firstCall.calledWith(serverToDelete)).toEqual(true); }); }); @@ -79,14 +80,14 @@ describe('serverReducer', () => { describe('createServer', () => { it('creates multiple servers and then fetches servers again', () => { const serversToCreate = values(servers); - const result = createServers(ServersServiceMock)(serversToCreate); + const result = createServers(ServersServiceMock, () => expectedFetchServersResult)(serversToCreate); - expect(result).toEqual({ type: FETCH_SERVERS, servers }); - expect(ServersServiceMock.listServers.callCount).toEqual(1); - expect(ServersServiceMock.createServer.callCount).toEqual(0); - expect(ServersServiceMock.createServers.callCount).toEqual(1); + expect(result).toEqual(expectedFetchServersResult); + expect(ServersServiceMock.listServers.called).toEqual(false); + expect(ServersServiceMock.createServer.called).toEqual(false); + expect(ServersServiceMock.createServers.calledOnce).toEqual(true); expect(ServersServiceMock.createServers.firstCall.calledWith(serversToCreate)).toEqual(true); - expect(ServersServiceMock.deleteServer.callCount).toEqual(0); + expect(ServersServiceMock.deleteServer.called).toEqual(false); }); }); });