Mastering Postman: Data-Driven Testing with CSV and JSON Files
While running bulk test cases is an excellent feature, what happens when you need to cover both positive and negative scenarios in your testing? How do you efficiently handle such cases without manually changing the input values for every test?
In the previous article, we walked through how to run test cases in bulk using Postman. If you missed it, you can check it out here.
data:image/s3,"s3://crabby-images/d0a7e/d0a7ef9e20bdb5998fd466edaacd04e31835c7b4" alt=""
While running bulk test cases is an excellent feature, what happens when you need to cover both positive and negative scenarios in your testing? How do you efficiently handle such cases without manually changing the input values for every test?
data:image/s3,"s3://crabby-images/77725/77725a4eddc238204e8bfe081ad9626d79c42eb1" alt="Postman.png Postman.png"
The answer lies in data-driven testing using CSV or JSON files, a powerful approach Postman offers to automate test cases with dynamic input sets. This article will guide you through implementing data-driven testing to cover all scenarios without breaking a sweat.
Practical Example Scenario
For this tutorial, let’s consider a Create a New User API endpoint. Here’s how the API responds based on the input:
- Case 1: When
username=echoapi
, the API successfully creates a user and returns:
{
"error": 0,
"msg": "ok",
"user": {
"id": 1787,
"username": "echoapi",
"firstName": "Echo",
"lastName": "Api",
"email": "support@echoapi.com",
"password": "12345",
"phone": "",
"userStatus": 0
}
}
data:image/s3,"s3://crabby-images/fd907/fd9074dee8b868659df7b9a5a99df53777f63d7a" alt="username=echoapi.jpg username=echoapi.jpg"
- Case 2: When
username
is empty, the API fails and returns:
{
"error": 1,
"msg": "Username is required"
}
data:image/s3,"s3://crabby-images/7e33c/7e33c7a691b42c8cab4d7ef01c36f91b05148892" alt="username is empty.jpg username is empty.jpg"
We’ll now demonstrate how to cover these scenarios with a CSV or JSON file to automate testing for these responses.
Step-By-Step Guide to Data-Driven Testing
Step 1: Create the Data File (CSV)
- On your local machine, create a new text document and name it
data.csv
. - Open the file in a text editor or any CSV editor.
Write your test data starting from the second row:
echoapi,0
,1
The first scenario tests for a valid username
, and the second scenario tests for an empty username
. Save the file.
Write the first row as the parameter names:
username,assert_value
Here, username
represents the input field, and assert_value
will store the expected value of the error
field for assertion.
data:image/s3,"s3://crabby-images/1ef5c/1ef5c00f8c551c5361ef8a6012b9978ba0defadc" alt="data.csv.jpg data.csv.jpg"
Step 2: Update the Request Body
In Postman’s request body, replace the username
static value with a dynamic variable using the double curly braces {{...}}
syntax:
{
"id": 0,
"username": "{{username}}",
"firstName": "Echo",
"lastName": "Api",
"email": "support@echoapi.com",
"password": "12345",
"phone": "",
"userStatus": 0
}
data:image/s3,"s3://crabby-images/5c4cf/5c4cf985ba71c2810784a37aa9ec30622f51e4d0" alt="request body.jpg request body.jpg"
Postman will replace {{username}}
dynamically with the values from the username
column in your CSV file during runtime.
Step 3: Write the Assertions in the Test Script
The next step is scripting assertions in the Tests tab of the request. For this example, we need to:
- Validate the status code.
- Assert the
error
response value against the expected value provided in theassert_value
field of the CSV file.
Here’s the full script:
// Check if "username" exists in the response
if (responseBody.search("username") != -1) {
var result = responseBody.match(new RegExp('"username":"(.*?)"'));
console.log("Extracted username: " + result[1]);
// Set the username as a global variable
pm.globals.set("username", result[1]);
}
// Assertion: Status code is 200
pm.test("Status code is 200", function () {
pm.response.to.have.status(200);
});
// Assertion: Body contains the expected "error" value
pm.test("Body matches error", function () {
pm.expect(pm.response.text()).to.include(data.assert_value);
});
data:image/s3,"s3://crabby-images/7017c/7017c33540124fd7396bce9fab50ae84019fa04b" alt="script.jpg script.jpg"
This ensures that the script works dynamically with data inputs while handling edge cases where username
may not be present in the payload.
Step 4: Add the Data File to the Collection Run
1. Click the Run collection button in Postman.
data:image/s3,"s3://crabby-images/a8d2c/a8d2ce570e6bb1569b9b718c9aca715bbccefcfe" alt="Run collection.jpg Run collection.jpg"
2. In the Data File section, upload your username.csv
file.
- You’ll notice that the Iterations field is automatically updated with the number of rows (test cases) in your CSV.
data:image/s3,"s3://crabby-images/02173/0217399566b444f52a3c4c711f10176a9a02fd41" alt="Data File.jpg Data File.jpg"
3. Click Preview to verify the test data loaded from the file.
data:image/s3,"s3://crabby-images/e7b45/e7b457c41e413bc4598ddf152abb0f71e6ca64e0" alt="Preview.jpg Preview.jpg"
4. Choose the API to be executed and click Run EchoAPI's Collection.
data:image/s3,"s3://crabby-images/85bf2/85bf20e5033cafb5ef2472416e2799d3a40cab59" alt="Run EchoAPI's Collection.jpg Run EchoAPI's Collection.jpg"
Step 5: Analyze the Results
After the collection run is complete, you can view the detailed report. It will display:
- The total number of iterations (corresponding to the rows in your data file).
- Passed, failed, and skipped test cases.
- Execution time, request, and response logs.
data:image/s3,"s3://crabby-images/d6794/d67942b2a744584b6a71c0377de58fee439dfdb3" alt="Analyze the Results.jpg Analyze the Results.jpg"
Postman will dynamically substitute the {{username}}
and {{assert_value}}
variables with their respective values from the CSV file and perform assertions for each iteration.
JSON File (Alternative Data Format)
The process for using a JSON file is identical to the CSV file method. The only difference lies in the data format. Here's how you can prepare the same test data as a JSON file:
[
{
"username": "echoapi",
"assert_value": 0
},
{
"username": "",
"assert_value": 1
}
]
When running the collection, select the JSON file instead of the CSV file, and Postman will handle the rest in the same way.
data:image/s3,"s3://crabby-images/312b1/312b1c2c935b850d06af50318b0afd49f9158b35" alt="JSON File.jpg JSON File.jpg"
Conclusion
Data-driven testing with Postman is an incredibly efficient way to cover multiple scenarios and datasets in your API testing. By leveraging CSV or JSON files, you can dynamically feed data into your tests, enabling you to automate both positive and negative test cases with ease.
This approach not only saves time but also improves accuracy by avoiding hard-coded values in test scripts. Whether you’re testing edge cases or scaling up tests with hundreds of user inputs, data-driven testing ensures your APIs are robust and reliable for all scenarios.
Master this technique, and you’ll be equipped to handle any API testing challenge efficiently!
data:image/s3,"s3://crabby-images/31c3d/31c3d166c852235d8530862989bc8db4a9b4239c" alt=""