Response time assertions check if a web service or API responds quickly enough. This helps ensure users get fast results and a good experience.
Response time assertions in Postman
Start learning this pattern below
Jump into concepts and practice - no test required
or
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Introduction
Syntax
Postman
pm.test("Response time is less than 200ms", function () { pm.expect(pm.response.responseTime).to.be.below(200); });
pm.test defines a test with a name and a function.
pm.response.responseTime gives the response time in milliseconds.
Examples
Postman
pm.test("Response time is less than 500ms", function () { pm.expect(pm.response.responseTime).to.be.below(500); });
Postman
pm.test("Response time is not more than 1000ms", () => { pm.expect(pm.response.responseTime).to.be.at.most(1000); });
Postman
pm.test("Response time is greater than 100ms", () => { pm.expect(pm.response.responseTime).to.be.above(100); });
Sample Program
This test checks if the API response time is under 300 milliseconds. If the response is slower, the test will fail.
Postman
pm.test("Response time is less than 300ms", function () { pm.expect(pm.response.responseTime).to.be.below(300); });
Important Notes
Response time is measured in milliseconds (ms).
Set realistic thresholds based on your API and user expectations.
Too strict limits may cause false failures during network delays.
Summary
Response time assertions help check API speed.
Use pm.response.responseTime to get response time in Postman tests.
Choose thresholds that match your performance goals.
Practice
1. What does
pm.response.responseTime represent in Postman tests?easy
Solution
Step 1: Understand the property
This property in Postman returns the time taken by the API server to send a response, measured in milliseconds.pm.response.responseTimeStep 2: Differentiate from other response properties
It does not represent response size, status code, or request count, which are different properties.Final Answer:
The time taken by the API to respond in milliseconds -> Option DQuick Check:
Response time = API speed [OK]
Hint: Response time means how fast API replies in ms [OK]
Common Mistakes:
- Confusing response time with response size
- Mixing response time with HTTP status code
- Thinking it counts number of requests
2. Which of the following is the correct syntax to assert that response time is less than 500 milliseconds in Postman test script?
easy
Solution
Step 1: Identify correct property and assertion method
The correct property for response time ispm.response.responseTime. To check if it is less than 500ms, useto.be.below(500).Step 2: Verify syntax correctness
pm.test('Response time is less than 500ms', () => { pm.expect(pm.response.responseTime).to.be.below(500); }); uses the correct property and assertion syntax. Other options use wrong properties or wrong comparison methods.Final Answer:
pm.test('Response time is less than 500ms', () => { pm.expect(pm.response.responseTime).to.be.below(500); }); -> Option BQuick Check:
Usepm.response.responseTimewithto.be.below()[OK]
Hint: Use pm.response.responseTime with to.be.below() for less than checks [OK]
Common Mistakes:
- Using wrong property like pm.response.time
- Using to.be.above() instead of to.be.below()
- Missing pm.expect wrapper
3. Given the following Postman test code, what will be the test result if the API response time is 450 ms?
pm.test('Response time is acceptable', () => {
pm.expect(pm.response.responseTime).to.be.below(400);
});medium
Solution
Step 1: Understand the assertion condition
The test expectspm.response.responseTimeto be below 400 milliseconds.Step 2: Compare actual response time with condition
The actual response time is 450 ms, which is greater than 400 ms, so the condition fails.Final Answer:
Test will fail because 450 is not below 400 -> Option CQuick Check:
450 > 400 means test fails [OK]
Hint: Check if actual time is less than threshold to pass [OK]
Common Mistakes:
- Assuming 450 is below 400
- Confusing pass/fail logic
- Ignoring comparison operator meaning
4. Identify the error in this Postman test script for response time assertion:
pm.test('Response time check', function() {
pm.expect(pm.response.responseTime).to.be.lessThan(300);
});medium
Solution
Step 1: Check assertion method correctness
Postman uses Chai assertion library where the correct method to check less than isto.be.below(), notlessThan().Step 2: Verify other parts of the script
The function syntax is valid, the property exists, and the test name is present.Final Answer:
The assertion methodlessThanis incorrect in Postman tests -> Option AQuick Check:
Useto.be.below()notlessThan()[OK]
Hint: Use to.be.below() for less than, not lessThan() [OK]
Common Mistakes:
- Using lessThan() instead of to.be.below()
- Thinking lessThan() is valid Chai syntax
- Ignoring assertion library conventions
5. You want to write a Postman test that fails if the response time is more than 1000 ms but passes if it is exactly 1000 ms or less. Which assertion code correctly implements this logic?
hard
Solution
Step 1: Understand the requirement
The test should pass if response time is 1000 ms or less, and fail if more than 1000 ms.Step 2: Choose correct assertion method
to.be.at.most(1000)checks if value is less than or equal to 1000, matching the requirement.to.be.below(1000)excludes 1000,to.equal(1000)only passes exactly 1000, andto.be.above(1000)is opposite.Final Answer:
pm.test('Response time check', () => { pm.expect(pm.response.responseTime).to.be.at.most(1000); }); -> Option AQuick Check:
Use to.be.at.most() for <= checks [OK]
Hint: Use to.be.at.most() for less than or equal assertions [OK]
Common Mistakes:
- Using to.be.below() excludes equal value
- Using to.equal() only matches exact value
- Using to.be.above() reverses logic
