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.
Syntax
showLineNumbers
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
showLineNumbers
bru.sendRequest()
Send a programmatic HTTP request within your script. This allows you to make additional API calls during script execution.
Syntax
showLineNumbers
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
showLineNumbers
POST Request with Data
showLineNumbers
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
showLineNumbers
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
showLineNumbers
- 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