Skip to content

Commit

Permalink
Restart closed websocket if still subscribed
Browse files Browse the repository at this point in the history
  • Loading branch information
paulfalgout committed Jan 3, 2025
1 parent 57f3cb4 commit 18779c9
Show file tree
Hide file tree
Showing 2 changed files with 40 additions and 8 deletions.
47 changes: 39 additions & 8 deletions src/js/services/ws.cy.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,13 @@ let service;
const clientKey = 'clientKey';

Cypress.Commands.add('startService', () => {
const startSpy = cy.spy().as('startService');

service.on('start', startSpy);

// Return a promise that resolves when the service starts
return new Cypress.Promise(resolve => {
service.on('start', resolve);
service.once('start', resolve);
service.start();
});
});
Expand Down Expand Up @@ -80,26 +85,52 @@ context('WS Service', function() {
specify('Restarting a closed socket', function() {
const channel = Radio.channel('ws');

const closedTest = { name: 'SendTest', data: 'CLOSED' };
const closedTest = { id: 'foo', type: 'bar' };
const addTest = { id: 'foo2', type: 'bar2' };

const notification = {
state: {},
data: {
name: 'Subscribe',
data: {
clientKey: 'clientKey',
resources: [closedTest],
},
},
};

cy
.startService()
.then(() => {
cy.stub(service, 'start').as('start');

return new Cypress.Promise(resolve => {
service.ws.addEventListener('close', () => {
channel.request('send', closedTest);
channel.request('subscribe', closedTest);
resolve();
});
service.ws.close();
});
});

cy
.get('@start')
.should('have.been.calledOnce')
.and('have.been.calledWith', { state: {}, data: closedTest });
.get('@startService')
.should('be.calledTwice')
.then(spy => {
const secondCall = spy.getCall(1);
expect(secondCall.args[0]).to.deep.equal(notification);
})
.then(() => {
channel.request('add', addTest);
service.ws.close();
});

cy
.get('@startService')
.should('be.calledThrice')
.then(spy => {
const thirdCall = spy.getCall(2);
notification.data.data.resources.push(addTest);
expect(thirdCall.args[0]).to.deep.equal(notification);
});
});

specify('Message handling', function() {
Expand Down
1 change: 1 addition & 0 deletions src/js/services/ws.js
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,7 @@ export default App.extend({

onClose() {
this.stopHeartbeat();
if (this.resources.length) this._subscribe();
},

onMessage(event) {
Expand Down

0 comments on commit 18779c9

Please sign in to comment.