Javascript mocking library for websockets and socket.io
npm install mock-socketimport { WebSocket, Server } from 'mock-socket';import test from 'ava';
import { Server } from 'mock-socket';
class ChatApp {
  constructor(url) {
    this.messages = [];
    this.connection = new WebSocket(url);
    
    this.connection.onmessage = (event) => {
      this.messages.push(event.data);
    };
  }
  
  sendMessage(message) {
    this.connection.send(message);
  }
}
test.cb('that chat app can be mocked', t => {
  const fakeURL = 'ws://localhost:8080';
  const mockServer = new Server(fakeURL);
  
  mockServer.on('connection', socket => {
    socket.on('message', data => {
      t.is(data, 'test message from app', 'we have intercepted the message and can assert on it');
      socket.send('test message from mock server');
    });
  });
  
  const app = new ChatApp(fakeURL);
  app.sendMessage('test message from app'); // NOTE: this line creates a micro task
  
  // NOTE: this timeout is for creating another micro task that will happen after the above one
  setTimeout(() => {  
    t.is(app.messages.length, 1);
    t.is(app.messages[0], 'test message from mock server', 'we have subbed our websocket backend');
    mockServer.stop(t.done);
  }, 100);
});import { WebSocket, Server } from 'mock-socket';
/*
 * By default the global WebSocket object is stubbed out. However, 
 * if you need to stub something else out you can like so:
 */
 
window.WebSocket = WebSocket; // Here we stub out the window objectconst mockServer = new Server('ws://localhost:8080');
  
mockServer.on('connection', socket => {
  socket.on('message', () => {});
  socket.on('close', () => {});
  
  socket.send('message');
  socket.close();
});
mockServer.clients() // array of all connected clients
mockServer.emit('room', 'message');
mockServer.stop(optionalCallback);A declaration file is included by default. If you notice any issues with the types please create an issue or a PR!
Socket.IO has limited support. Below is a similar example to the one above but modified to show off socket.io support.
import test from 'ava';
import { SocketIO, Server } from 'mock-socket';
class ChatApp {
  constructor(url) {
    this.messages = [];
    this.connection = new io(url);
    
    this.connection.on('chat-message', data => {
      this.messages.push(event.data);
    };
  }
  
  sendMessage(message) {
    this.connection.emit('chat-message', message);
  }
}
test.cb('that socket.io works', t => {
  const fakeURL = 'ws://localhost:8080';
  const mockServer = new Server(fakeURL);
  
  window.io = SocketIO;
  
  mockServer.on('connection', socket => {
    socket.on('chat-message', data => {
      t.is(data, 'test message from app', 'we have intercepted the message and can assert on it');
      socket.emit('chat-message', 'test message from mock server');
    });
  });
  
  const app = new ChatApp(fakeURL);
  app.sendMessage('test message from app');
  
  setTimeout(() => {
    t.is(app.messages.length, 1);
    t.is(app.messages[0], 'test message from mock server', 'we have subbed our websocket backend');
    
    mockServer.stop(t.done);
  }, 100);
});The easiest way to work on the project is to clone the repo down via:
git clone [email protected]:thoov/mock-socket.git
cd mock-socket
yarn installThen to create a local build via:
yarn buildThen create a local npm link via:
yarn linkAt this point you can create other projects / apps locally and reference this local build via:
yarn link mock-socketfrom within your other projects folder. Make sure that after any changes you run yarn build!
This project uses ava.js as its test framework. Tests are located in /tests. To run tests:
yarn testThis project uses eslint and a rules set from airbnb's javascript style guides. To run linting:
yarn lintThis project uses prettier. To run the formatting:
yarn formatCode coverage reports are created in /coverage after all of the tests have successfully passed. To run the coverage:
yarn test:coverageIf you have any feedback, encounter any bugs, or just have a question, please feel free to create a github issue or send me a tweet at @thoov.
