Beanstalkd Extension for K6, allows you to write k6 tests against your beanstalk tubes and more.
It makes use of xk6 providing a client for interacting with Beanstalkd, a simple and fast work queue.
To build a k6
binary with this extension, first ensure you have the prerequisites:
- Go 1.22.6 or later
- Git
Then:
- Install
xk6
:
go install go.k6.io/xk6/cmd/xk6@latest
- Build the binary:
xk6 build --with github.com/dnlowman/xk6-beanstalkd=.
Run the binary with your script:
./k6 run script.js
This extension implements the following API:
Creates a new Beanstalkd client.
address
: string, the address of the Beanstalkd server (e.g., "localhost:11300")
Puts a job into the currently used tube.
data
: string, the job bodypriority
: number, job prioritydelay
: number, delay in seconds before the job becomes readyttr
: number, time to run in seconds
Returns: job ID (number)
Reserves a job from a watched tube.
timeout
: number, timeout in seconds
Returns: [job ID (number), job body (string)]
Deletes a job.
id
: number, job ID
Releases a reserved job back to the ready queue.
id
: number, job IDpriority
: number, new prioritydelay
: number, delay in seconds
Buries a job.
id
: number, job IDpriority
: number, new priority
Kicks buried or delayed jobs into the ready queue.
bound
: number, upper bound on the number of jobs to kick
Returns: number of jobs actually kicked
Changes the tube used for put
commands.
tube
: string, tube name
Adds a tube to the watch list for reserve
commands.
tube
: string, tube name
Removes a tube from the watch list for reserve
commands.
tube
: string, tube name
Peeks at a job.
id
: number, job ID
Returns: job body (string)
Returns a map of server statistics.
Returns a map of tube statistics.
tube
: string, tube name
Returns a list of all existing tubes.
import beanstalkd from 'k6/x/beanstalkd';
import { check } from 'k6';
export default function () {
const client = beanstalkd.newClient('localhost:11300');
const jobId = client.put('Hello, Beanstalkd!', 1, 0, 60);
console.log(`Put job with ID: ${jobId}`);
const [reservedId, jobBody] = client.reserve(5);
console.log(`Reserved job ${reservedId}: ${jobBody}`);
check(jobBody, {
'job content is correct': (body) => body === 'Hello, Beanstalkd!',
});
client.delete(reservedId);
console.log('Job deleted');
client.close();
}
- Make sure you have a Beanstalkd server running and accessible at the address you specify when creating a new client.
- Remember to close the client when you're done to release resources.
- This extension is designed for testing purposes and may not include all features of a full Beanstalkd client library.
- This is still in BETA, but should work ok!