2
0
mirror of https://github.com/tenrok/vue-native-websocket.git synced 2026-05-17 04:19:38 +03:00

fixed minor bags

This commit is contained in:
Viktor Shcheglov
2018-01-08 20:17:34 +03:00
parent 3551355f2b
commit a3b33dd5f3
5 changed files with 53 additions and 6 deletions
+2 -2
View File
@@ -143,10 +143,10 @@ export default new Vuex.Store({
state.message = message
},
// mutations for reconnect methods
[ws.WS_RECONNECT](state, count) {
SOCKET_RECONNECT(state, count) {
console.info(state, count)
},
[ws.WS_RECONNECT_ERROR](state) {
SOCKET_RECONNECT_ERROR(state) {
state.socket.reconnectError = true;
},
}
+1 -1
View File
File diff suppressed because one or more lines are too long
-1
View File
@@ -36,7 +36,6 @@ export default {
},
beforeDestroy () {
let sockets = this.$options['sockets']
clearTimeout(observer.reconnectTimeoutId)
if (sockets) {
Object.keys(sockets).forEach((key) => {
+2 -2
View File
@@ -53,9 +53,9 @@ export default class {
if (this.store) { this.passToStore('SOCKET_' + eventType, event) }
if (this.reconnection && this.eventType === 'onopen') { this.reconnectionCount = 0 }
if (this.reconnection && eventType === 'onopen') { this.reconnectionCount = 0 }
if (this.reconnection && eventType === 'onclose') { this.reconnect(event) }
if (this.reconnection && eventType === 'onclose') { this.reconnect() }
}
})
}
+48
View File
@@ -130,4 +130,52 @@ describe('Observer.js', () => {
mockServer.stop(done)
}, 100)
})
describe('reconnection feature', () => {
let observer, mockServer, vm, mockStore
let wsUrl = 'ws://localhost:8080'
beforeEach(() => {
mockServer = new Server(wsUrl)
mockServer.on('connection', ws => ws.send('hi'))
Vue.use(VueNativeSock, wsUrl)
vm = new Vue()
mockStore = sinon.mock({ commit: () => {} })
observer = new Observer(wsUrl, {
store: mockStore.object,
reconnection: true,
reconnectionAttempts: 2,
WebSocket: new WebSocket(wsUrl),
})
})
it('calls #reconnect() method', (done) => {
sinon.spy(observer, 'reconnect');
mockServer.close()
expect(observer.reconnect).to.called
mockServer.stop(done)
})
it('fires SOCKET_RECONNECT event', (done) => {
sinon.spy(observer, 'passToStore');
const clock = sinon.useFakeTimers()
mockServer.close()
clock.tick(1500);
expect(observer.passToStore).to.have.been.calledWith('SOCKET_RECONNECT')
mockServer.stop(done)
})
it('fires SOCKET_RECONNECT_ERROR event, after all attemps', (done) => {
sinon.spy(observer, 'passToStore');
observer.reconnectionCount = 2
observer.reconnectionAttempts = 1
mockServer.close()
expect(observer.passToStore).to.have.been.calledWith('SOCKET_RECONNECT_ERROR')
mockServer.stop(done)
})
})
})