- preface
- Based on using
- Collection
- Environment
- Test
- Collection Runner
- The resources
- About me
preface
I am an Android developer, and the most inevitable part of daily development is to use Postman for network debugging. Postman is also very convenient, and CAN be set with URLS and headers. Let’s share a few useful features and see if there are any you haven’t used.
Based on using
When you first open Postman, you’ll see a page like the one above. To test a request, open a Tab, fill in the URL, select the request mode, and set the response Header and Params according to the interface requirements. Then click Send to Send the request and observe the response.
Collection
This is the most simple network request, I have been using this before, no problem. Until one day, the boss gave me a JSON file and asked me to import it to Postman, saying that this is all the network requests for the project you are going to take on later. When I import it, it looks something like this. The boss told me that the imported Collection is a single Collection and that you can create multiple collections in Postman.
This was my first time to contact Collection, and I was quite excited, so I went to the side to study these interfaces. After a while, I found that Collection can also create folders internally and sort out the requests in the Collection in the form of subcontracting, like this.
Environment
After a while, I found a problem. Every time the token of the interface I accessed changed, I needed to change the token value in the header of each request, which was too troublesome. I wonder if Postman can set the global variable, then I just need to update the token in one place and set it automatically in the other places. I looked it up and it did work.
However, Postman put the concept of variables in the Environment. If you think of variables as requests, then Environment is a Collection of variables.
① Current Environment
② View the value in the current Environment
You can add, delete or edit variables in the Environment.
Click ③ to open the panel below, which lists all the current Environment. Click the name of each Environment to enter and edit the variable to which it belongs.
Click ④ to create an Environment and create, edit, and delete variables. Click ⑤ to create, edit, and delete global variables directly. Global refers to variables that can be used by the Environment when a request is made.
Clicking (4) or (5) in the image above will open a panel to set the parameters. The difference is that (5) does not need to set the name of Environment.
Note that if you set the variable to Environment instead of global, you need to set the current Environment before sending the request. Click on (1) to select Environment.
I just used it for a while, but nothing happened. I developed my APP honestly until the test came to me. I said no, the data on your APP was wrong, and sometimes there was no data for half a day. This I can not endure, after MY investigation, the result is found to be a server problem, so I let the test again encounter this situation, using Postman test, to see their own data. I found a new Postman feature called Test.
Test
Test performs the corresponding Test logic for each request and response, such as whether the delay exceeds 200ms, whether the server response is 200, and so on, using JavaScript as the programming language.
Each request has a Tests Tab, and you can write your own code in the edit box below Tests. Each response also has a TestResult, which shows the execution result of each Test, whether it passed or failed, and if it failed, the specific reason.
The following is a simple test, the test item is the response time is less than 200ms and whether the response is successful “whether the response is successful, directly determine whether the server returned the status code is 200”.
As you can see, this test has one pass and one fail. The reason for the failure is that the request time of 1891ms is higher than our target value of 200ms.
Hey, are you thinking of testing something? Postman provides examples, as you can see in the Tests sidebar above, of some of the templates Postman provides. Just use it. If you don’t have enough templates, you can write your own. You can test both the Header and the Body.
For example, we generally specify the server response as the following type, and the client needs to determine whether the status is correct, and then the value, so we need to get the status, and then judge. Here is the sample data and test sample code.
{
"data": {
"isAgency": "0". "token": "456789..."
},
"msg": "OK". "oK": true. "status": 200 } Copy the code
var data = JSON.parse(responseBody)
var statusCode = data.status
pm.test("Test for abnormal interface".function () {
pm.expect(200).to.equal(statusCode)
})
Copy the code
Remember when we used Environment to set variables and then used them in the Header of the request? Test can also operate on variables. The following four methods enable you to value and assign Environment or global variables.
pm.environment.get("variable_key");
pm.environment.set("variable_key"."variable_value");
pm.globals.get("variable_key");
pm.globals.set("variable_key"."variable_value");
Copy the code
In this way, we can also use Test to update the Token automatically. When we check that the current interface returns normal data, we can write the Token to the Environment variable.
if (statusCode == 200) {
var token = data.data.token
pm.environment.set("token", token)
}
Copy the code
Collection Runner
That’s fine for a single request, but what about a lot of tests? Testers are not going to use this yet. Is there a batch testing tool? The answer is yes, it’s in a Collection. A Collection is a Collection of requests, and it provides a feature called Runner.
Click the icon pointed to by the arrow to enter the Collection Runner panel.
Look at the figure above. In area A, all interfaces in the current Collection can be selected to execute the scope, which is the entire Collection by default. In area B, the selected interfaces to be tested can also be sorted by dragging. The C block is the configuration of the whole test, such as how many times to execute, how many milliseconds between each request, whether to save the response, etc., after the configuration is complete, it can be executed.
This is the test result. I made three requests for a single interface in a single Collection. On this page, you can also view the information of each request for each request, including the request address, Header, Response, Response Header, and Response Body.
But also can export, the single request result is exported, the exported file is also JSON format, very convenient to view.
I didn’t expect Postman to be very useful, I recommend it to the test quickly. Next time there is a problem with the data, let him go directly to the background. There is still data in front of him, he can’t run away.
By the way, if you log in to Postman, Postman will also store the Collection and Environment variable in the cloud, which will be automatically synchronized between multiple devices.
The resources
- Test sample and official information
- Postman log print
- Collection Run
About me
I’m an average Android developer, and you can find me at Briefbooks, Nuggets, and my personal blog.
Cover image: Photo by Ian Schneider on Unsplash
This article was typeset using MDNICE