- Introduction
- Getting started
- Philosophy
- Comparison
- Limitations
- Debugging runbook
- FAQ
- Basics
- Concepts
- Network behavior
- Integrations
- API
- CLI
- Best practices
- Recipes
- Cookies
- Query parameters
- Response patching
- Polling
- Streaming
- Network errors
- File uploads
- Responding with binary
- Custom worker script location
- Global response delay
- GraphQL query batching
- Higher-order resolver
- Keeping mocks in sync
- Merging Service Workers
- Mock GraphQL schema
- Using CDN
- Using custom "homepage" property
- Using local HTTPS
- Vitest Browser Mode
ws
Intercept WebSocket connections.
The ws
namespace helps you create event handlers to intercept WebSocket connections.
Call signature
The ws
namespace exposes a method called link()
. The link()
method creates a WebSocket link preconfigured to handle WebSocket connections matching the specified URL.
ws.link(url: string | URL | RegExp)
ws.ts
Source code for the `ws` namespace.
Event handler
The object returned from the ws.link()
call is referred to as a WebSocket link. The link has the following properties and methods:
.addEventListener(event, listener)
Adds a connection listener for the outgoing WebSocket client connections.
.clients
Set<WebSocketClientConnection>
The set of all active WebSocket clients.
.broadcast(data)
data: string | Blob | ArrayBuffer
Sends the given data to all active WebSocket clients.
const api = ws.link('wss://*')
api.broadcast('hello, everyone')
.broadcastExcept(clients, data)
clients: WebSocketClientConnection | Array<WebSocketClientConnection>
data: string | Blob | ArrayBuffer
Sends the given data to all active WebSocket clients except the given clients
.
const api = ws.link('wss://*')
api.addEventListener('connection', ({ client }) => {
api.broadcastExcept(client, 'all except this')
})
You can also provide an array of WebSocket client connections as the argument to clients
:
const ignoredClients = Array.from(api.clients).filter((client) => {
return client.url.includes('abc')
})
api.broadcastExcept(ignoredClients, 'hello')
Connection listener
Argument | Type | Description |
---|---|---|
client | WebSocketClientConnection | Outgoing WebSocket client connection object. |
server | WebSocketServerConnection | Actual WebSocket server connection object. |
params | Record<string, string> | Path parameters extracted from the connection url . |
info | WebSocketConnectionInfo | Extra information about this WebSocket connection. |
The connection listener is called on every outgoing WebSocket client connection.
import { ws } from 'msw'
import { setupWorker } from 'msw/browser'
const api = ws.link('wss://chat.example.com')
const worker = setupWorker(
api.addEventListener('connection', () => {
console.log('client connected!')
}),
)
await worker.start()
const socket = new WebSocket('wss://chat.example.com')
socket.onopen = () => {
console.log('connection established!')
}
In this example, the WebSocket connection to wss://chat.example.com
emits the "connection"
event on the api
event handler because the endpoint matches the one provided to the ws.link()
call. Since the connection is successful, the "open"
event is also dispatched on the socket
instance.
WebSocketClientConnection
The WebSocketClientConnection
object represents an intercepted WebSocket client connection from the server’s perspective. This means that the message
event on the client stands for a message sent by the client and received by the “server”.
.addEventListener(event, listener, options)
Adds a listener to the given client event. These are the supported client events:
Event name | Description |
---|---|
message | Dispatched when this client sends a message. |
error | Dispatched when this client connection has been closed with an error. |
close | Dispatched when this client is closed (e.g. by your application). |
.removeEventListener(event, listener, options)
Removes the listener for the given client event.
.send(data)
data: string | Blob | ArrayBuffer
Sends data to the WebSocket client. This is equivalent to the client receiving that data from the server.
api.addEventListener('connection', ({ client }) => {
client.send('hello')
client.send(new Blob(['hello']))
client.send(new TextEncoder().encode('hello'))
})
.close(code, reason)
code: number | undefined
, default:1000
reason: string | undefined
Closes the active WebSocket client connection.
api.addEventListener('connection', ({ client }) => {
client.close()
})
Unlike the WebSocket.prototype.close()
method, the client.close()
method accepts non-configurable close codes. This allows you to emulate client close scenarios based on server-side errors.
api.addEventListener('connection', ({ client }) => {
client.addEventListener('message', (event) => {
client.close(1003, 'Invalid data')
})
})
You can also implement custom close code and reason:
api.addEventListener('connection', ({ client }) => {
client.close(4000, 'Custom close reason')
})
WebSocketServerConnection
The WebSocketServerConnection
object represents the actual WebSocket server connection.
.connect()
Establishes connection to the actual WebSocket server.
api.addEventListener('connection', ({ server }) => {
server.connect()
})
.addEventListener(event, listener, options)
Adds a listener to the original server WebSocket connection. The supported events are:
Event name | Description |
---|---|
open | Dispatched when the connection to the original server has been opened. |
message | Dispatched when the original server sends a message. |
error | Dispatched when the original server connection has been closed with an error. |
close | Dispatched when the original server connection has been closed. |
.removeEventListener(event, listener, options)
Removes the listener for the given server event.
.send(data)
data: string | Blob | ArrayBuffer
Sends data to the actual WebSocket server. This is equivalent to the client sending this data to the server.
api.addEventListener('connection', ({ server }) => {
server.connect()
server.addEventListener('message', (event) => {
if (event.data === 'hello from server') {
server.send('hello from client')
}
})
})
.close(code, reason)
Closes the underlying original WebSocket server connection. Provides a custom close code
and reason
.
api.addEventListener('connection', ({ server }) => {
server.connect()
server.close()
})
WebSocketConnectionInfo
The info
argument on the connection
event listener contains additional WebSocket connection infromation.
Property name | Type | Description |
---|---|---|
protocols | string | string[] | undefined | The list of protocols used when establishing this WebSocket connection. |
api.addEventListener('connection', ({ info }) => {
if (info.protocols?.includes('chat')) {
// ...
}
})