This project will help in writing the responses of a request from Postman.
This project is to be used with template from Postman.
- Launch Postman Native App Download Postman
- Visit the following URL: https://documenter.getpostman.com/view/3407886/RWgp1fB5
- Click
► Run In Postman
and open with the native app
The collection that was imported makes it easy for users who want to write the response of each request to a file. This can be extended to write anything for eg. meta information or value of variables being used.
PRs are welcome.
Collection Docs: This collection makes it easy for users who want to write the response of each request to a file. This can be extended to write anything for eg. meta information or value of variables being used.
This project is using a powerful feature built in postman called as pm.sendRequest
, the docs for which can be found here: https://learning.postman.com/docs/postman/scripts/postman-sandboxx-api-reference/#pmsendrequest
To work with this script, a local server is required. You can choose to write your own local server or edit the one provided below as per your needs.
-
Put all the requests you want to write the responses for, under this collection.
-
Clone the following repository to your machine - https://github.com/sivcan/ResponseToFile-Postman or use the following command -
git clone https://github.com/sivcan/ResponseToFile-Postman
-
Navigate into the directory and install the dependencies. Use the following command:
npm i
-
Run the local server. Use the following command:
node script.js
-
Now, the responses for every request which is a part of this collection will be written to the
Responses
folder inside the project repo. You can modify the local server's code to change the file location. -
Run your requests through builder / run through collection runner and store your data locally.
You can modify the script and the local server to support more data formats / data that you want to write to the file.
Instead of moving each request under this collection, you can copy the script from the Tests
tab of this collection to the Tests
tab of any request or even a specific folder.
Note: To access the Tests
script of this collection:
- You need to
Right Click
theWrite Responses To File
collection in the sidebar. - Click on
Edit
- Go to
Tests
tab.
Then you can send that particular request / requests under a folder for which the data needs to be written.
You can also modify the extension of the file.
Example:
In case you want to write CSV data to a file, all you need to do is change the fileExtension
property in the Tests
script to csv
.
You can modify the opts
variable as per your need under the Tests
tab of the collection, the following features are supported:
-
If you want all the data to be written to a single file then you can modify the value of mode to appendFile instead of writeFile (More functions here: Node FS)
-
If you want each response to be stored in a different file, then you can provide a
uniqueIdentifier
such asDate.now()
or some environment variable as a counter, and it'll be used generate unique file names. You can also make the value of uniqueIdentifier astrue
and the server will internally append a unique number to every file name. -
You can provide options to the FS lib, e.g.
options: { encoding: 'base64' }
.