This is documentation for the next version of Grafana k6 documentation. For the latest stable release, go to the latest version.

Open source

Socket.setTimeout()

Sets the inactivity timeout for the socket. When the socket has been idle for timeout milliseconds without receiving data, a timeout event is emitted.

The socket doesn’t automatically close after a timeout. The connection remains open until you explicitly call destroy(). To disable a previously set timeout, pass 0.

Signature

JavaScript
socket.setTimeout(timeout)

Parameters

ParameterTypeDescription
timeoutnumberInactivity timeout in milliseconds. Pass 0 to disable

Returns

TypeDescription
SocketThe socket instance, for method chaining

Example

JavaScript
import { Socket } from "k6/x/tcp"

export default async function () {
  const socket = new Socket()

  const closed = new Promise((resolve) => {
    socket.on("close", () => {
      console.log("Connection closed")
      resolve()
    })
  })

  socket.on("data", (data) => {
    const str = String.fromCharCode.apply(null, new Uint8Array(data))
    console.log("Received:", str)
    // Reset the timeout after each data event
    socket.setTimeout(5000)
  })

  socket.on("timeout", () => {
    console.log("No data received for 5 seconds — closing")
    socket.destroy()
  })

  socket.on("error", (err) => {
    console.error("Error:", err)
  })

  const host = __ENV.TCP_HOST || "localhost"
  const port = __ENV.TCP_PORT || "8080"

  await socket.connect(port, host)
  console.log("Connected — waiting for data (5s timeout)")

  // Set timeout after connecting; no immediate write so the idle timer can fire
  socket.setTimeout(5000)

  await closed
}