Bird
Raised Fist0
Postmantesting~8 mins

Delay between requests in Postman - Framework Patterns

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Framework Mode - Delay between requests
Folder Structure
Postman Collection Project/
├── collections/
│   └── api-requests.postman_collection.json
├── environments/
│   ├── dev.postman_environment.json
│   └── prod.postman_environment.json
├── scripts/
│   └── delay-scripts.js
├── tests/
│   └── delay-tests.postman_collection.json
└── README.md

This structure organizes Postman collections, environment files, and custom scripts for delays.

Test Framework Layers
  • Collections: Group of API requests to test endpoints.
  • Environments: Variables for different setups (dev, prod).
  • Scripts: Pre-request and test scripts to add delays and validations.
  • Tests: Collections or folders with tests that include delay logic.
  • Utilities: Reusable scripts or functions for delay implementation.
Configuration Patterns
  • Environment Variables: Define delay duration (e.g., requestDelayMs) per environment.
  • Pre-request Script: Use setTimeout with pm.variables.get('requestDelayMs') to pause before sending requests.
  • Collection Runner Settings: Control iteration delays if needed.
  • Global Variables: For shared delay settings across collections.
Test Reporting and CI/CD Integration
  • Use Postman built-in test reports to see pass/fail results.
  • Integrate with Newman CLI to run collections in CI/CD pipelines.
  • Newman supports reporters like HTML, JSON for detailed reports.
  • Delay scripts do not affect reporting but help avoid rate limits or server overload.
  • Configure CI/CD to respect delays to prevent flaky tests.
Best Practices
  1. Use environment variables to control delay duration for flexibility.
  2. Implement delays in pre-request scripts to keep requests organized.
  3. Avoid hard-coded delays; prefer configurable values to adapt to different environments.
  4. Use delays only when necessary to avoid slowing down test suites unnecessarily.
  5. Document delay usage clearly in README or collection descriptions.
Self Check

Where in this folder structure would you add a new script to implement a 2-second delay before each API request?

Key Result
Use environment-configured pre-request scripts in Postman collections to add flexible delays between API requests.

Practice

(1/5)
1. What is the main purpose of adding a delay between requests in Postman?
easy
A. To change the request URL dynamically
B. To speed up the test execution
C. To skip some requests automatically
D. To simulate real user behavior and avoid server overload

Solution

  1. Step 1: Understand delay usage in Postman

    Delays are used to mimic real user wait times and prevent sending too many requests too fast.
  2. Step 2: Identify the correct purpose

    Speeding up tests or skipping requests are not related to delays; delays help simulate real scenarios and protect servers.
  3. Final Answer:

    To simulate real user behavior and avoid server overload -> Option D
  4. Quick Check:

    Delay purpose = simulate real use and avoid overload [OK]
Hint: Delays mimic real users and protect servers from overload [OK]
Common Mistakes:
  • Thinking delays speed up tests
  • Confusing delay with skipping requests
  • Assuming delay changes request data
2. Which of the following is the correct way to add a 2-second delay between requests in Postman using JavaScript?
easy
A. delay(2000); postman.setNextRequest('Request2');
B. postman.setNextRequest('Request2', 2000);
C. setTimeout(() => postman.setNextRequest('Request2'), 2000);
D. setTimeout(postman.setNextRequest('Request2'), 2000);

Solution

  1. Step 1: Recall correct setTimeout syntax

    setTimeout takes a function and delay in milliseconds: setTimeout(function, delay).
  2. Step 2: Check usage with postman.setNextRequest

    postman.setNextRequest must be called inside a function passed to setTimeout to delay execution.
  3. Final Answer:

    setTimeout(() => postman.setNextRequest('Request2'), 2000); -> Option C
  4. Quick Check:

    Use setTimeout with function and delay [OK]
Hint: Wrap setNextRequest in a function inside setTimeout [OK]
Common Mistakes:
  • Passing setNextRequest call directly to setTimeout
  • Using non-existent delay function
  • Trying to pass delay as second argument to setNextRequest
3. Given this Postman test script snippet, what will happen?
setTimeout(() => postman.setNextRequest('Login'), 3000);
console.log('Request scheduled');
medium
A. The 'Login' request will run immediately, and 'Request scheduled' logs after 3 seconds
B. 'Request scheduled' logs immediately, and 'Login' request runs after 3 seconds
C. Both 'Login' request and log happen immediately
D. Neither 'Login' request nor log will run

Solution

  1. Step 1: Understand setTimeout behavior

    setTimeout delays the function call (postman.setNextRequest) by 3000 ms, but console.log runs immediately.
  2. Step 2: Determine order of execution

    console.log('Request scheduled') runs first; after 3 seconds, the 'Login' request is set to run next.
  3. Final Answer:

    'Request scheduled' logs immediately, and 'Login' request runs after 3 seconds -> Option B
  4. Quick Check:

    console.log immediate, setNextRequest delayed [OK]
Hint: console.log runs immediately; setNextRequest delayed by setTimeout [OK]
Common Mistakes:
  • Assuming setNextRequest runs immediately
  • Thinking console.log waits for delay
  • Confusing order of asynchronous calls
4. You wrote this Postman script to delay the next request by 1 second, but the delay does not work. What is wrong?
setTimeout(postman.setNextRequest('NextRequest'), 1000);
medium
A. postman.setNextRequest should be inside a function passed to setTimeout
B. Delay time should be in seconds, not milliseconds
C. setTimeout cannot be used in Postman scripts
D. postman.setNextRequest does not accept request names

Solution

  1. Step 1: Analyze setTimeout usage

    setTimeout expects a function as first argument, but here postman.setNextRequest is called immediately.
  2. Step 2: Correct usage for delay

    Wrap postman.setNextRequest call inside a function (e.g., arrow function) to delay execution properly.
  3. Final Answer:

    postman.setNextRequest should be inside a function passed to setTimeout -> Option A
  4. Quick Check:

    Pass function to setTimeout, not direct call [OK]
Hint: Wrap setNextRequest call in a function for setTimeout delay [OK]
Common Mistakes:
  • Passing direct call instead of function to setTimeout
  • Confusing milliseconds with seconds
  • Believing setTimeout is unsupported in Postman
5. You want to run three requests in sequence with a 1-second delay between each in Postman. Which script correctly implements this in the Tests tab of the first request?
hard
A. setTimeout(() => { postman.setNextRequest('Request2'); setTimeout(() => postman.setNextRequest('Request3'), 1000); }, 1000);
B. setTimeout(() => postman.setNextRequest('Request2'), 1000);
C. postman.setNextRequest('Request2'); setTimeout(() => postman.setNextRequest('Request3'), 1000);
D. postman.setNextRequest('Request2'); postman.setNextRequest('Request3');

Solution

  1. Step 1: Understand sequential delays

    Each request must be delayed before triggering the next; nested setTimeout calls create sequential delays.
  2. Step 2: Analyze options

    setTimeout(() => { postman.setNextRequest('Request2'); setTimeout(() => postman.setNextRequest('Request3'), 1000); }, 1000); nests setTimeout calls to delay Request2 by 1s, then Request3 by another 1s, correctly sequencing requests with delays.
  3. Final Answer:

    setTimeout(() => { postman.setNextRequest('Request2'); setTimeout(() => postman.setNextRequest('Request3'), 1000); }, 1000); -> Option A
  4. Quick Check:

    Nested setTimeouts create sequential delays [OK]
Hint: Use nested setTimeouts to delay multiple requests sequentially [OK]
Common Mistakes:
  • Calling setNextRequest multiple times without delay
  • Not nesting delays causing immediate requests
  • Assuming one setTimeout delays all requests