What is Postman?
Postman is a scalable API testing tool that quickly integrates into CI/CD pipeline. It started in 2012 as a side project by Abhinav Asthana to simplify API workflow in testing and development. API stands for Application Programming Interface which allows software applications to communicate with each other via API calls.
Why Use Postman?
With over 4 million users nowadays, Postman Software has become a tool of choice for the following reasons:
- Accessibility β To use Postman tool, one would just need to log-in to their own accounts making it easy to access files anytime, anywhere as long as a Postman application is installed on the computer.
- Use of Collections β Postman lets users create collections for their Postman API calls. Each collection can create subfolders and multiple requests. This helps in organizing your test suites.
- Collaboration β Collections and environments can be imported or exported making it easy to share files. A direct link can also be used to share collections.
- Creating Environments β Having multiple environments aids in less repetition of tests as one can use the same collection but for a different environment. This is where parameterization will take place which we will discuss in further lessons.
- Creation of Tests β Test checkpoints such as verifying for successful HTTP response status can be added to each Postman API calls which help ensure test coverage.
- Automation Testing β Through the use of the Collection Runner or Newman, tests can be run in multiple iterations saving time for repetitive tests.
- Debugging β Postman console helps to check what data has been retrieved making it easy to debug tests.
- Continuous Integration β With its ability to support continuous integration, development practices are maintained.
How to use Postman to execute APIs
Below is the Postman Workspace. Letβs explore the step by step process on How to use Postman and different features of the Postman tool!
- New β This is where you will create a new request, collection or environment.
- Import β This is used to import a collection or environment. There are options such as import from file, folder, link or paste raw text.
- Runner β Automation tests can be executed through the Collection Runner. This will be discussed further in the next lesson.
- Open New β Open a new tab, Postman Window or Runner Window by clicking this button.
- My Workspace β You can create a new workspace individually or as a team.
- Invite β Collaborate on a workspace by inviting team members.
- History β Past requests that you have sent will be displayed in History. This makes it easy to track actions that you have done.
- Collections β Organize your test suite by creating collections. Each collection may have subfolders and multiple requests. A request or folder can also be duplicated as well.
- Request tab β This displays the title of the request you are working on. By default, βUntitled Requestβ would be displayed for requests without titles.
- HTTP Request β Clicking this would display a dropdown list of different requests such as GET, POST, COPY, DELETE, etc. In Postman API testing, the most commonly used requests are GET and POST.
- Request URL β Also known as an endpoint, this is where you will identify the link to where the API will communicate with.
- Save β If there are changes to a request, clicking save is a must so that new changes will not be lost or overwritten.
- Params β This is where you will write parameters needed for a request such as key values.
- Authorization β In order to access APIs, proper authorization is needed. It may be in the form of a username and password, bearer token, etc.
- Headers β You can set headers such as content type JSON depending on the needs of the organization.
- Body β This is where one can customize details in a request commonly used in POST request.
- Pre-request Script β These are scripts that will be executed before the request. Usually, pre-request scripts for the setting environment are used to ensure that tests will be run in the correct environment.
- Tests β These are scripts executed during the request. It is important to have tests as it sets up checkpoints to verify if response status is ok, retrieved data is as expected and other tests.
Working with GET Requests
Get requests are used to retrieve information from the given URL. There will be no changes done to the endpoint.
We will use the following URL for all examples in this Postman tutorial https://jsonplaceholder.typicode.com/users
In the workspace
- Set your HTTP request to GET.
- In the request URL field, input link
- Click Send
- You will see 200 OK Message
- There should be 10 user results in the body which indicates that your test has run successfully.
**Note:* There may be cases that Get Postman request may be unsuccessful. It can be due to an invalid request URL or authentication is needed.
RELATED ARTICLES
- How to Download and Install Postman on Windows/MacOS
- How to Install and Use Postman Interceptor on Chrome?
Working with POST Requests
Post requests are different from Get request as there is data manipulation with the user adding data to the endpoint. Using the same data from the previous tutorial in Get request, letβs now add our own user.
Step 1) Click a new tab to create a new request.
Step 2) In the new tab
- Set your HTTP request to POST.
- Input the same link in request url: https://jsonplaceholder.typicode.com/users
- switch to the Body tab
Step 3) In Body,
- Click raw
- Select JSON
Step 4) Copy and paste just one user result from the previous get request like below. Ensure that the code has been copied correctly with paired curly braces and brackets. Change id to 11 and name to any desired name. You can also change other details like the address.
[
    {
        "id": 11,
        "name": "Krishna Rungta",
        "username": "Bret",
        "email": "Sincere@april.biz",
        "address": {
            "street": "Kulas Light",
            "suite": "Apt. 556",
            "city": "Gwenborough",
            "zipcode": "92998-3874",
            "geo": {
                "lat": "-37.3159",
                "lng": "81.1496"
            }
        },
        "phone": "1-770-736-8031 x56442",
        "website": "hildegard.org",
        "company": {
            "name": "Romaguera-Crona",
            "catchPhrase": "Multi-layered client-server neural-net",
            "bs": "harness real-time e-markets"
        }
    }
]
**Note:* Online Post request should have the correct format to ensure that requested data will be created. It is a good practice to use Get first to check the JSON format of the request. You can use tools like https://jsonformatter.curiousconcept.com/
Step 5) Next,
- Click Send.
- Status: 201 Created should be displayed
- Posted data are showing up in the body.
How to Parameterize Requests
Data Parameterization is one of the most useful features of Postman. Instead of creating the same requests with different data, you can use variables with parameters. These data can be from a data file or an environment variable. Parameterization helps to avoid repetition of the same tests and iterations can be used for automation testing.
Parameters are created through the use of double curly brackets: {{sample}}. Letβs take a look at an example of using parameters in our previous request:
Now letβs create a parameterize get request.
Step 1)
- Set your HTTP request to GET
- Input this link: https://jsonplaceholder.typicode.com/users. Replace the first part of the link with a parameter such as {{url}}. Request url should now be {{url}}/users.
- Click send.
There should be no response since we have not set the source of our parameter.
Step 2) To use the parameter you need to set the environment
- Click the eye icon
- Click edit to set the variable to a global environment which can be used in all collections.
Step 3) In variable,
- set the name to the url which is https://jsonplaceholder.typicode.com
- click Save.
Step 4) Go back to your Get request then click send. There should now be results for your request.
**Note:* Always ensure that your parameters have a source such as an environment variable or data file to avoid errors.
How to Create Postman Tests
Postman Tests are JavaScript codes added to requests that help you verify results such as successful or failed status, comparison of expected results, etc. It usually starts with pm.test. It can be compared to asserts, verify commands available in other tools.
Letβs do some basic API testing using Postman for our parameterize requests from the previous lesson.
Step 1) Go to your GET user request from the previous tutorial.
- Switch to the tests tab. On the right side are snippet codes.
- From the snippets section, click on βStatus code: Code is 200β.
The pane is auto-populated
Step 2) Now click Send. The test result should now be displayed.
Step 3) Go back to the test tab and letβs add another test. This time we will compare the expected result to the actual result.
From the snippets section, click on βResponse body:JSON value checkβ. We will be checking if Leanne Graham has the userid 1.
Step 4)
- Replace βYour Test Nameβ from the code with βCheck if user with id1 is Leanne Grahamβ so that the test name specifies exactly what we want to test.
- Replace jsonData.value with jsonData[0].name. To get the path, check the body in Get result earlier. Since Leanne Graham is userid 1, jsonData is in the first result which should start with 0. If you want to get the second result, use jsonData[1] and so on for succeeding results.
- In to eql, input βLeanne Grahamβ
pm.test("Check if user with id1 is Leanne Graham", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData[0].name).to.eql("Leanne Graham");
});
Step 5) Click send. There should now be two passed test results for your request.
**Note:* There are different kind of tests that can be created in Postman. Try to explore the tool and see what tests will fit your needs.
How to Create Collections
Collections play an important role in organizing test suites. It can be imported and exported making it easy to share collections amongst the team. In this tutorial, we will learn how to create and execute a collection.
Letβs start in creating a collection:
Step 1) Click on the New button at the top left corner of the page.
Step 2) Select Collection. Create collection window should pop up.
Step 3) Input the desired collection name and description then click create. A collection should now be created.
Step 4) Go back to the previous Get request. Click Save
Step 5)
- Select Postman Test Collection.
- Click Save to Postman Test Collection
Step 6) Postman test collection should now contain one request.
Step 7) Repeat steps 4-5 for the previous Post request so that collection will now have two requests.
How to Run Collections using Collection Runner
There are two ways to run a collection which is the Collection Runner and Newman. Letβs begin by executing the collection in Collection Runner.
Step 1) Click on the Collections found a Runs button.
Step 2) Collection Runner page should appear such as below. Following is the description of various fields
Step 3) Run your Postman Test Collection by setting up the following:
- Choose Postman test collection- Set iterations as 3
- Set delay as 2500 ms
- Click on Run Postman Test⦠button
Step 4) Run Results page should be displayed after clicking the Run button. Depending on the delay, you should see the tests as they execute.
- Once tests have finished, you can see the test status if it is Passed or Failed and the results per iteration.
- You see Pass status for the Get Requests
- Since we did not have any tests for Post, there should be a message that the request did not have any tests.
You can see how important it is that there are tests in your requests so that you can verify HTTP request status if successful and the data is created or retrieved.
Postman Free Plan limitation
While Postman's Free Plan provides an excellent starting point for users, it does have certain limitations. When these thresholds are surpassed, users will see an error message indicating, 'You have reached the monthly usage limits of your plan.' To continue enjoying the seamless experience with Postman, upgrading to a suitable plan is required.
Apidog, a superior alternative to Postman, offers unlimited API creation, no flow restrictions, and unrestricted testing with unlimited API and mock server calls in its Free Plan. Experience the ultimate flexibility for your projects with Apidog!
Conclusion
While Postman remains a popular choice for API development, the market offers numerous alternatives. Enter Apidogβan efficient solution that empowers developers to create, test, and manage APIs seamlessly, free from restrictions. We strongly advocate for Apidog as the preferred choice, ensuring an enhanced testing experience and overcoming limitations posed by Postman Collection Runner.
 
 
              




























 
    
Top comments (8)
This is exactly what I needed as a backend newbie - finally understood request chaining thanks to your clear examples!
Perfect guide for Postman beginners!
Try to write in detail so that everyone can learn Postman.
a Great Postman TutorialοΌ
Thank you for reading, bro
Try out Bruno. I've been using it for so long and loving it so far. It's the fact that it's open source and just does all the things I plan to use it for.
Thanks for introducing, I will try Bruno!
Go for it!