Menu
Choose a product
Viewing: v1.7.x (latest)
Find another version
Scroll for more
Open source
Socket.setTimeout(callback, delay)
Note
A module with a better and standard API exists.
The new k6/websockets API partially implements the WebSockets API living standard.
When possible, we recommend using the new API. It uses a global event loop for consistency with other k6 APIs and better performance.
Call a function at a later time, if the WebSocket connection is still open then.
| Parameter | Type | Description |
|---|---|---|
| callback | function | The function to call when delay has expired. |
| delay | number | The delay time, in milliseconds. |
Example
JavaScript
JavaScript
import ws from 'k6/ws';
import { sleep } from 'k6';
export default function () {
console.log('T0: Script started');
const url = 'wss://echo.websocket.org';
const response = ws.connect(url, null, function (socket) {
console.log('T0: Entered WebSockets run loop');
socket.setTimeout(function () {
console.log('T0+1: This is printed');
}, 1000);
socket.setTimeout(function () {
console.log('T0+2: Closing socket');
socket.close();
}, 2000);
socket.setTimeout(function () {
console.log('T0+3: This is not printed, because socket is closed');
}, 3000);
});
console.log('T0+2: Exited WebSockets run loop');
sleep(2);
console.log('T0+4: Script finished');
}Was this page helpful?
Related resources from Grafana Labs
Additional helpful documentation, links, and articles:
Video

Performance testing and observability in Grafana Cloud
Optimize user experiences with Grafana Cloud. Learn real-time insights, performance testing with k6, and continuous validation with Synthetic Monitoring.
Events

User-centered observability: load testing, real user monitoring, and synthetics
Learn how to use load testing, synthetic monitoring, and real user monitoring (RUM) to understand end users' experience of your apps. Watch on demand.