Overview
Bruno provides several methods for request chaining:bru.runRequest()- Execute requests within your collectionbru.sendRequest()- Send programmatic HTTP requestsbru.runner.setNextRequest()- Control request execution order in collection runs
bru.runRequest()
Execute any request in your collection and retrieve the response directly within your script.
Avoid using
bru.runRequest() in collection-level scripts. Since collection scripts run for all requests, calling bru.runRequest() from a collection script will trigger the target request, which will also execute the collection script again, creating an infinite loop.Syntax
Parameters
- requestPath: The absolute path to the request from the collection root (string)
Returns
Returns a response object containing:status: HTTP status codestatusText: HTTP status textheaders: Response headers objectbody: Response body (automatically parsed if JSON)responseTime: Response time in milliseconds
Examples
Basic Request Execution
bru.sendRequest()
Send a programmatic HTTP request within your script. This allows you to make additional API calls during script execution.
Syntax
Parameters
- method: HTTP method (GET, POST, PUT, DELETE, etc.)
- url: The URL to send the request to
- headers: (Optional) Request headers object
- data: (Optional) Request data. Can be a string or object
- timeout: (Optional) Request timeout in milliseconds
- callback: Function to handle the response with signature
(err, res)
Examples
Basic HTTP Request
POST Request with Data
bru.runner.setNextRequest()
Control the order in which requests are executed during collection runs. This allows you to skip requests or change the execution flow based on conditions.
bru.runner.setNextRequest() works only in post-request scripts or test scripts.Syntax
Parameters
- requestName: The name of the next request to execute (string) or
nullto stop execution
How it works
setNextRequestworks with single requests - it executes the current request first, then jumps to the specified request- It skips all requests between the current one and the target request
- The target request must exist in the collection and be specified by its exact name
- For requests inside folders: Use just the request name (e.g., “request-name”), not the full path
Examples
Conditional Request Execution
- Use
bru.runRequest()for requests within your collection (faster, uses existing configuration) - Use
bru.sendRequest()for external APIs or when you need custom request configuration - Avoid nested loops that could cause infinite request chains