End To End API Testing
End To End API Testing
End to End API Testing, Automation API Test With Cucumber, Mock Interview Question for API Testing for
Backend Engineer, SDET, Software Quality Engineer, Software Quality Assurance, Software Test Engineer, and
Test Engineer
PART 1:
Version 1.0
Contact Information:
Email:lamhot.id@gmail.com
ite:https://lamhotjm.github.io
S
Linkedin:https://www.linkedin.com/in/lamhotsiagian
ips or Buy me a coffee:https://buymeacoffee.com/lamhot
T
TABLE OF CONTENTS
reface
P
1
Introduction to APIs and API Testing 3
Understanding APIs 3
Importance of API Testing 5
Types of APIs 7
Overview of API Testing Techniques 9
Common Interview Questions and Answers Related to Basic APIs 11
Setting Up Your API Testing Environment 14
Choose Your API Testing Tool 14
1. Postman 14
2. Insomnia 14
3. Swagger UI 15
4. SoapUI 15
5. HTTPie 15
6. Paw 16
7. JMeter 16
Install and Set Up the Tool 17
1. Installing Postman 17
2. Configuring Postman 18
3. Organize Your Requests 18
Using Collections 18
4. Configure and Send Requests 19
5. Validate Responses 19
6. Documentation and Collaboration 20
7. Advanced Features 20
Common Interview Questions & Answers Related to API Test Tools 21
Basic Questions 21
Intermediate Questions 21
Advanced Questions 22
Practical Questions 22
Troubleshooting Questions 23
Integration Questions 24
2
End to End APIs and API Testing, Curated by Lamhot Siagian
3
End to End API Testing, Curated by Lamhot Siagian
4
End to End APIs and API Testing, Curated by Lamhot Siagian
5
End to End API Testing, Curated by Lamhot Siagian
6
End to End APIs and API Testing, Curated by Lamhot Siagian
7
End to End API Testing, Curated by Lamhot Siagian
Preface
his book is structured to provide both practical knowledge and insights into real-world API testing
T
scenarios.ThechaptersaremeticulouslyorganizedtotakeyoufromthebasicsofAPItestingtoadvanced
topics such as security, performance testing, and automation. Here's a brief overview of the chapters:
1
End to End API Testing, Curated by Lamhot Siagian
Interview Preparation
achchaptercontainsasetofinterviewquestionsandsampleanswers,helpingyouprepareforAPItesting
E
roles in Backend Engineering, SDET (Software Development Engineer in Test), Software Quality
Assurance, and Test Engineering positions. These questions are inspired by my own experiences from
years of technical interviews in the United States and other resources.
ver the past seven years, I've meticulously gathered notes and questions from each interview,
O
summarizingthemintothisguide.Whetheryouareafreshgraduateoranexperiencedtester,thesenotes
willhelpyousolidifyyourunderstandingofkeyconceptswhilegivingyoutheconfidencetofaceanyAPI
testing interview.
E
● nd-to-end API testers seeking practical insights and automation tips
● QA professionals looking to enhance their API testing skills with Cucumber and Java
● Candidates preparing for backend testing roles, including SDET, Software Quality Engineers, and
Test Engineers
● Individuals seeking mock interview questions and answers to prepare for technical interviews
PI testing has been increasingly recognized for its efficiency, flexibility, and integration capabilities,
A
makingitavitalpartofanysoftwaretestingstrategy.Ihopethisbookhelpsyougainastrongfoundation
inAPItesting,andItrustthattheincludedinterviewquestionsandanswerswillbeavaluableresourcefor
your career progression.
Happy learning, and good luck with your API testing journey!
Lamhot Siagian
2
End to End APIs and API Testing, Curated by Lamhot Siagian
Chapter 1
Understanding APIs
PIs (Application Programming Interfaces) is fundamental for modern software development, as they
A
enabledifferentsoftwaresystemstocommunicatewitheachother.Here’sadetailedoverviewtohelpyou
understand what APIs are, how they work, and why they are important.
What is an API?
n API, or application programming interface, is a set of rules or protocols that enables software
A
applications to communicate with each other to exchange data, features and functionality..
simple way to understand how APIs work is to look at a common example—third-party payment
A
processing.Whenauserpurchasesaproductonane-commercesite,thesitemightprompttheuserto“Pay
with PayPal” or another type of third-party system. This function relies on APIs to make the connection.
- hen the buyer clicks the payment button, an APIcallissenttoretrieveinformation.Thisisthe
W
request.ThisrequestisprocessedfromanapplicationtothewebserverthroughtheAPI’sUniform
Resource Identifier (URI) and includes a request verb, headers, and sometimes, a request body.
- Afterreceivingavalidrequestfromtheproductwebpage,theAPIcallstotheexternalprogramor
web server, in this case, the third-party payment system.
- The server sends a response to the API with the requested information.
- The API transfers the data to the initial requesting application, in this case, the product website1
Components of an API
.
1 ndpoints: URLs that provide access to specific resourcesor functionalities.
E
2. Methods/HTTP Verbs: Actions that can be performed(e.g., GET, POST, PUT, DELETE).
3. Requests: Data sent by the client to the server.
4. Responses: Data sent back by the server to the client.
5. Headers: Metadata about the request or response (e.g.,authentication tokens, content type).
1
https://www.ibm.com/topics/api
3
End to End API Testing, Curated by Lamhot Siagian
6. Payload/Body: Data being sent with the request (typically in JSON or XML format).
.
1 utomation: Streamlines repetitive tasks, boostingproductivity.
A
2. Innovation: Enables external teams to innovate byleveraging existing functionalities.
3. Security: Adds a layer of protection by requiringauthentication and authorization.
4. Cost Efficiency: Reduces expenses by using third-party tools instead of developing in-house
systems.2
1. I ntegration: Connecting different applications andservices, such as integrating payment gateways
into e-commerce platforms.
2. Automation: Automating repetitive tasks, such as deployingcode, managing resources, or data
synchronization.
3. Data Access: Providing access to data from differentsources, such as retrieving weather data or
financial information.
4. Third-Party Services: Enabling third-party developersto build applications that interact with your
services, such as social media apps using Facebook or Twitter APIs.
5. Microservices Architecture: Facilitating communicationbetween microservices in a distributed
system.
API Documentation
ood API documentation is essential for developers to understand how to use the API effectively. It
G
typically includes:
.
1 ndpoint Descriptions: Detailed information aboutavailable endpoints and their purposes.
E
2. HTTP Methods: The methods supported by each endpoint(e.g., GET, POST).
3. Parameters: Required and optional parameters for eachendpoint.
4. Request and Response Formats: Examples of requestpayloads and expected responses.
5. Authentication: Information about authentication andauthorization mechanisms.
6. Error Handling: Common error codes and messages, alongwith troubleshooting information.
2
https://www.postman.com/what-is-an-api/#benefits-of-apis
4
End to End APIs and API Testing, Curated by Lamhot Siagian
PI testing is a crucial aspect of software development, offering numerous benefits and addressing key
A
challenges that can significantly impact the quality, reliability, andperformanceofsoftwareapplications.
Here are the primary reasons why API testing is important:
● V erification of Requirements: API testing ensuresthat the API functions according to the specified
requirements. This involves checking that the endpoints are working correctly, the data is being
processed as expected, and the correct responses are returned.
● Detection of Errors Early: By testing APIs early inthe development cycle, errors can be detected
and fixed before they become more difficult and costly to resolve.
● C onsistent Performance: Regular API testing helpsensure that the API performs consistently
under various conditions, reducing the likelihood of unexpected failures in production
environments.
● Regression Testing: API tests can be automated andincluded in regression testing to ensure that
new changes do not break existing functionality.
● I dentification of Vulnerabilities: API testing canreveal security vulnerabilities such as SQL
injection, cross-site scripting (XSS), and other common exploits.
● Validation of Authentication and Authorization: Ensuresthat security mechanisms like
authentication and authorization are working correctly, protecting sensitive data and functionality
from unauthorized access.
● L oad and Stress Testing: API testing includes performancetests such as load and stress testing,
which help determine how well the API performs under heavy traffic and identify potential
bottlenecks.
● Scalability Assessment: Helps in assessing whetherthe API can scale effectively to handle
increased load as the user base grows.
● E nsures Smooth Integration: For APIs that are consumedby external developers or third-party
applications, thorough testing ensures that these integrations work smoothly, providing a better
user experience.
● Reduces Downtime: By identifying and resolving issuesearly, API testing helps reduce the chances
of downtime, ensuring that end-users experience fewer disruptions.
5
End to End API Testing, Curated by Lamhot Siagian
● A utomated Testing: API tests can be automated and integrated into CI/CD pipelines, providing
quick feedback to developers and ensuring that changes do not introduce new issues.
● Continuous Monitoring: Ongoing API testing helps monitorthe API's health and performance
continuously, allowing for rapid response to issues.
● I mproved Debugging: API tests provide detailed informationabout failures, making it easier for
developers to debug and resolve issues.
● Documentation and Clarity: Writing API tests oftenhelps clarify the API's functionality and
expected behavior, which can improve the quality of documentation and assist other developers in
understanding how to use the API.
● L ower Maintenance Costs: Identifying and fixing issuesearly in the development process reduces
the costs associated with post-release maintenance and support.
● Fewer Production Issues: Well-tested APIs are lesslikely to cause issues in production, leading to
reduced costs related to bug fixes and customer support.
● A dherence to Standards: API testing ensures that theAPI complies with industry standards and
protocols, which is particularly important for APIs in regulated industries.
● Contract Testing: Validates that the API contracts(the agreed-upon schema and behavior between
API consumers and providers) are maintained, ensuring compatibility and reliability.
6
End to End APIs and API Testing, Curated by Lamhot Siagian
Types of APIs
PIscomeinvariousforms,eachwithitsownstrengthsandpurposes.Understandingthesedifferencesis
A
essentialforpickingtherightAPIforyourprojectandensuringyourapplicationiseffective,scalable,and
reliable.Let’slookatthedifferenttypesofAPIs,exploringwhatmakeseachuniqueandhowtheyfitinto
modern software development.
This table provides a high-level overview of various API types, their descriptions, and examples.3
ibrary-based
L art of software libraries,
P J ava API for Android app development, .NET
APIs language-specific, range from basic libraries used in Windows applications
utilities to complex GUI components
perating
O rovide interfaces for OS interaction,
P indows API for Windows OS interaction,
W
system APIs manage hardware resources and POSIX API for UNIX-like systems
processes
Database APIs E
nable interaction with database QL API for relational databases, Oracle’s
S
management systems, facilitate data OCI for Oracle databases
querying and manipulation
ardware
H llow communication with hardware
A I oT device APIs for smart home systems,
APIs devices, direct control over hardware Printer APIs for document processing
functions
TTP APIs
H acilitate client-server communication W
F eb services, mobile apps, IoT devices, social
(web API) over the web, use standard HTTP media platforms, content management
methods, lightweight and flexible systems
EST APIs
R se HTTP requests for data
U eb services accessible via the web, social
W
(web API) operations, stateless and separate media APIs, cloud services
client-server concerns
OAP APIs
S se service interfaces to expose
U nterprise-level services like banking,
E
(web API) business logic, high security, suitable healthcare, where security and transactions
for enterprise-level organizations are critical
raphQL
G lients request only needed data,
C omplex data-driven web and mobile
C
APIs (web reduce data transfer over the network, applications, ad-hoc queries by the client
API) support multiple responses in one
request
3
https://www.nylas.com/api-guide/types-of-apis/
7
End to End API Testing, Curated by Lamhot Siagian
pen APIs
O ccessible by third-party developers,
A witter API for tweets, Stripe API for
T
(public APIs) typically for external users, require payments, providing data or services to
API keys external developers
omposite
C ombine different data and service
C ggregating various services in a single call
A
APIs APIs, access multiple endpoints in one for smoother user experience, commonly used
call in microservices architectures
ynchronous
S ynchronous: Request-response
S ynchronous: Essential data retrieval, web
S
and model, Asynchronous: Non-blocking, page loading, Asynchronous: Background
asynchronous no immediate response required tasks, real-time data streams
ibrary-based
L art of software libraries,
P J ava API for Android app development, .NET
APIs language-specific, range from basic libraries used in Windows applications
utilities to complex GUI components
8
End to End APIs and API Testing, Curated by Lamhot Siagian
O
● bjective: Test individual API components in isolation.
● Tools: JUnit (Java), NUnit (C#), pytest (Python).
● Description: Unit tests are typically written by developersto test the functionality of specific
methods or functions in the API, ensuring that each part works as intended.
O
● bjective: Verify that the API performs its intendedfunctions correctly.
● Tools: Postman, SoapUI, REST Assured.
● Description: Functional tests validate the API againstthe functional requirements and
specifications. This includes testing endpoints, methods (GET, POST, PUT, DELETE), and responses.
O
● bjective: Ensure that the API interacts correctlywith other components and systems.
● Tools: Postman, SoapUI, JUnit (with integration testconfigurations).
● Description: Integration tests evaluate the interactionsbetween different parts of the API and other
services or databases to ensure that integrated parts work together as expected.
O
● bjective: Assess the API’s performance under variousconditions.
● Tools: JMeter, LoadRunner, Gatling.
● Description: Performance tests include load testing(to check API behavior under expected load),
stress testing (to determine the API’s breaking point), and endurance testing (to evaluate
performance over an extended period).
O
● bjective: Identify vulnerabilities and ensure theAPI is secure.
● Tools: OWASP ZAP, Burp Suite, Postman (with securityextensions).
● Description: Security testing involves checking forcommon vulnerabilities like SQL injection,
cross-site scripting (XSS), and ensuring proper authentication and authorization mechanisms are in
place.
O
● bjective: Ensure the API is easy to use and well-documented.
● Tools: Swagger, Postman.
● Description: Usability testing focuses on the API’suser experience, ensuring that the
documentation is clear, the endpoints are intuitive, and error messages are helpful.
9
End to End API Testing, Curated by Lamhot Siagian
O
● bjective: Validate the API’s functionality, performance, and security comprehensively.
● Tools: Postman, SoapUI.
● Description: Validation testing ensures that the APImeets the business requirements and
expectations, combining functional, performance, and security testing aspects.
O
● bjective: Ensure the API complies with industry standardsand regulations.
● Tools: Postman, SoapUI, custom scripts.
● Description: Compliance testing checks if the APIadheres to legal and regulatory requirements,
such as GDPR, HIPAA, and other industry-specific standards.
O
● bjective: Test the API in isolated environments bysimulating dependencies.
● Tools: WireMock, MockServer, Postman (mock servers).
● Description: Mocking and virtualization allow testersto simulate the behavior of the API’s
dependencies, enabling testing in scenarios where real dependencies are unavailable or difficult to
configure.
O
● bjective: Ensure new changes do not negatively affectexisting functionality.
● Tools: Postman, SoapUI, automated test scripts.
● Description: Regression testing involves re-runningpreviously conducted tests to verify that new
code changes have not introduced any new bugs or issues.
● utomation: Automate as many tests as possible toensure efficiency and repeatability.
A
● Version Control: Keep track of API versions and ensuretests are updated accordingly.
● Environment Management: Use consistent environmentsfor testing to avoid discrepancies.
● Data Management: Use realistic data for testing touncover potential issues.
● Continuous Integration/Continuous Deployment (CI/CD):Integrate API testing into the CI/CD
pipeline to catch issues early.
10
End to End APIs and API Testing, Curated by Lamhot Siagian
2. Can you explain the difference between REST and SOAP APIs?
Answer:
3. What are the main HTTP methods used in RESTful APIs and what are their purposes?
Answer:
● ET: Retrieve data from the server.
G
● POST: Submit data to the server to create a new resource.
● PUT: Update an existing resource on the server.
● DELETE: Remove a resource from the server.
● PATCH: Apply partial modifications to a resource.
nswer:AnAPIendpointisaspecificURLthatprovidesaccesstoaparticularresourceorfunctionalityof
A
theAPI.ItrepresentsoneofthediscreteunitsofinteractioninanAPIandistypicallyacombinationofthe
base URL and a resource path.
11
End to End API Testing, Curated by Lamhot Siagian
s ession information about the client between requests, making each request independent and
self-contained.
nswer:AnAPIkeyisauniqueidentifierusedtoauthenticateaclientaccessinganAPI.Ithelpstrackand
A
control how the API is used, ensuring that only authorized users can make requests. API keys are
commonly used for security purposes to prevent misuse and limit the number of requests from a client.
nswer: CORS (Cross-Origin Resource Sharing) is a security feature implemented by web browsers to
A
preventwebpagesfrommakingrequeststoadifferentdomainthantheonethatservedthewebpage.Itis
important in webAPIsbecauseitenablesserverstospecifywhocanaccesstheirresources,ensuringthat
only trusted domains can make cross-origin requests.
8. What are some common status codes returned by APIs, and what do they mean?
Answer:
● 00 OK: The request was successful.
2
● 201 Created: A new resource was successfully created.
● 204 No Content: The request was successful, but thereis no content to return.
● 400 Bad Request: The request was invalid or cannotbe processed.
● 401 Unauthorized: Authentication is required and hasfailed or not been provided.
● 403 Forbidden: The server understands the requestbut refuses to authorize it.
● 404 Not Found: The requested resource could not befound.
● 500 Internal Server Error: An error occurred on theserver side.
9. What is the purpose of API versioning and how can it be implemented?
nswer:APIversioningensuresthatchangesintheAPIdonotbreakexistingclientapplications.Itallows
A
developers to introduce new features andimprovementswithoutdisruptingthecurrentfunctionalityfor
existing users. Versioning can be implemented in several ways:
U
● RL Path: Including the version number in the URL (e.g., /v1/users).
● Query Parameters: Adding a version parameter in the query string (e.g., ?version=1).
● Headers: Using a custom header to specify the version (e.g., Accept:
application/vnd.myapi.v1+json).
10. What are the differences between synchronous and asynchronous API calls?
Answer:
12
End to End APIs and API Testing, Curated by Lamhot Siagian
T
○ he client sends a request and waits for the server to respond.
○ The client is blocked until the response is received.
○ Simple and straightforward but can lead to inefficiencies if the server takes a long time to
respond.
Asynchronous API Calls:
●
○ The client sends a request and continues processing other tasks.
○ The client is notified (usually via a callback or promise) when the response is ready.
○ More efficient for long-running operations, as it doesn't block the client.
Answer:RatelimitingisamechanismtocontrolthenumberofrequestsaclientcanmaketoanAPIwithin
certain time period. It is important for:
a
● P reventing Abuse: Protects the API from being overwhelmedby too many requests from a single
client.
● Ensuring Fair Usage: Ensures that all clients havefair access to the API.
● Maintaining Performance: Helps maintain the API'sperformance and availability by avoiding
excessive load.
nswer: API throttling is a technique used to control the usage of an API by limiting the number of
A
requests that can be made in aspecifictimeframe.Ithelpsinmanagingtheloadontheserver,ensuring
serviceavailability,andpreventingabuse.Throttlingcanbeimplementedbysettingalimitonthenumber
of requests per minute, hour, or day.
13
End to End API Testing, Curated by Lamhot Siagian
Chapter 2
anualAPItestingtoolsaredesignedtoallowtesterstointeractwithAPIsinanintuitive,oftengraphical
M
interface, providing the capability to sendrequests,inspectresponses,andvalidatefunctionalitywithout
writing code. Here are some popular manual API testing tools along with their key features:
1. Postman
Features:
U
● ser-Friendly Interface: Intuitive interface for creating,saving, and organizing API requests.
● Support for Various HTTP Methods: Supports GET, POST,PUT, DELETE, PATCH, and more.
● Environment Variables: Allows setting up differentenvironments (e.g., development, testing,
production) and switching between them easily.
● Collections: Organize requests into collections andfolders.
● Automated Testing: Basic automated testing capabilitiesusing JavaScript.
● Mock Servers: Create mock servers to simulate endpointsand responses.
● Collaboration: Team collaboration features to sharecollections and environments.
Website:Postman
2. Insomnia
Insomniais another popular API client that emphasizessimplicity and ease of use.
Features:
● imple Interface: Clean and straightforward interfacefor creating and managing requests.
S
● Environment Variables: Support for environment variablesto manage different configurations.
● GraphQL Support: Native support for GraphQL queriesand mutations.
● Plugins: Extend functionality with community plugins.
● Scripting: Pre-request scripts and response templatingwith Nunjucks.
Website:Insomnia
14
End to End APIs and API Testing, Curated by Lamhot Siagian
Features:
4. SoapUI
Features:
● xtensive Protocol Support: Supports REST, SOAP, GraphQL,and other protocols.
E
● Data-Driven Testing: Supports data-driven testingusing various data sources.
● Assertions: Rich set of assertions for validatingresponses.
● Automation: Scripting support with Groovy.
● Load Testing: Built-in capabilities for performanceand load testing.
Website:SoapUI
5. HTTPie
TTPie is a command-line HTTP client designed to make CLI interaction with web services as
H
human-friendly as possible.
Features:
● ser-Friendly CLI: Simple syntax for making requestsand viewing responses.
U
● JSON Support: Automatically formats JSON responses.
● Plugins: Extensible with plugins.
● Scripting: Suitable for inclusion in shell scriptsfor automated testing.
Website:HTTPie
15
End to End API Testing, Curated by Lamhot Siagian
6. Paw
Features:
● ac Integration: Explicitly designed for macOS, withnative look and feel.
M
● Environment Variables: Support for environments andvariables.
● Extensions: Create custom Paw extensions using JavaScript.
● Response Rendering: View responses in various formats(e.g., JSON, XML, HTML).
Website:Paw
7. JMeter
J Meter, an open-source project, is renowned for its performance testing capabilities, though it also
effortlessly accommodates API testing. It features a user-friendly interface that simplifies the creationof
complex tests.
Features of JMeter:
● E asytosetup:SettingupJMeterisstraightforward.ItjustrequiresdownloadingtheJMeterjarto
start testing.
● Open-source: Beingopensource,JMeteroffersallitsfeaturesforfree,makingitanaccessibletool
for everyone.
● Powerful CLI tool: Beyond its UI, JMeter can execute tests via its command-line interface,
providing users extensive options, including reporting functionalities.
● Extensible: The tool's capabilities can be expanded through numerous plugins, which users can
easily download and integrate.
● Multiple operating systems support: As a Java (jar) application, JMeter is compatible with any
operating system that supports Java, broadening its usability.
Pricing:
Who′s It For?
J Meter is suitable for developers and testers who require a robust performance and API testing tool.Its
extensibility and support for multiple operating systems make it a versatile choice for many users.
However, due to its complexity and high memory consumption, it might be more suited for thosewith
more experience in testing or those willing to invest time in learning the tool.
16
End to End APIs and API Testing, Curated by Lamhot Siagian
. D
1 ownload Postmanfrom the official website:PostmanDownload.
2. Installthe application by following the installation instructions for your operating system
(Windows, macOS, Linux).
3. Sign upfor a Postman account (optional but recommendedfor saving and syncing your work).
ou can download and install the Postman CLI manually or programmatically (with a script or the
Y
command line).
System requirements
he Postman CLI supports the exact operating system requirements as the Postman desktop app. For a
T
complete list of system requirements, see Installing and updating Postman.
Windows installation
un the following commands to install the Postman CLI for Windows. This will download an install script
R
and run it. The install script creates a %USERPROFILE%\AppData\Local\Microsoft\WindowsApps
directory if it doesn't exist yet, then installs a postman binary there.
un the following command to install the Postman CLI for Macs with an Apple silicon processor. This will
R
download an install script and run it. The install script creates a/usr/local/bindirectory if it doesn'texist
yet, then installs a postman binary there.
un the following command to install the Postman CLI for Macs with Intel chips. This will download an
R
install script and run it. The install script creates a/usr/local/bindirectory if it doesn't exist yet,then installs
a postman binary there.
4
https://learning.postman.com/docs/postman-cli/postman-cli-installation/
17
End to End API Testing, Curated by Lamhot Siagian
Linux installation
un the following command to install the Postman CLI for the latest Linux version. This will download an
R
install script and run it. The install script creates a /usr/local/bin directory if it doesn't exist yet, then
installs a postman binary there.
o update your Postman CLI installation to the latest version, run the same command you used to install.
T
The new version will overwrite the earlier version.
. O
1 pen Postman.
2. Create a New Workspace:
○ Click on your workspace name in the top left.
○ Select "Create Workspace".
○ Name your workspace and provide a description (optional).
○ Choose the visibility (Personal, Team, Public).
3. Set Up Environments:
○ Click on the gear icon in the top right corner and select "Manage Environments".
○ Click "Add" to create a new environment.
A
○ baseUrl
dd variables such as apiKey
, , etc.
○ Save the environment.
Using Collections
18
End to End APIs and API Testing, Curated by Lamhot Siagian
○ Enter the request URL using environment variables if needed (e.g.,
{baseUrl}}/endpoint
{ ).
3. Organize Requests:
○ Create folders within collections to group related requests.
○ Drag and drop requests into folders for better organization.
1. C heck Status Codes: Ensure the API returns the expectedHTTP status code (e.g., 200 for success,
404 for not found).
2. Validate Response Body:
○ Check that the response body contains the expected data.
○ Use Postman’s built-in JSON viewer for easy navigation.
3. Use Tests for Validation:
○ Click on the "Tests" tab in the request editor.
○ Write JavaScript code to perform assertions on the response.
Example:
19
End to End API Testing, Curated by Lamhot Siagian
1. E nvironment and Global Variables: Manage different environments (e.g., development, staging,
production) using environment variables. Define global variables for values that are used across
multiple environments.
2. Pre-Request Scripts: Write JavaScript code to executebefore a request is sent. Useful for setting
dynamic variables.
3. Mock Servers: Create mock servers to simulate APIendpoints and responses.
20
End to End APIs and API Testing, Curated by Lamhot Siagian
erearecommoninterviewquestionsrelatedtomanualAPItestingtools,alongwithbriefanswerstohelp
H
you prepare for interviews:
Basic Questions
ostman is a popular API development and testing tool that allows users to create, test, document,
P
and share APIs.
ou can install Postman by downloading it from the Postman website and following the installation
Y
instructions for your operating system.
collection in Postman is a group of related API requests that can be organized into folders and
A
subfolders. It helps in organizing and managing your API tests efficiently.
lick on the "New" button, select "Request," enter a request name, and specify the HTTP method
C
and URL.
ostman supports all standard HTTP methods, including GET, POST, PUT, DELETE, PATCH,
P
HEAD, OPTIONS.
Intermediate Questions
Click the gear icon, select "Manage Environments," and create new environments by defining
baseUrl
variables like apiKey
, , etc.
nvironment variables are placeholders for values that can change depending on the environment
E
(e.g., development, staging, production). They make requests reusable across different
environments.
21
End to End API Testing, Curated by Lamhot Siagian
In the request editor, go to the "Headers" tab and add key-value pairs for headers such as
Content-Type
Authorization
, , etc.
se the "Authorization" tab in the request editor to set up authentication mechanisms like Basic
U
Auth, Bearer Token, OAuth, API Key, etc.
he "Tests" tab allows you to write JavaScript code to perform assertions on the response, validate
T
data, and automate test scripts.
Advanced Questions
rite test scripts in the "Tests" tab and use the Postman CLI tool, Newman, to run collections from
W
the command line for automated testing.
ewman is a command-line collection runner for Postman, allowing you to run and test Postman
N
collections directly from the CLI.
se the "Pre-request Script" tab to write JavaScript code that executes before the request is sent,
U
helpful in setting dynamic variables and pre-request logic.
ariables in Postman can be defined at different scopes: global, environment, collection, and local.
V
They store values that can be reused in requests and scripts.
Practical Questions
22
End to End APIs and API Testing, Curated by Lamhot Siagian
Click on the collection, select "Export," and choose the format (v2.1 or v2.0) to save it as a JSON file.
lick on the "Import" button, select the file or paste the raw text of the collection JSON, and import
C
it.
ostman monitors are automated runs of your Postman collections at scheduled intervals to check
P
the performance and health of your APIs.
avigate to the "Mock Server" section, create a new mock server, and associate it with an existing
N
collection to simulate endpoints and responses.
dd detailed descriptions to requests and collections, use Markdown for formatting, and generate
A
documentation using Postman's built-in documentation feature.
Troubleshooting Questions
heck the response status code, headers, and body. Use console logs in test scripts and the Postman
C
console to debug issues.
22. What are some common HTTP status codes you might encounter?
ommon status codes include 200 OK, 201 Created, 400 Bad Request, 401 Unauthorized, 403
C
Forbidden, 404 Not Found, and 500 Internal Server Error.
se pre-request scripts and environment variables to generate and store dynamic data, such as
U
timestamps or random values.
rite JavaScript test scripts to check if the response body contains the expected JSON structure and
W
values.
25. What is the difference between global and environment variables in Postman?
23
End to End API Testing, Curated by Lamhot Siagian
lobal variables are available across all collections and environments, while environment variables
G
are specific to a particular environment.
Integration Questions
se Newman to run Postman collections in CI/CD pipelines by integrating it with tools like
U
Jenkins, GitLab CI, Travis CI, etc.
he Postman API allows you to programmatically access and manage Postman resources, such as
T
collections, environments, and monitors.
I mplement delay logic in test scripts or pre-request scripts to wait between requests, or configure
Postman monitors to run at intervals within the rate limits.
29. How can you share Postman collections with your team?
hare collections by generating a shareable link, exporting the collection file, or using Postman’s
S
built-in team workspaces for collaboration.
30. What are Postman workspaces, and how do they help in collaboration?
orkspaces in Postman are collaborative spaces where team members can share collections,
W
environments, and other resources, making it easier to work together on API development and
testing.
24
End to End APIs and API Testing, Curated by Lamhot Siagian
Chapter 3
HTTP Methods
ESTfacilitateseasydatasharingbetweenclientsandservers.RESTfulapplicationsutilizeHTTPmethods
R
such as GET, POST, DELETE, and PUT to perform CRUD (Create, Read, Update, Delete) operations.
y now, you should understand how the HTTP protocol operates, includingthevariousHTTPmethods
B
and their appropriate uses. This section will delve deeperintoeachprocess,startingwithGET,themost
commonly used HTTP method. So, let's dive in!
1. GET
P
● urpose:Retrieve data from a server.
● Usage:Requests data from a specified resource.
● Idempotent:Yes, calling GET multiple times does notchange the resource state.
25
End to End API Testing, Curated by Lamhot Siagian
2. POST
P
● urpose:Send data to the server to create a new resource.
● Usage:Submits data to be processed to a specified resource, often causing a change in state or side
effects on the server.
● Idempotent:No, multiple POST requests may resultin multiple resource creations.
3. PUT
P
● urpose:Update or replace an existing resource orcreate a new one if it does not exist.
● Usage:Sends data to a specified resource, often replacingthe resource entirely.
● Idempotent:Yes, multiple PUT requests with the samedata result in the same resource state.
4. DELETE
P
● urpose:Remove a specified resource from the server.
● Usage:Deletes the specified resource.
● Idempotent:Yes, deleting a resource multiple timeshas the same effect as deleting it once.
26
End to End APIs and API Testing, Curated by Lamhot Siagian
5. PATCH
P
● urpose:Apply partial modifications to a resource.
● Usage:Sends partial data to update an existing resource.
● Idempotent:Yes, applying the same PATCH multipletimes will result in the same state.
6. HEAD
P
● urpose:Retrieve headers for a resource, similarto GET but without the response body.
● Usage:Used to obtain metadata about a resource, suchas headers.
● Idempotent:Yes, calling HEAD multiple times doesnot change the resource state.
7. OPTIONS
P
● urpose:Describe the communication options for thetarget resource.
● Usage:Used to determine the HTTP methods and otheroptions supported by a web server.
● Idempotent:Yes, it does not change the resource state.
8. CONNECT
27
End to End API Testing, Curated by Lamhot Siagian
● U sage:Mainly used for tunneling, such as establishing a VPN or SSL connection through an HTTP
proxy.
● Idempotent:Yes, it establishes a connection but does not change the resource state.
9. TRACE
P
● urpose:Perform a message loop-back test along thepath to the target resource.
● Usage:Used for diagnostic purposes to trace the pathof a request.
● Idempotent:Yes, it is a diagnostic method and doesnot alter the resource state.
equest
R RFC equest has
R esponse has
R Safe Idempotent Cacheable
method payload body payload body
5
https://en.wikipedia.org/wiki/HTTP
28
End to End APIs and API Testing, Curated by Lamhot Siagian
Request Headers
TTP headers are key-value pairs sent between the client and the server along with the request or
H
response.Theyprovidemetadataabouttherequestorthedatabeingsent.Somecommonrequestheaders
include:
● U ser-Agent: Identifies the client making the request,often containing information about the user
agent's software and operating system.
● Host: Specifies the domain name of the server beingrequested.
● Accept: Informs the server about the types of mediathat the client can process.
● Content-Type: Specifies the media type of the requestbody, typically used in POST and PUT
requests.
● Authorization: Contains credentials for authenticatingthe client with the server, often used with
Basic or Bearer authentication.
● Cookie: Contains stored HTTP cookies previously sentby the server with the Set-Cookie header.
Request Parameters
equestparametersarekey-valuepairssentintheURLquerystringorintherequestbody.Theyprovide
R
additional data to the server, often used for filtering, sorting, or providing context to the request. Some
common types of request parameters include:
● Q
uery Parameters: Appended to the end of the URL aftera question mark (?), query parameters are
key-value pairs separated by ampersands (&). For example,
ttps://example.com/search?q=term&page=1
h .
Path Parameters: Used to parameterize parts of theURL path, typically denoted by placeholders in
●
t he URL. For example,https://example.com/users/{id} .
Form Data: Sent in the body of POST requests, formdata consists of key-value pairs encoded in
●
application/x-www-form-urlencodedor
either multipart/form-data .
● J SON/XML Data: In RESTful APIs, data can be sent inJSON or XML format in the request body.
Example Request:
29
End to End API Testing, Curated by Lamhot Siagian
Host: example.com
ser-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko)
U
Chrome/91.0.4472.124 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
Accept-Language: en-US,en;q=0.9
Query Parameter
Structure:
Q
● uery parameters are separated by an ampersand (&) if there are multiple parameters.
● Each parameter consists of a key and a value, separated by an equals sign (=).
Example:
https://api.example.com/search?q=example&limit=10&page=2
●
https://api.example.com/searchis the base URL.
●
q=example limit=10
, page=2are query parameters.
, and
q=example
● The key-value pairs are limit=10
, page=2
, and .
q,
● The keys are limit page
, and example
, and their respectivevalues are 10
, 2.
, and
Usage:
● Filtering: Query parameters are commonly used forfiltering data. For example,
?category=booksto filter products by category.
● P pageand
agination: Parameters like limitare frequentlyused for pagination to retrieve a subset
of results.
30
End to End APIs and API Testing, Curated by Lamhot Siagian
Fragment Parameters
ragmentparameters,alsoknownasfragmentidentifiersorhashfragments,arecomponentsofaURLthat
F
appearafterahashsymbol(#).Theyarecommonlyusedtospecifyaspecificsectionorresourcewithina
web page, especially in client-side scripting and navigation.
Structure:
F
● ragment parameters are appended to the end of a URL after a hash symbol (#).
● They typically consist of key-value pairs or identifiers that denote a specific section or resource
within a document.
● Fragment parameters do not get transmitted to the server; they are processed exclusively by the
client-side browser.
Example:
https://example.com/page#section1
●
https://example.com/pageis the base URL.
●
#section1is the fragment parameter.
section1
● I t denotes that the browser should navigate to or highlight the section with the identifier
within the document.
Character Encoding
pecialcharactersareencodedintheURL,byamechanismcalled“percentencoding”.Inthismechanism
S
any character can be replaced by the percent symbol, followed by a two-digit hexadecimal value of the
encoded character. If special characters (such as the hash character) need to be sent as actual data,they
must be encoded. All other characters can optionally be encoded.
haracter encoding is a process used to represent characters in a computer's memory or storage by
C
assigning each character auniquenumericalvalue.Thisallowscomputerstostore,transmit,anddisplay
textual data in various human-readable languages and scripts. Here's an overview:
Unicode:
31
End to End API Testing, Curated by Lamhot Siagian
nicodeisthemostcommonlyusedcharacterencodingstandardtoday.Itassignsuniquenumericalvalues
U
(code points) to characters from virtually all writing systems and symbols used worldwide. Unicode
supports over 143,000 characters, covering various scripts, symbols, emoji, and special characters.
UTF-8:
TF-8(UnicodeTransformationFormat-8)isavariable-widthcharacterencodingthatrepresentsUnicode
U
charactersusing8-bitcodeunits.It'sthemostwidelyusedencodingontheinternetduetoitscompatibility
withASCII(AmericanStandardCodeforInformationInterchange)anditsabilitytorepresentallUnicode
characters efficiently.
Other Encodings:
● U TF-16: Represents Unicode characters using 16-bitcode units. It's commonly used in
environments that require fixed-width characters, such as Windows operating systems.
● ISO 8859-1 (Latin-1): A widely used single-byte encoding that supports Western European
languages. It's not as versatile as Unicode and may not support characters from other writing
systems.
● ASCII: A 7-bit character encoding standard that representsbasic English characters, symbols, and
control characters. It's compatible with UTF-8, making it a subset of Unicode.
Size Limits
hile the URI standard remains silent on prescribing a maximum URL size, many clients impose an
W
arbitrary limit of 2000 characters. When handling data that's intricate or exceeds this threshold, it's
advisabletotransmititwithinthebodyoftherequest.Thisisparticularlyrelevantwhendealingwithdata
that's challenging to represent hierarchically.
s we explored in the SOAP vs. REST comparison, the request's body offers a versatile canvas for
A
structuring data, accommodating various machine-readable formats. While XML and JSON formats are
prevalent, the flexibility also extends to other formats.
yleveragingtherequestbodyfortransmittingsizableorcomplexdata,APIscansidesteptheconstraints
B
posed by URL character limits. This approach not only fosters cleaner, more maintainableAPIsbutalso
enhances interoperability and scalability.
32
End to End APIs and API Testing, Curated by Lamhot Siagian
TTPstatuscodesarestandardizednumericalcodesthatindicatetheoutcomeofanHTTPrequest.They
H
provideinformationabouttheresultoftherequestandwhetheritwassuccessfulorencounteredanerror.
Here are some common HTTP status codes and their meanings:
● 1 00 Continue: The server has received the initialpart of the request and is willing to accept further
processing.
● 101 Switching Protocols: The server is indicatinga change in protocol requested by the client (e.g.,
switching from HTTP to WebSocket).
● 102 Processing(WebDAV; RFC 2518): A WebDAV requestmay contain many sub-requests
involving file operations, requiring a long time to complete the request.
● 103 Early Hints(RFC 8297): Used to return some responseheaders before final HTTP message.
2xx Success
2
● 00 OK: The request was successful.
● 201 Created: The request has been fulfilled, and anew resource has been created.
● 202 A
ccepted: The request has been accepted for processing, but the processing has not been
completed.
● 204 No Content:The server successfully processedthe request but is not returning any content.
● 2 05 Reset Content: The server successfully processed the request,asksthattherequesterresetits
document view,andisnotreturninganycontent.Thisstatuscodeistypicallyusedinconjunction
with form submissions.
● 2 06PartialContent:Theserverisdeliveringonlypartoftheresource(byteserving)duetoarange
header sentbytheclient.Thisstatuscodeiscommonlyusedforresuminginterrupteddownloads
or splitting a download into multiple simultaneous streams.
● 2 07Multi-Status:Thisstatuscode,definedinWebDAV(RFC4918),indicatesthatthemessagebody
contains an XML message bydefaultandcancontainseveralseparateresponsecodes,depending
on how many sub-requests were made.
● 2 08AlreadyReported:DefinedinWebDAV(RFC5842),thisstatuscodeindicatesthatthemembers
of a DAV binding have already been enumerated in aprecedingpartoftheresponseandarenot
being included again.
● 2 26IMUsed:DefinedinRFC3229,thisstatuscodeindicatesthattheserverhasfulfilledarequest
for the resource, and the response is a representation of the result of one or more
instance-manipulations applied to the current instance. It's used in conjunction with
instance-manipulation applied to the resource.
33
End to End API Testing, Curated by Lamhot Siagian
3xx Redirection
● 00 Multiple Choices: Indicates multiple options forthe resource that the client may follow.
3
● 301 Moved Permanently: The requested resource has been permanently moved to a new URL.
● 302 Found: The requested resource temporarily residesunder a different URL.
● 304NotModified:Theclient'scachedcopyoftherequestedresourceisstillvalid.Thisstatuscode
indicates that the resource has not been modified since the lastrequest,andtheclientcanuseits
cached copy.
● 3 05UseProxy:Thisstatuscodeisprovidedintheresponsetoindicatethattherequestedresourceis
onlyavailablethroughaproxyserver.However,manyHTTPclientsdonotobeythisstatuscodefor
security reasons.
● 3 06 Switch Proxy: This status code is no longer used. It was originally intended to instruct
subsequent requests to use the specified proxy.
● 3 07TemporaryRedirect:Inthiscase,therequestshouldberepeatedwithanotherURI,butfuture
requests should still use the original URI. Unlike the 302 status code, the request method is not
allowed to change when reissuing the original request. Forexample,iftheoriginalrequestwasa
POST request, it should be repeated using another POST request.
● 3 08PermanentRedirect:Thisstatuscode,like307,indicatesthatfuturerequestsshouldbedirected
to the given URI. However, unlike 307, 308 does not allow the HTTP method to change. So, for
example, submitting aformtoapermanentlyredirectedresourcemaycontinuesmoothlywithout
changing the method.
● 00 Bad Request: The server could not understand therequest due to invalid syntax.
4
● 401 Unauthorized: The request requires user authentication.
● 403 Forbidden: The server understood the request butrefuses to authorize it.
● 404 Not Found: The requested resource could not befound on the server.
● 405 Method Not Allowed: The request method is notsupported for the specified resource.
● 405 Method Not Allowed: The request method is notsupported for the requested resource. For
example, trying to perform a GET request on a resource that only allows POST requests.
● 406 Not Acceptable: The requested resource is capableof generating only content that is not
acceptable according to the Accept headers sent in the request.
● 407 Proxy Authentication Required: The client mustfirst authenticate itself with the proxy.
● 408 Request Timeout: The server timed out waitingfor the request. The client may repeat the
request without modifications at any later time.
● 409 Conflict: Indicates that the request could notbe processed because of a conflict in the current
state of the resource.
● 410 Gone: Indicates that the resource requested waspreviously in use but is no longer available and
will not be available again.
34
End to End APIs and API Testing, Curated by Lamhot Siagian
● 4 11 Length Required: The request did not specify the length of its content, which is required by the
requested resource.
● 412 Precondition Failed: The server does not meetone of the preconditions that the requester put
on the request header fields.
● 413 Payload Too Large: The request is larger thanthe server is willing or able to process.
● 414 URI Too Long: The URI provided was too long forthe server to process.
● 415 Unsupported Media Type: The request entity has a media type which the server or resource
does not support.
● 416 Range Not Satisfiable: The client has asked fora portion of the file, but the server cannot
supply that portion.
● 417 Expectation Failed: The server cannot meet therequirements of the Expect request-header field.
● 418 I'm a teapot: A humorous status code, not intendedto be implemented by actual HTTP servers.
● 421 Misdirected Request: The request was directedat a server that is not able to produce a
response.
● 422 Unprocessable Content: The request was well-formedbut could not be processed.
● 423 Locked: The resource that is being accessed islocked.
● 424 Failed Dependency: The request failed becauseit depended on another request and that
request failed.
● 425 Too Early: Indicates that the server is unwillingto risk processing a request that might be
replayed.
● 426 Upgrade Required: The client should switch toa different protocol given in the Upgrade
header field.
● 428 Precondition Required: The origin server requiresthe request to be conditional.
● 429 Too Many Requests: The user has sent too manyrequests in a given amount of time.
● 431 Request Header Fields Too Large: The server isunwilling to process the request because an
individual or all header fields are too large.
● 451 Unavailable For Legal Reasons: A server operatorhas received a legal demand to deny access
to the resource.
● 5 00 Internal Server Error: A generic error messageindicating that the server encountered an
unexpected condition.
● 501 Not Implemented: The server does not support thefunctionality required to fulfill the request.
● 502 Bad Gateway: The server received an invalid responsefrom an upstream server while acting as
a gateway or proxy.
● 503 Service Unavailable: The server is currently unableto handle the request due to temporary
overloading or maintenance of the server.
● 504 Gateway Timeout: The server, acting as a gatewayor proxy, did not receive a timely response
from the upstream server.
● 505 HTTP Version Not Supported: The server does notsupport the HTTP version used in the
request.
35
End to End API Testing, Curated by Lamhot Siagian
● 5 06 Variant Also Negotiates: Transparent content negotiation for the request results in a circular
reference.
● 507 Insufficient Storage: The server is unable tostore the representation needed to complete the
request.
● 508 Loop Detected: The server detected an infiniteloop while processing the request.
● 510 Not Extended: Further extensions to the requestare required for the server to fulfill it.
● 511 Network Authentication Required: The client needsto authenticate to gain network access.
This is often used by intercepting proxies to control access to the network, such as "captive portals"
requiring agreement to Terms of Service before granting full Internet access via a Wi-Fi hotspot.
36
End to End APIs and API Testing, Curated by Lamhot Siagian
I f the resource is accessible, the API returns the 200 Status Code, which means OK.
●
● Along with the 200 Status Code, the server usually returns a response body in XML or JSON
f ormat. So, for example, we expect the [GET] /members endpoint to return a list of membersin
XML or JSON.
If the server does not support the endpoint, theserverreturnsthe404StatusCode,whichmeans
●
Not Found.
● If we send the request in the wrong syntax, the serverreturnsthe400StatusCode,whichmeans
Bad Request.
● curl -v -X GET https://api.example.com/resource
ince the POST method creates data, we must be cautious about changing data; testing all the POST
S
methods in APIs is highly recommended. Moreover, make sure to delete the createdresourceonceyour
testing is finished.
Here are some suggestions that we can do for testing APIs with POST methods:
● Create a resource with the POST method, and it should return the 201 Status Code.
● PerformtheGETmethodtocheckifitcreatedtheresourcewassuccessfullycreated.Youshouldget
the 200 status code, and the response should contain the created resource.
● Perform the POST method with incorrect or wrong formatted data to check if the operation fails.
● curl -v -X POST https://api.example.com/resource -H "Content-Type: application/json" -d
'{"key":"value"}'
● Send a PUT request to the server many times, and it should always return the same result.
● When the server completes the PUT request and updatestheresource,theresponseshouldcome
with 200 or 204 status codes.
37
End to End API Testing, Curated by Lamhot Siagian
● After the server completes the PUT request, make a GET request to check if the data isupdated
correctly on the resource.
● If the input is invalid or has the wrong format, the resource must not be updated.
● curl -v -X PUT https://api.example.com/resource/123 -H "Content-Type: application/json" -d
'{"key":"value"}'
● SendaPATCHrequesttotheserver;theserverwillreturnthe2xxHTTPstatuscode,whichmeans:
the request is successfully received, understood, and accepted.
● Perform the GET request and verify that the content is updated correctly.
● If the request payload is incorrect or ill-formatted, the operation must fail.
● CallthePOSTmethodtocreateanewresource.NevertestDELETEwithactualData.Forexample,
first, create a new customer and then try to delete the customer you just created.
● MaketheDELETErequestforaspecificresource.Forexample,therequest[DELETE]/customers/
{customer-id} deletes a customer with thee specified customer Id.
● CalltheGETmethodforthedeletedcustomer,whichshouldreturn404,astheresourcenolonger
exists.
● Testfully’sMulti-steptestsallowyoutocreateresourcesontheflyandusethemfortestingDELETE
endpoints.
38
End to End APIs and API Testing, Curated by Lamhot Siagian
neoftheadvantagesoftheHEADmethodisthatwecantesttheserverifitisavailableandaccessibleas
O
long as the API supports it, and itismuchfasterthantheGETmethodbecauseithasnoresponsebody.
The status code we expect to get fromtheAPIis200.BeforeeveryotherHTTPmethod,wecanfirsttest
API with the HEAD method.
● Make an OPTIONS request and check the header and the status code that returns.
● Test the case of failure with a resource that doesn’t support the OPTIONS method.
● Checkwhattheserverreturns.Iftheresponsehasthesameinformationastheoriginalrequest,the
TRACE ability is enabled in the server and works correctly.
esting the HTTP CONNECT method can be done using tools that supportrawHTTPrequests,suchas
T
cURL,Telnet,orspecificnetworkdiagnostictools.TheCONNECTmethodisprimarilyusedtoestablisha
networkconnectiontoaresource,oftenthroughaproxyserver.Here'showyoucantestitusingdifferent
tools:
39
End to End API Testing, Curated by Lamhot Siagian
1. V alidateStructure:CheckthattheresponsebodyfollowstheexpectedstructuredefinedintheAPI
documentation or specifications. This includes verifying the presence of required fields, nested
objects, arrays, and data types.
2. P arse JSON/XML: If the response body is in JSON or XML format, parse it programmaticallyto
extract relevant data for validation. Use libraries or tools appropriate for your programming
language to parse and manipulate the response.
3. V erifyDataIntegrity:Ensurethatthedatareturnedintheresponsebodyisaccurateandconsistent
with the inputprovidedintherequest.Comparetheresponsedataagainsttheexpectedvaluesor
data retrieved from the database.
4. H andle Pagination: If the API supports pagination, analyze the response body to ensure that
paginationparameterssuchaspagenumbers,pagesize,andtotalcountarecorrectlyreturned.Test
scenarios involving navigating through multiple pages of results.
5. T est Edge Cases: Evaluate how the API handles edge cases and boundary conditions in the
response body. This includes scenarios such as empty responses, null values, maximum and
minimum values, and unexpected input data.
6. C heck Error Responses: Verify that error responses include meaningful error messages and
appropriate HTTP status codes. Analyze the response body for error details such as error codes,
descriptions, and troubleshooting instructions.
7. E valuate Performance: Analyze the size and complexity of the r esponse body to assess
performance implications, especially for large datasets or complex object structures. Monitor
response times and network traffic during performance testing.
8. H andleLocalization:IftheAPIsupportslocalizationorinternationalization,analyzetheresponse
body to ensure that localized content is correctly returned based on the client's language
preferences specified in the request.
9. T est Content Negotiation: If the API supports content negotiation, test scenarios where clients
requestspecificmediatypes(e.g.,JSON,XML)intheAcceptheader.Analyzetheresponsebodyto
verify that the requested content type is returned.
10. Validate Hypermedia Controls: If the API follows the HATEOAS principle (Hypermedia as the
Engine of Application State), analyze the response body to ensure that hypermedia links and
controls are correctly included, allowing clients to navigate the API dynamically.
ythoroughlyanalyzingresponsebodiesduringtesting,youcanidentifyissues,validatedatacorrectness,
B
and ensure that the API behaves as expected in various scenarios. This helps maintain the reliability,
usability, and performance of the API for end-users.
40
End to End APIs and API Testing, Curated by Lamhot Siagian
Common Interview Questions & Answers Related to API Request and Response
safemethodisamethodthatdoesn’tchangedataontheserver.Forexample,GETandHEADaresafe
A
methods because the user or an application does not request side effects on the server when calling them.
n Idempotent method means it returns the same response no matter how many times it runs. For
A
example, The PUT and DELETE methods share this property. However, it is possible thatasequenceof
severalrequestsisnotidempotent,evenifallofthemethodsexecutedinthatsequenceareidempotent.So,
a series of requests is idempotent if a single execution of the entire series always returns the same result.
3. What are HTTP methods and their significance in API development?
nswer: HTTP methods (GET, POST, PUT, DELETE, PATCH, etc.) specify the action to be performed on a
A
resource. They are essential for defining the behavior of APIs and determining how clients interact with
resources.
nswer: GET requests are used to retrieve data from the server, while POST requests are used to submit
A
data to the server for processing or storage.
nswer: HTTP headers provide additional information about the request or the data being sent, such as
A
content type, authentication credentials, and caching directives.
nswer: A query parameter is a key-value pair appended to the end of a URL that provides additional
A
information to the server about the request, such as filtering or pagination criteria.
nswer: HTTP status codes indicate the outcome of an API request, such as success, failure, or redirection.
A
They help clients understand how to process the response.
nswer: HTTP headers provide metadata about the response, such as content type, caching directives, and
A
server information.
41
End to End API Testing, Curated by Lamhot Siagian
nswer: Content negotiation is the process of selecting the appropriate representation of a resource based
A
on the client's preferences specified in the request headers.
10. What are common HTTP status codes for error responses?
nswer: Common HTTP status codes for error responses include 400 Bad Request, 404 Not Found, 500
A
Internal Server Error, etc.
nswer: Errors in API responses should be handled gracefully by providing informative error messages,
A
appropriate HTTP status codes, and troubleshooting guidance to the client.
42
End to End APIs and API Testing, Curated by Lamhot Siagian
Chapter 4
PISecurityTestinggoesalongwayinavoidingAPIbreachesbypreventingsecurityvulnerabilitiesfrom
A
ever reaching production environments. Noname ActiveTestingfocusesonfindingandremediatingAPI
security vulnerabilities during the development phase of the SDLC, before they can be exploited.
ecurity testing of APIs (Application Programming Interfaces) is crucial to ensure that the data and
S
functionalitiesexposedbytheseinterfacesareprotectedfromvariousthreatsandvulnerabilities.Hereisa
comprehensive overview of security testing for APIs:
Authentication
uthenticationistheprocessofverifyingtheidentityofauserordevice,anditisusedtoaccessasystem,
A
service, or network. It’s an important part of any application and can be done in many ways such as
username and password authentication, two-factor authentication, and API authentication.
PI authentication uses an API key to verify the identity of the user. This typeofauthenticationcanbe
A
used for both public and private APIs.
43
End to End API Testing, Curated by Lamhot Siagian
ethods:Check the implementation of authentication mechanisms such as OAuth, JWT, API keys, and
M
basic auth.
Tests:Validate token expiration, token revocation, replay attacks, and credential brute-forcing.
Authorization
heAPIauthorizationisaprocessofcheckingtheidentityoftheuserandauthorizingthemtoaccessthe
T
application.It’sacommonpracticeinwebapplicationsandcanbedonebysendinganHTTPrequestwith
the appropriate header and token in it. The API will then return a response with information about
whether or not the request was successful or not.
ests:Check for privilege escalation, verify accesscontrol rules, and ensure that users cannot access data
T
belonging to other users.
44
End to End APIs and API Testing, Curated by Lamhot Siagian
Injection Attacks:
APIs can be vulnerable to injection attacks, where malicious code or commands are injected into API
r equests. This can lead to unauthorized data exposure, compromised systems, or a takeover.
eak authentication mechanisms, improper session handling, or inadequate access controls can expose
W
APIs to authentication and session-related vulnerabilities. Attackers may exploit these weaknesses to
impersonate legitimate users, hijack sessions, or gain unauthorized access to sensitive data.
PIs that expose internal references, such as database IDs or file paths, without proper authorization
A
checks can be prone to IDOR vulnerabilities. Attackers can manipulate these references to access
unauthorized resources or sensitive information.
45
End to End API Testing, Curated by Lamhot Siagian
nsuring the security of APIs is crucial to protect sensitive data and prevent potential breaches. API
E
security testing plays a vital role in identifying vulnerabilities and weaknesses in API implementations.
Following are some pointers to consider when preparing for API security testing:
reate a separate, isolated environment dedicated explicitly to API security testing. This prevents any
C
accidental impact on the production systems and ensures a controlled testing environment.
eplicate the configuration of the production environment as closely as possible, including the server
R
setup,networkarchitecture,andinfrastructurecomponents.Thisensuresthatthesecuritytestsaccurately
reflect real-world scenarios.
everage virtualization technologies like virtual machines or containerization platforms (e.g.,Docker)to
L
create a scalable and reproducible testing environment. This enables the easy setup of multiple testing
instances and facilitates efficient testing of different API configurations.
etermine which APIs and specific endpoints will be included in the testing. It’s essential to consider
D
internal and external-facing APIs and any public APIs that may expose sensitive data or critical
functionalities.
46
End to End APIs and API Testing, Curated by Lamhot Siagian
ssess the APIs’ various authentication and authorization mechanisms. Include scenarios like APIkeys,
A
tokens, or user credentials to evaluate the security measures thoroughly.
nalyzehowAPIshandledatavalidationandinputhandling.Assesshowtheyrespondtoinputformats,
A
including invalid or unexpected data. Pay special attention to potential injection vulnerabilities.
Evaluate how APIs handle errors and exceptions. Test their response to different error conditions and
e nsure that sensitive information is not leaked in error messages.
quipping your API security testing efforts with the right tools and resources is essential for effective
E
testing. Consider the following:
amiliarize yourself with security testing frameworks, such as the OWASP API Security Top 10, which
F
guidesthemostcriticalAPIsecurityrisks.Theseframeworksserveasinvaluablereferencesthroughoutthe
testing process.
btain the API documentation, specifications, and relevant security requirements. Thoroughly review
O
them to understand the expected behavior, expected security measures, and any specific test cases.
evelop a comprehensive security testing checklist encompassing various aspects of API security,
D
including authentication, authorization, input validation, error handling, and encryption. This checklist
will serve as a roadmap for your testing efforts.
47
End to End API Testing, Curated by Lamhot Siagian
ests:Enumerate API endpoints, verify the necessityof exposed endpoints, and check for hidden or
T
undocumented endpoints.
API endpoints serve as the entry points for interactions with an API. To conduct effective security testing:
I dentifyanddocumentallAPIendpoints.Categorizethembasedonfunctionality,sensitivity,andpotential
security risks.
Determine which endpoints handle sensitive data, perform critical operations, or involve user
uthentication. These endpoints may be more prone to security vulnerabilities and require rigorous testing.
a
reate a comprehensive map of API endpoints, including the request and response types, expected
C
behavior, and associated security controls. This map will serve as a reference during testing to ensure
thorough coverage.
48
End to End APIs and API Testing, Curated by Lamhot Siagian
ssess the strength and effectiveness of authentication mechanisms, such as API keys, tokens, or
A
multifactor authentication. Verify that only authenticated users can access protected resources.
I dentify potential security misconfigurations or improper access controls that may allow unauthorized
access to sensitive endpoints or operations. Thoroughly examine access control rules and configurations.
ests:Inject various forms of input such as SQL injection,XSS (cross-site scripting), command injection,
T
and XML external entity (XXE) attacks.
Here some tips on how to implement input validation for your APIs to make sure it’s as secure as possible.
he Content-Type header indicates what media type will be transmitted from an HTTP request or
T
response.VerifyingtheContent-Typetoensurethattheposteddatamatchestheexpectedformatisoneof
the most straightforward ways to protect an API from invalid or malicious data.
I magine an API endpoint that expects a JSON object for a specific application.Verifyingtheheaderand
thattherequestisinJSONformatprotectsyourAPIfromdatacorruptionorinjectionattacks,amongother
things.
enialofservice(DoS)attackslikeABillionLaughsorXMLbombattacksrelyonvulnerableXMLparsers.
D
TheattackinvolvessendinganXMLfilewithalargenumberofnestedentities,resultingintheXMLparser
expanding each entity and consuming an excessive amount of resources. Simply limiting thenumberof
entities that can be opened by the parser eliminates this type of DoS attack entirely.
49
End to End API Testing, Curated by Lamhot Siagian
I njection flaws are pervasive in SQL, LDAP, or NoSQL queries, OScommands,XMLparsers,andORM.
They’re very easy to discover, as well, using tools like scanners or fuzzers. Injection flaws are when an
attacker can run malicious code through anexternalapplication.Thiscanresultinbothabackendbeing
compromised as well as third-party clients connected to the affected application.
ohelppreventtheriskduetoinjectionflaws,youshouldvalidateinputfromeverypotentiallyuntrusted
T
source.Thisincludeseverythingfrominternet-facingwebclientstobackendfeedsoverextranetsanddata
from suppliers, vendors, or regulators. Any of these could be compromised, putting your system at risk.
o help ensure API security, input validation should be performed onboththesyntacticalandsemantic
T
levels.Syntacticlevelvalidationshouldchecktoseethatstructuredfieldsareformattedcorrectly,suchas
ensuring the right currency symbols are used, for example, or that the proper hyphenated structure is
followedforthingslikephoneorsocialsecuritynumbers.Semanticinputvalidationcheckstoensuredata
falls within a specific context, such as a particular date or price range.
any developers use block lists to try and prevent common attack patterns, such as the apostrophe ‘
M
character,the1=1string,or<script>tags.Thisapproachiseasyforattackerstocircumvent,though.Valid
inputs can trigger the filter, too, as in the case of last names like O’Grady.
sing allow lists is a better approach for user inputs. They let you specify what is allowed rather than
U
tryingtopreventanypotentialrisk.Thisiseasytoimplementforstructureddata,likeaddressesorsocial
securitynumbers.Inputfieldswithlimitedoptions,likeadrop-downmenu,areeveneasiertovalidate,as
the selection needs to exactly match one of the available options.
ree-form inputs, such as text, have a reputation of beingthemostdifficulttovalidate,asthere’ssucha
F
wide range of possible variables. To validate free-form UNICODE inputs, you should practice
normalization to ensure no invalid characters are present. You should create an allow-listforacceptable
50
End to End APIs and API Testing, Curated by Lamhot Siagian
c haracter categories, such as Arabic or Cyrillic alphabets. You can also create allow-lists for individual
characters, like the apostrophe in a name field.
J avaScriptinputvalidationiseasilybypassedbyattackers,whocaneitherdisableJavaScriptoruseaWeb
Proxy. Validating input on the client side adds an invaluable extra layer of protection.
ealreadymentionedhowattackerscanuseuploadsforDoSattacks.Puttingsizelimitsonuseruploads
W
isjustoneapproachforvalidatinguseruploads,though.IfyourAPIonlyacceptscertainfiletypes,youcan
use input validation to make sure the uploaded file matches the expected file type. Once the file’s
uploaded, though, make suretochangethefile’snameinyoursystem.Theyshouldalsobeanalyzedfor
malicious content, such as malware. The user shouldn’t be able to dictate where the file is stored, either.
VerifythattheAPIperformspropervalidation,sanitization,andencodingofuser-supplieddatatoprevent
ata corruption or tampering. Validate the integrity of data transmitted between the client and server.
d
I dentifypotentialdataleakagesrisks,suchasinadvertentlydisclosingsensitiveinformationinresponsesor
error messages. Test for scenarios where sensitive data may be unintentionally exposed.
ests:Generate various errors and examine responsesfor sensitive data leakage, verify logging
T
configurations, and check for proper log sanitization.
roper error handling and exception management improve an API’s overall security and robustness. When
P
conducting testing:
valuate how the API handles errors and exceptions. Test for proper errorcodes,informativemessages,
E
and appropriate logging practices.
ook for potential information disclosure vulnerabilities in error responses or stack traces. Ensure that
L
error messages do not expose sensitive information that could aid attackers.
51
End to End API Testing, Curated by Lamhot Siagian
ssess how the API handles unexpected situations, such as unhandled exceptions or denial-of-service
A
attacks. Verify that the API gracefully handles exceptions and does not expose system vulnerabilities.
ests:Simulate high request rates, verify the enforcement of rate limits, and check for DoS (Denial of
T
Service) vulnerabilities. Rate limiting and throttling mechanisms protect APIs against abuse and
denial-of-service attacks. During testing:
ecognize the significance of rate limiting and throttling to prevent abuse, brute-force attacks, or DoS
R
scenarios. Familiarize yourself with industry best practices.
ttempt to bypass rate limits and verify if the API enforces them consistently. Check for potential
A
vulnerabilities that allow attackers to circumvent rate limits and overload the system.
esttheAPIundervariousloadconditionstoensurethatrate-limitingandthrottlingmechanismsfunction
T
as expected. Measure the API’s response time and stability during high-volume traffic.
o preventabuseandensureequitable
T omaintainsystemperformanceand
T
access to resources by limiting the stabilitybydynamicallyadjustingthe
rimary
P
number of requests a user or service rate of incoming requests based on
Objective
can make within a specified time current system load or predefined
frame. rules.
52
End to End APIs and API Testing, Curated by Lamhot Siagian
imstooptimizetheflowofrequests
A
ocuses on enforcing fairness and
F to prevent system overloads while
perational
O
preventing system overload bysetting accommodating fluctuating demand
Focus
clear, predefined limits on API usage. and ensuring critical requests are
processed efficiently.
53
End to End API Testing, Curated by Lamhot Siagian
Learn about common API abuse scenarios, such as parameter tampering, replay attacks, or API key
e xposure. Develop test cases to identify and mitigate these risks.
tilizeautomatedtoolsandframeworks,suchasOWASPZAPorBurpSuite,tostreamlinesecuritytesting
U
efforts. Automate vulnerability scanning, fuzz testing, and security checks to achieve comprehensive
coverage.
everage open-source tools and frameworks tailored for API security testing. These resources providea
L
wealth of knowledge, best practices, and test scripts to enhance the effectiveness of your testing efforts.
● urp Suite: Comprehensive web vulnerability scannerwith plugins for API testing.
B
● OWASP ZAP: Open-source tool for finding vulnerabilitiesin web applications and APIs.
● Postman: API development environment with securitytesting capabilities.
● SoapUI: Functional testing tool for SOAP and RESTAPIs.
● Insomnia: API client for testing and debugging withsecurity testing extensions.
● Fiddler: Web debugging proxy for capturing and manipulatingAPI requests and responses.
● JMeter: Performance testing tool with capabilitiesfor API security testing.
54
End to End APIs and API Testing, Curated by Lamhot Siagian
Tests:Verify session expiration, test session fixationand hijacking, and ensure proper session termination.
55
End to End API Testing, Curated by Lamhot Siagian
● hift Left Security: Integrate security testing earlyin the development lifecycle.
S
● Use Security Standards: Follow OWASP API SecurityTop 10 guidelines.
● Regular Audits and Penetration Testing: Conduct periodicsecurity audits and penetration tests.
● Secure Development Practices: Adopt secure codingpractices and conduct code reviews.
● Following Industry Standards and Guidelines:To ensurerobust API security, it is vital to follow
industry standards and guidelines. These standards provide a framework for implementing
adequate security controls and mitigating common vulnerabilities. By adhering to these standards,
organizations can align their security practices with industry best practices and reduce the risk of
potential breaches.
● Keeping Up with Evolving Threats and Security Practices:It is another critical aspect of API
security. The threat landscape constantly evolves, with new attack vectors and techniques emerging
regularly. Staying updated on the latest threats allows organizations to identify and address
vulnerabilities proactively before they can be exploited. By actively participating in security
communities, attending conferences, and leveraging threat intelligence sources, organizations can
stay one step ahead of attackers and implement timely security measures.
Continuous Monitoring and Retesting for Ongoing Security:These are essential for maintaining
●
ongoing security. It is not enough to perform security testing once and consider the job done. APIs
and their associated threats evolve. Organizations can detect and respond to potential security
incidents in real-time by implementing continuous monitoring. Additionally, regular retesting helps
identify new vulnerabilities that may have been introduced due to system updates or changes in the
threat landscape. This iterative approach ensures that APIs remain secure and protected against
emerging risks. : Automate security tests within CI/CD pipelines.
56
End to End APIs and API Testing, Curated by Lamhot Siagian
Authentication Testing
:Authentication verifies the identity of a user,while authorization determines what resources and
A
actions the authenticated user is allowed to access.
2. Q: How can you test if an API properly handles JWT (JSON Web Tokens)?
:Validate token structure, check for proper expirationhandling, ensure the token signature is
A
verified, and test for token revocation.
Authorization Testing
:RBAC assigns permissions to users based on theirroles within an organization, ensuring they
A
can only access resources necessary for their role.
6. Q: How can you ensure API endpoints are not publicly accessible?
A:Use API gateways, apply IP whitelisting, and implementproper access control policies.
:It prevents malicious input that can lead to securityvulnerabilities like SQL injection, XSS, and
A
command injection.
8. Q: What are common injection attacks you should test against in APIs?
A:SQL injection, XSS, command injection, and XMLexternal entity (XXE) attacks.
9. Q: How do you test for SQL injection vulnerabilities in an API?
57
End to End API Testing, Curated by Lamhot Siagian
:Inject SQL payloads into API parameters and observe if the API behaves unexpectedly or returns
A
database errors.
:Rate limiting controls the number of requests aclient can make to the API within a specified time
A
period to prevent abuse.
11. Q: How can you test the effectiveness of rate limiting?
:Simulate high request rates from a single clientand verify that the API enforces rate limits by
A
returning appropriate error responses (e.g., HTTP 429 Too Many Requests).
12. Q: What is the difference between rate limiting and throttling?
:Rate limiting restricts the number of requestsover time, while throttling limits the bandwidth or
A
processing capacity available to a client.
:To avoid exposing sensitive information througherror messages and ensure the API gracefully
A
handles unexpected conditions.
14. Q: How can you test for information leakage in error messages?
:Intentionally cause errors and analyze the APIresponses for detailed error messages that reveal
A
implementation details or sensitive information.
15. Q: What should you check in API logs for security?
:Ensure logs do not contain sensitive informationlike passwords or tokens, and verify that
A
logging complies with privacy regulations.
17. Q: What are common methods for encrypting data at rest in an API?
A:Use encryption algorithms like AES to encrypt sensitivedata stored in databases or file systems.
58
End to End APIs and API Testing, Curated by Lamhot Siagian
18. Q: How can you test if data is properly encrypted in transit?
:Inspect network traffic using tools like Wiresharkto verify that data is encrypted during
A
transmission.
:Use tools like Burp Suite or OWASP ZAP to spiderthe API and look for endpoints that are not
A
documented.
20. Q: Why is it important to limit endpoint exposure?A:To reduce the attack surface and prevent
unauthorized access to sensitive resources.
21. Q: What should you verify in API endpoint testing?
:Ensure only necessary endpoints are exposed, endpointsrequire proper authentication and
A
authorization, and input is properly validated.
22. Q: How do you test for session fixation vulnerabilities in an API?
:Attempt to set or reuse session identifiers andverify that the API properly generates new session
A
IDs after authentication.
:Attributes like Secure and HttpOnly ensure cookiesare only transmitted over HTTPS and are not
A
accessible via JavaScript. Test by examining cookie properties in browser developer tools.
24. Q: Why is session timeout important and how do you test it?
:To minimize the risk of session hijacking. Testby leaving a session inactive for a period and
A
verifying that the session is invalidated after the timeout.
:Testing the API’s functionality to ensure it enforcesbusiness rules and processes correctly
A
without security flaws.
59
End to End API Testing, Curated by Lamhot Siagian
:Perform scenario-based testing to simulate real-world usage and identify logic flaws, race
A
conditions, and bypasses.
:A list of the top ten security risks for APIs published by the Open Web Application Security
A
Project (OWASP), providing guidelines for securing APIs.
29. Q: How can you integrate security testing into the development lifecycle?
:To detect and respond to security incidents inreal-time, ensuring the API remains secure against
A
emerging threats.
:So when should you conduct API security testing?The best answer is “as early as possible.” This
A
means testing pre-production. Like other security testing done in software development, API
security testing should “shift left,” meaning it should move to the earliest possible stage in the
development cycle. That’s the time when developers are most likely to be familiar with the recent
code they wrote rather than the code they wrote a month or 6 months ago. This way, testers can
catch and remediate security issues before they go into production.
nce an application is in production, it becomes more expensive and disruptive to fix a security
O
problem. With CI/CD, a new vulnerability can go into production every hour, so it’s really helpful
to be on top of API security testing before code reaches the end of the CI/CD pipeline. A further
best practice is to follow up with post-production API security testing. Security testing at this
juncture catches security flaws that arise in production, but which may be difficult to detect in
pre-production, such as production configuration issues.
:The earlier you catch security vulnerabilities,the better. From both a cost perspective and
A
remediation angle, it is much easier to correct issues during the development process of the API
than after it has been released into production and is being actively used. It allows organizations to
60
End to End APIs and API Testing, Curated by Lamhot Siagian
ore confidently and efficiently deliver applications to the business and remain competitive
m
securely.
:Developers, security teams and more, can now availthemselves of a new generation of API
A
security testing tools. As exemplified by Noname Security Active Testing, they can run numerous
dynamic API security tests on an application. Active Testing offers a purpose-built API security
testing solution that takes into account the user’s unique business logic. It provides comprehensive
coverage of API-specific vulnerabilities, including the OWASP API Top Ten security issues. The
suite can help align API security tests with business objectives and team structures. These latter two
factors are important in making the “shift left” approach viable because making API security testing
part of the dev cycle takes people and processes.
PI security testing is critical for protecting modern web applications in this era of CI/CD. It
A
should occur as “far to the left” as possible in the development process. API testing should entail
scanning for known API vulnerabilities, such as those referenced in the OWASP list, as well as other
security problems. With the right testing tools, it is possible to conduct thorough API security
testing early in development—detecting and remediating problems before they go into production.
61
End to End API Testing, Curated by Lamhot Siagian
Chapter 5
Y
● ou can clone the template and have separate test case sheets for different areas of the software
● Follow a consistent naming convention for test cases to make them easily searchable.
● You can group similar test cases together under a common feature/scenario
● Familiarize yourself with the requirement or featureyou'retestingbeforecreatingthetestcaseso
that you’ll know what information to include
● Useactionverbsatthestartofeachteststeplike“Click”,“Enter”or“Validate”.Ifneeded,youmay
evencreateasemanticstructuretodescribeyourtestcase.YoucancheckouthowitisdoneinBDD
testing.
● Include any setup or prerequisites neededbefore executingthe test.
● Ensurethatthetestcasesyouincludedarenotonlythe“common”scenariosbutalsothenegative
scenarios that users don’t typically face but do happen in the system
● Use formatting to make your test cases easier to read and follow
● Make sure to update your test cases regularly
1. S tatus Code Validation for Valid Requests: Verify that theAPIconsistentlyreturnstheexpected
response status code, such as "200 OK," for valid and properly formatted requests.
2. Authentication Handling with Invalid Credentials: Test the API'sresponsewhenprovidedwith
invalidauthenticationcredentials,ensuringitconsistentlyreturnsa"401Unauthorized"statuscode
as expected.
3. Graceful Handling of Missing or Invalid Parameters: Verify that the API handles missing or
invalidrequestparametersgracefullyandreturnsclearanduser-friendlyerrormessagesthataidin
troubleshooting.
4. InputDataValidationwithMalformedData:TesttheAPI'sinputvalidationbysubmittingvarious
forms of malformed data, such as invalid email formats, and confirm that itproperlyrejectsand
responds to these inputs.
62
End to End APIs and API Testing, Curated by Lamhot Siagian
5. T imeout Handling under Load: Confirm that the API correctly handles timeouts by simulating
requests that take longer to process, ensuring that it remains responsive and does not hang.
6. Pagination Functionality Verification: Test the API's pagination functionality by requesting
specificpagesofresultsandverifyingthattheresponsescontaintheexpecteddataandpagination
information.
7. Concurrency Testing without Data Corruption: Verify that the API handles concurrent requests
from multiple users without data corruption or conflicts, ensuring data integrity.
8. Response Format Adherence (JSON/XML): Ensure that theAPIconsistentlyreturnsresponsesin
the specified format (e.g., JSON or XML) and adheres to the defined schema for data structure.
9. Caching MechanismEvaluationwithRepeatedRequests:EvaluatetheAPI'scachingmechanism
by making repeated requests and verifying that the cache headers are correctly set and honored.
10. Rate Limiting Assessment: Test the API's rate limiting bysendingrequestsataratethatexceeds
the defined limits and checking for the expected rate-limiting responses, ensuring that limits are
enforced.
11. HTTP Method Support for CRUD Operations: Verify that the API supports a variety of HTTP
methods (GET, POST, PUT, DELETE) for Create,Read,Update,andDeleteoperations,andthatit
returns appropriate responses for each.
12. Error Handling Capabilities for Meaningful Messages: Evaluate the API's error-handling
capabilities by intentionally causing errors, such as invalid inputs or unexpected situations, and
confirm that it consistently returns meaningful error messages for troubleshooting.
13. Conditional Request Handling (If-Modified-Since, If-None-Match): Test the API's support for
conditional requests using headers like If-Modified-Since and If-None-Match, ensuring that
responses are handled appropriately.
14. Sorting and Filtering Validation for Resource Listings: Verify that the API correctly sorts and
filters resource listings based on specified parameters, maintaining data accuracy.
15. HandlingLongorComplexDatawithoutDataCorruption:EnsurethattheAPIproperlyhandles
long or complex strings, such as URLs or text fields, without truncating or corrupting the data.
16. ContentNegotiationSupportforMultipleFormats:TesttheAPI'ssupportforcontentnegotiation
by specifying different Accept headers (e.g., JSON, XML) and verifying that the response format
matches the requested format.
17. Resource Not Found Handling (404 Not Found): Confirm that the API consistently returns the
appropriate "404 Not Found" response when attempting to access a non-existent resource.
18. ResponseTimeMeasurementforVariousRequests:MeasuretheAPI'sresponsetimefordifferent
types of requests to assess its performance and responsiveness.
19. HandlingLargePayloads(FileUploads):VerifythattheAPIcanhandlelargepayloads,suchasfile
uploads, without encountering errors or significant performance degradation.
20. Compatibility with Client Libraries and SDKs: Evaluate the API's compatibility with different
client libraries or SDKs to ensure seamless integration with various platforms and programming
languages.
63
End to End API Testing, Curated by Lamhot Siagian
ehavior-Driven Development (BDD) is a software development process that encourages
B
collaboration among developers, testers, and business stakeholders. BDD extends Test-Driven
Development(TDD)bywritingtestcasesinanaturallanguagethatnon-technicalstakeholders
canunderstand.CucumberisoneofthemostpopulartoolsforBDD,whichallowsyoutowrite
tests in a human-readable Gherkin syntax.
POST
Postive Test
Negative Test
64
End to End APIs and API Testing, Curated by Lamhot Siagian
PUT
Posive Test
Negative Test
65
End to End API Testing, Curated by Lamhot Siagian
GET
Positive Test
66
End to End APIs and API Testing, Curated by Lamhot Siagian
Negative Test
67
End to End API Testing, Curated by Lamhot Siagian
PATCH
Positive Test
Negative Test
68
End to End APIs and API Testing, Curated by Lamhot Siagian
DELETE
Positive Test
Negative Test
69
End to End API Testing, Curated by Lamhot Siagian
70
End to End APIs and API Testing, Curated by Lamhot Siagian
71
End to End API Testing, Curated by Lamhot Siagian
72
End to End APIs and API Testing, Curated by Lamhot Siagian
73
End to End API Testing, Curated by Lamhot Siagian
namefield
iventhe request body is missing the
G
WhenI send a POST request to /resourceswith an empty namefield
400 Bad Request
Thenthe response status code should be
namefield is required
Andthe response message should indicate that the
iventhe
G namefield has a maximum length of 50 characters
WhenI send a POST request to /resourceswith anamethat is 51 characters long
400 Bad Request
Thenthe response status code should be
namefield exceeds the maximum length
Andthe response message should indicate that the
74
End to End APIs and API Testing, Curated by Lamhot Siagian
iventhe
G namefield should only contain alphabetic characters
WhenI send a POST request to /resourceswith a namethat contains special characters like
@,
#,
$
Thenthe response status code should be 400 Bad Request
Andthe response message should indicate that thenamefield contains invalid characters
iventhe
G namefield should not be numeric
WhenI send a POST request to /resourceswith anamethat is a number like
12345
400 Bad Request
Thenthe response status code should be
namefield should be alphabetic
Andthe response message should indicate that the
iventhe
G namefield should not be null
WhenI send a POST request to /resourceswith anamefield set to
null
Thenthe response status code should be 400 Bad Request
namefield cannot be null
Andthe response message should indicate that the
iventhe
G namefield should not be an empty string
WhenI send a POST request to /resourceswith a namefield that is an empty string
Thenthe response status code should be 400 Bad Request
Andthe response message should indicate that thenamefield cannot be empty
iventhe
G namefield should not contain HTML or scripttags
WhenI send a POST request to /resourceswith anamefield that contains
<script>alert('XSS')</script>
Thenthe response status code should be 400 Bad Request
namefield contains invalid characters
Andthe response message should indicate that the
iventhe
G namefield should be validated against SQLinjection attempts
WhenI send a POST request to /resourceswith a namefield that contains
'; DROP TABLE users;
--
Thenthe response status code should be 400 Bad Request
Andthe response message should indicate that thenamefield contains invalid characters
75
End to End API Testing, Curated by Lamhot Siagian
iventhe
G namefield should not contain leading ortrailing spaces
WhenI send a POST request to /resourceswith a namefield that contains leading or trailing spaces
Thenthe response status code should be 400 Bad Request
Andthe response message should indicate that thenamefield cannot contain leading or trailing spaces
Common Interview Questions and answers related to Writing Basic API Test Cases
ere are 30 popular interview questions and answers related to POST, PUT, GET, PATCH, DELETE,
H
response format validation, sorting validation, pagination validation,authenticationhandlingvalidation,
and input validation for API testing:
Questions and Answers on HTTP Methods (POST, PUT, GET, PATCH, DELETE)
1. Q: What is the difference between POST and PUT methods?
○ A:POST is used to create a new resource, while PUTis used to update an existing resource
or create a resource if it does not exist. POST requests are not idempotent, meaning
subsequent identical requests will result in different outcomes, whereas PUT requests are
idempotent.
2. Q: When should you use the PATCH method?
○ A:PATCH is used to make partial updates to a resource.Unlike PUT, which requires the
entire resource data for the update, PATCH allows updating only the fields that need to be
changed.
3. Q: How does the DELETE method work in RESTful APIs?
○ A:DELETE is used to remove a specified resource fromthe server. The server should
204 No
respond with a status code indicating the result of the operation, typically
ontentfor a successful deletion.
C
4. Q: What is the purpose of the GET method in RESTful services?
○ A:The GET method is used to retrieve data from theserver. It should not alter the state of
the resource, making it a safe and idempotent operation.
. Q: Can you explain idempotency with an example?
5
○ A:Idempotency means that making the same requestmultiple times will result in the same
outcome. For example, sending a PUT request to update a user's email address to
"example@example.com" will result in the email being set to "example@example.com"
regardless of how many times the request is made.
76
End to End APIs and API Testing, Curated by Lamhot Siagian
77
End to End API Testing, Curated by Lamhot Siagian
○ A:To test authenticated endpoints, you can include valid and invalid credentials in the
request, check for the appropriate status codes (
200
OKfor successful authentication,
401
nauthorizedfor missing/invalid credentials), andvalidate the response data.
U
15. Q: What is the difference between authentication and authorization?
○ A:Authentication verifies the identity of a useror client, while authorization determines the
permissions and access rights of the authenticated user to specific resources or actions.
78
End to End APIs and API Testing, Curated by Lamhot Siagian
○ A
:Common security issues include SQL injection, cross-site scripting (XSS), cross-site
request forgery (CSRF), improper authentication/authorization, and data leakage through
improper error handling.
25. Q: How do you validate a POST request with a complex JSON payload?
○ A:Validate a POST request with a complex JSON payloadby checking each field's presence,
data type, value range, format, and ensuring nested structures conform to the expected
schema.
26. Q: What status code should be returned for a successful POST request?
○ A 201 Createdstatus code, indicating that the
:A successful POST request should return a
resource has been successfully created.
27. Q: How do you handle versioning in APIs?
○ A :Handle versioning by including version informationin the URL (e.g., /v1/resources ),
in the request header, or as a query parameter. This allows clients to specify which version
of the API they want to use.
28. Q: What is the purpose of the OPTIONS HTTP method?
○ A:The OPTIONS HTTP method is used to describe thecommunication options for the
target resource. It is commonly used for CORS (Cross-Origin Resource Sharing) preflight
requests.
29. Q: How do you test the resilience of an API?
○ A:Test the resilience of an API by simulating networkissues, server failures, high loads, and
other adverse conditions. Validate the API's ability to handle these scenarios gracefully and
recover.
30. Q: What is HATEOAS and why is it important in RESTful APIs?
○ A:HATEOAS (Hypermedia As The Engine Of ApplicationState) is a constraint of RESTful
APIs where the client interacts with the application entirely through hypermedia provided
dynamically by application servers. It is important because it provides discoverability and
navigability of the API, allowing clients to dynamically follow links to other resources and
actions.
hesequestionsandanswersshouldprovideasolidfoundationforunderstandingvariousaspectsofAPI
T
testing, including HTTP methods, response validation, sorting, pagination, authentication, and input
validation.
79
End to End API Testing, Curated by Lamhot Siagian
Chapter 6
DD (Behavior-Driven Development) is a software development approach that enhances collaboration
B
betweendevelopers,testers,andbusinessstakeholders.Itinvolveswritingtestcasesinanaturallanguage
that non-programmers can read. Combining TestNG with BDD for API testing provides a structured
approach to testing while leveraging the powerful features of TestNG.
In this guide, we'll integrate BDD into API testing using TestNG and the Rest Assured library.
Prerequisites
1. Create a Maven Project: Open your IDE and create anew Maven project.
2. A pom.xmlwith the necessarydependencies for TestNG, Rest
dd Dependencies: Update your
Assured, and Cucumber (for BDD).
<
p
roject
xmlns
="http://maven.apache.org/POM/4.0.0"
xmlns:
xsi
="http://www.w3.org/2001/XMLSchema-instance"
xsi
:schemaLocation
="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/maven-v4_0_0.xsd"
>
<
m
odelVersion
>4.0.0</
modelVersion
>
<
g
roupId
>com.example</
groupId
>
<
a
rtifactId
>bdd-api-automation</
artifactId
>
<
v
ersion
>1.0-SNAPSHOT</
version
>
<
d
ependencies
>
<!-- TestNG Dependency -->
<
d
ependency
>
<
g
roupId
>org.testng</
groupId
>
<
a
rtifactId
>testng</
artifactId
>
<
v
ersion
>7.4.0</
version
>
<
s
cope
>test</
scope
>
</
dependency
>
<!-- Rest Assured Dependency -->
<
d
ependency
>
80
End to End APIs and API Testing, Curated by Lamhot Siagian
<g
roupId>io.rest-assured</
groupId
>
<
a
rtifactId>rest-assured</
artifactId
>
<
v
ersion>4.3.3</
version
>
</
dependency
>
<!-- Cucumber Dependencies -->
<
d
ependency>
<
g
roupId>io.cucumber</
groupId
>
<
a
rtifactId>cucumber-java</
artifactId
>
<
v
ersion>6.10.4</
version
>
</
dependency
>
<
d
ependency>
<
g
roupId>io.cucumber</
groupId
>
<
a
rtifactId>cucumber-testng</
artifactId
>
<
v
ersion>6.10.4</
version
>
</
dependency
>
<!-- JSON Schema Validator Dependency -->
<
d
ependency>
<
g
roupId>io.rest-assured</
groupId
>
<
a
rtifactId>json-schema-validator</
artifactId
>
<
v
ersion>4.3.3</
version
>
</
dependency
>
<
d
ependency>
<
g
roupId>org.testng</
groupId
>
<
a
rtifactId>testng</
artifactId
>
<
v
ersion>7.4.0</
version
>
<
s
cope>compile</
scope
>
</
dependency
>
</
dependencies
>
<
p
roperties
>
<
m
aven.compiler.source >17</
maven.compiler.source
>
<
m
aven.compiler.target >17</
maven.compiler.target
>
</
properties
>
</
project
>
Project Structure
81
End to End API Testing, Curated by Lamhot Siagian
src/test/resources/features
Create a feature file in .
Feature
: User API Testing
Scenario
: Get Users
Given
the API endpoint is "https://reqres.in/api/users?page=2"
When
I send a GET request to the endpoint
Then
the response status code should be 200
And
the response should contain "page"
82
End to End APIs and API Testing, Curated by Lamhot Siagian
src/test/java/steps
Create a new Java class for step definitions in .
package
steps
;
mport
i io.restassured.RestAssured;
import
io.restassured.response.Response
;
import
io.cucumber.java.en.
Given
;
import
io.cucumber.java.en.
When
;
import
io.cucumber.java.en.
Then
;
import
org.testng.Assert
;
public class
ApiSteps
{
rivate
p String
endpoint
;
private
Response
response;
Given
@ (
"
the API endpoint is {string}")
public void
theApiEndpointIs
(
String
url) {
this
.
e
ndpoint
= url;
83
End to End API Testing, Curated by Lamhot Siagian
}
When
@ (
"
I send a GET request to the endpoint"
)
public void
iSendAGetRequestToTheEndpoint
() {
response
=
RestAssured
.
given
()
.get(
endpoint
);
}
Then
@ (
"
the response status code should be {int}" )
public void
theResponseStatusCodeShouldBe
(
int
statusCode)
{
Assert
.
assertEquals
(
response
.getStatusCode(),
statusCode);
}
Then
@ (
"
the response should contain {string}" )
public void
theResponseShouldContain
(
String
content)
{
Assert
.
assertTrue
(
response
.asString().contains(content));
}
}
src/test/java/runners
Create a test runner class in .
package
runners
;
mport
i io.cucumber.testng.AbstractTestNGCucumberTests
;
import
io.cucumber.testng.
CucumberOptions
;
@CucumberOptions
(
features =
"src/test/resources/features"
,
glue =
"steps"
)
public class
TestRunner
extends
AbstractTestNGCucumberTests
{
}
84
End to End APIs and API Testing, Curated by Lamhot Siagian
mvn test
2. Run from Maven: You can also run the tests using Mavenwith the following command:
1. A
nnotations: TestNG provides a wide range of annotationswhich makes it easier to write tests and
understand them.
85
End to End API Testing, Curated by Lamhot Siagian
2. T est Configuration: TestNG allows you to configure your test suites, groups, and test parameters
easily through XML files.
3. Parallel Execution: TestNG supports parallel executionof tests, which is essential for speeding up
the testing process.
4. Data-driven Testing: It supports data providers fordata-driven testing.
5. Integration: TestNG can be easily integrated withother tools and frameworks like Maven, Jenkins,
and various reporting tools.
● asic Authentication: Include the username and passwordin the request header.
B
● OAuth: Use tokens obtained through authorization servers.
● API Keys: Include the API key in the request headeror URL parameter.
● JWT (JSON Web Tokens): Include the JWT token in therequest header.
/ Basic Authentication
/
given().auth().basic(
"username"
,
"password"
).when().get(
"/endpoint"
);
// OAuth
given().auth().oauth2(
"access_token"
).when().get(
"/endpoint"
);
// API Key
given().header(
"API-Key"
,
"your_api_key"
).when().get(
"/endpoint"
);
// JWT
given().header(
"Authorization"
,
"Bearer
your_jwt_token"
).when().get(
"/endpoint"
);
● tatus Code: Ensure the response code is as expected(e.g., 200 OK, 404 Not Found).
S
● Response Body: Validate the data returned in the responsebody.
● Headers: Check if the required headers are presentand correct.
● Schema Validation: Ensure the response follows a predefinedschema.
// Status Code
Assert
.
assertEquals
(
response
.getStatusCode(),
200
);
86
End to End APIs and API Testing, Curated by Lamhot Siagian
// Response Body
Assert
.
assertTrue
(
response
.asString().contains(
"expectedValue"
));
// Header
Assert
.
assertEquals
(
response
.getHeader(
"Content-Type"
),
"application/json"
);
// Schema Validation
response
.then().assertThat().body(matchesJsonSchemaInClasspath(
"schema.json"
));
nswer: Data-driven testing involves running the same test case with multiple sets ofdata.Thiscanbe
A
done using external data sources like Excel, CSV files, or databases.
DataProvider(name =
@ "userData"
)
public
Object
[][] createUserData() {
return new
Object[][]{
{
"
John"
,
"Developer"
},
{
"
Jane"
,
"Tester"
}
};
}
Test(dataProvider =
@ "userData")
public void
testCreateUser(String
name,
String
job)
{
given().body(
"{
\"
name
\"
:
\"
"
+ name +"
\"
,
\"
job
\"
:
\"
"
+ job +
"
\
"
}"
)
.when().post(
"/users"
)
.then().statusCode(
201
);
}
● V alidating Error Responses: Ensure the API returnsappropriate error codes and messages (e.g., 400
Bad Request, 401 Unauthorized).
● Boundary Testing: Test the API with edge cases andinvalid inputs.
● Exception Handling: Ensure the API gracefully handlesexceptions and returns user-friendly error
messages.
Response response
= given().when().get(
"/invalid-endpoint"
);
87
End to End API Testing, Curated by Lamhot Siagian
ssert
A .
a
ssertEquals
(
response
.getStatusCode(),
404
);
Assert
.
a
ssertTrue
(
r
esponse
.asString().contains(
"Not
Found"
));
L
● imit and Offset: Specify the number of records toreturn and the starting point.
● Page and Page Size: Define the page number and thenumber of records per page.
● Cursor-Based: Use a pointer to keep track of the currentposition in the data set.
esponse response
R = given().queryParam("page"
,
2
).queryParam(
"pageSize"
,
10
).when().get(
"/users"
);
Assert
.
a
ssertEquals
(
response
.getStatusCode(),
200);
Assert
.
a
ssertTrue
(
r
esponse.jsonPath().getList(
"data"
).size()
<=
10
);
nswer: Behavior-Driven Development (BDD) is a software development approach that encourages
A
collaboration between developers, testers, and business stakeholders. It involves writing test cases in a
natural language that is understandable by all stakeholders. In API testing, BDD helps in defining the
behavior of APIs in a readable format using tools like Cucumber.
Answer:
Answer:
88
End to End APIs and API Testing, Curated by Lamhot Siagian
● ucumber: For writing BDD tests in Gherkin syntax.
C
● Rest Assured: For making HTTP requests and validatingresponses.
● Serenity BDD: For generating comprehensive test reports.
● TestNG: For running tests.
● JBehave: Another BDD framework for Java.
Feature
: Create a new user
Scenario
: Successful creation of a new user
Given
the API endpoint is "https://reqres.in/api/users"
When
I send a POST request to the endpoint with
the following details
|
name |
job |
|
John Doe
|
Developer
|
Then
the response status code should be 201
And
the response should contain "name"
And
the response should contain "job"
mport
i io.restassured.RestAssured;
import
io.restassured.response.Response;
import
io.cucumber.java.en.Given;
import
io.cucumber.java.en.When;
import
io.cucumber.java.en.Then;
import
org.testng.Assert;
import
java.util.Map;
public class
ApiSteps {
rivate
p String endpoint;
private
Response response;
Given(
@ "the API endpoint is {string}"
)
public void
theApiEndpointIs(String url) {
this
.endpoint = url;
}
When(
@ "I send a POST request to the endpoint with
the following details"
)
public void
iSendAPostRequestToTheEndpointWithTheFollowingDetails(Map<String,
String> userDetails) {
89
End to End API Testing, Curated by Lamhot Siagian
response = RestAssured
.given()
.contentType(
"application/json"
)
.body(userDetails)
.post(
endpoint
);
}
Then
@ (
"
the response status code should be {int}"
)
public void
theResponseStatusCodeShouldBe(
int
statusCode)
{
Assert.assertEquals(response.getStatusCode(), statusCode);
}
Then(
@ "the response should contain {string}"
)
public void
theResponseShouldContain(String content)
{
Assert.assertTrue(response.asString().contains(content));
}
}
package
runners
;
mport
i io.cucumber.testng.AbstractTestNGCucumberTests
;
import
io.cucumber.testng.
CucumberOptions
;
@CucumberOptions
(
features =
"src/test/resources/features"
,
glue =
"steps"
)
public class
TestRunner
extends
AbstractTestNGCucumberTests
{
}
Answer:Gherkinisadomain-specificlanguageforwritingBDDtestcases.ItusesplainEnglishlanguage
Feature
todefinetestcasesinastructuredmannerusingkeywordslike Scenario
, Given
, When
, Then
, ,
And
and .
Feature
: User creation
90
End to End APIs and API Testing, Curated by Lamhot Siagian
Scenario Outline
: Create multiple users
Given
the API endpoint is "https://reqres.in/api/users"
When
I send a POST request to the endpoint with
the following details
|
name |
job |
|
<name> |
<job> |
Then
the response status code should be 201
And
the response should contain "name"
And
the response should contain "job"
Examples
:
|
name |
job |
|
John Doe
|
Developer
|
|
Jane Doe
|
Tester |
Then(
@ "the response should contain {string}"
)
public void
theResponseShouldContain(String content)
{
Assert.assertTrue(response.asString().contains(content));
}
Then(
@ "the response should contain the field {string}
with value {string}"
)
public void
theResponseShouldContainTheFieldWithValue(String
field, String value) {
Assert.assertEquals(response.jsonPath().getString(field), value);
}
When(
@ "I send a POST request to the endpoint with
the following details and token
{string}"
)
public void
iSendAPostRequestToTheEndpointWithTheFollowingDetailsAndToken(String
token, Map<String, String> userDetails) {
response = RestAssured
.given()
.header(
"Authorization"
,
"Bearer "
+ token)
.contentType(
"application/json"
)
.body(userDetails)
.post(endpoint);
}
91
End to End API Testing, Curated by Lamhot Siagian
When
@ (
"
I send the same POST request multiple times"
)
public void
iSendTheSamePostRequestMultipleTimes
(Map<
String
,
String
> userDetails) {
response
=
RestAssured
.
g
iven
()
.contentType(
"application/json"
)
.body(userDetails)
.post(
endpoint
);
Response responseRepeated
=
RestAssured
.
g
iven
()
.contentType(
"application/json"
)
.body(userDetails)
.post(
endpoint
);
ssert
A .
a
ssertEquals
(
response
.getStatusCode(),
responseRepeated
.getStatusCode());
Assert
.
a
ssertEquals
(
response
.asString(),
responseRepeated
.asString());
}
Answer:Handle rate limiting by sending requests ina loop and checking the response for rate limit errors.
When
@ (
"
I send multiple requests to the endpoint" )
public void
iSendMultipleRequestsToTheEndpoint () {
for
(
i
nt
i =
0; i <
10
; i++) {
response
=RestAssured
.
given
().get(
endpoint
);
if
(
r
esponse.getStatusCode() ==
429
) {
// 429Too Many Requests
break
;
}
}
}
Then
@ (
"
I should receive a rate limit error")
public void
iShouldReceiveARateLimitError() {
Assert
.
a
ssertEquals(
r
esponse
.getStatusCode(),
429
);
Assert
.
a
ssertTrue
(
response
.asString().contains(
"rate
limit"
));
}
Answer:Use JSON schema validation to ensure the responsematches the expected schema.
92
End to End APIs and API Testing, Curated by Lamhot Siagian
import
io.restassured.module.jsv.JsonSchemaValidator
;
Then
@ (
"
the response should match the schema {string}")
public void
theResponseShouldMatchTheSchema
(
String
schemaPath) {
esponse
r .then().assertThat().body(JsonSchemaValidator.matchesJsonSchemaInClasspath(sc
hemaPath));
}
Given
@ (
"
the API endpoint is set for {string} environment")
public void
theApiEndpointIsSetForEnvironment
(
String
environment) {
if
(environment.equalsIgnoreCase(
"production"
))
{
this
.
e
ndpoint
=
"https://api.production.com/users";
}
else if
(environment.equalsIgnoreCase(
"staging"
))
{
this
.
e
ndpoint
=
"https://api.staging.com/users";
}
}
Answer:Manage test data using external files (CSV,JSON, Excel) or in-memory data providers.
DataProvider(name =
@ "userData"
)
public
Object
[][]
createUserData() {
return new
Object[][]{
{
"
John Doe"
,
"Developer"},
{
"
Jane Doe"
,
"Tester"}
};
}
Test(dataProvider =
@ "userData")
public void
testCreateUser(
String
name,
String
job)
{
given().body(
"{
\"
name
\"
:
\"
"
+ name +"
\"
,
\"
job
\"
:
\"
"
+ job +
"
\
"
}"
)
.when().post(
"/users"
)
.then().statusCode(
201
);
}
93
End to End API Testing, Curated by Lamhot Siagian
Chapter 7
Install Java
J Meter requires Java to be installed on your machine. Ensure you have the Java DevelopmentKit(JDK)
installed.
1. Check if Java is already installed:Open a terminal(Command Prompt on Windows) and type:
ava -version
j ; you will see a version number if Javais installed.
2. Download and install Java:
○ If Java is not installed, download the JDK from theOracle websiteorOpenJDK.
○ Follow the installation instructions specific to your operating system.
Download JMeter
. G
1 o to theApache JMeter download page.
2. Download the binary (zip or tgz) file from the "Binaries" section.
Install JMeter
Setting up environment variables allows you to run JMeter from any command prompt or terminal
irectory.
d
94
End to End APIs and API Testing, Curated by Lamhot Siagian
Windows:
- pen the Control Panel, go to System and Security > System > Advanced system settings.
O
- Click on "Environment Variables".
- Pathvariable,select it, and click "Edit".
Under "System variables", find the
- bindirectory of the extractedJMeter folder (e.g.,
Add the path to the
C:\path\to\apache-jmeter-<version>\bin
).
Mac/Linux:
- ~/.bashrc(or
pen your terminal and edit the
O ~/.bash_profileor
~/.zshrcif using zsh)
file:
nano ~/.bashrc
Launch JMeter
1. Windows:
bindirectory inside the JMeter folder.
○ Navigate to the
jmeter.batto launch JMeter.
○ Double-click
2. Mac/Linux:
○ Open a terminal.
bindirectory inside the JMeter folder.
○ Navigate to the
○ Run the following command:
./jmeter.sh
Verify Installation
After launching JMeter, you should see the JMeter GUI, which indicates that the installation succeeded.
95
End to End API Testing, Curated by Lamhot Siagian
Tips:
● Updating JMeter:To update JMeter, download the latestversion and replace the old folder with the
ew one. Ensure that the
n Pathvariable (if set) isupdated accordingly.
Plugins:Consider installing JMeter plugins for extendedfunctionality. Visit theJMeter Plugins
●
websitefor more information.
96
End to End APIs and API Testing, Curated by Lamhot Siagian
JMeter Components
6
pache JMeter has several key components that you can use to design and execute your performance tests.
A
Here’s an overview of the main components:
● D escription:A Test Plan is the container for yourentire test script. It includes all the other
components like Thread Groups, Samplers, Listeners, and more.
● Usage:Define the overall structure of your performancetest. Add other components to build your
test scenario.
● D escription:A Thread Group represents a group ofvirtual users that will execute the test scripts. It
defines the number of users, the ramp-up period, and the loop count.
● Usage:Configure how many users will run the test,how quickly they will start, and how many
times they will repeat the test.
3. Samplers
● D escription:Samplers are requests that JMeter sendsto the server. They can be of various types,
including HTTP requests, FTP requests, JDBC requests, and more.
● Types of Samplers:
○ HTTP Request:Used to send HTTP/HTTPS requests.
○ FTP Request:Used to send FTP commands.
6
https://www.devstringx.com/use-jmeter-for-api-load-testing
97
End to End API Testing, Curated by Lamhot Siagian
D
● escription:Logic Controllers determine the orderin which Samplers are processed.
● Types of Logic Controllers:
○ Simple Controller:Organizes the samplers and othercontrollers.
○ Loop Controller:Runs the samplers a specified numberof times.
○ If Controller:Executes samplers only if a certaincondition is true.
○ Transaction Controller:Measures the overall timetaken to complete a set of nested
samplers.
○ While Controller:Repeats the nested samplers whilea condition is true.
5. Listeners
● D escription:Listeners collect and display the resultsof the test execution. They provide different
views of the performance test results.
● Types of Listeners:
○ View Results Tree:Shows the results of each samplein a tree format.
○ Summary Report:Provides a summary of performancemetrics.
○ Graph Results:Displays the test results in a graphicalformat.
○ Aggregate Report:Summarizes statistics like average,min, max, and standard deviation for
the test samples.
6. Timers
● D escription:Timers introduce delays between requests.They help simulate real-world user
interactions by adding think time.
● Types of Timers:
○ Constant Timer:Introduces a fixed delay.
○ Gaussian Random Timer:Introduces a random delay basedon a Gaussian distribution.
○ Uniform Random Timer:Introduces a random delay withina specified range.
○ Constant Throughput Timer:Controls the throughputby introducing pauses to maintain a
specified number of requests per minute.
7. Assertions
● D escription:Assertions are used to validate the responsesreceived from the server. They ensure
that the responses contain the expected data.
● Types of Assertions:
○ Response Assertion:Checks for patterns in the responsetext.
○ Duration Assertion:Verifies that the response timeis within a specified limit.
○ Size Assertion:Ensures that the response is of acertain size.
98
End to End APIs and API Testing, Curated by Lamhot Siagian
● D escription:Configuration Elements provide supportdata for Samplers and modify the requests
they send.
● Types of Configuration Elements:
○ CSV Data Set Config:Reads data from a CSV file forparameterization.
○ HTTP Request Defaults:Sets default values for HTTPrequests.
○ User Defined Variables:Defines variables that canbe used throughout the test plan.
○ JDBC Connection Configuration:Configures databaseconnections.
● Pre-Processors:
○ Description:Pre-Processors are actions that are performedbefore the sampler request is
sent.
○ Example:HTTP URL Re-writing Modifier, Regular ExpressionExtractor.
● Post-Processors:
○ Description:Post-Processors are actions that areperformed after the sampler request has
been sent.
○ Example:Regular Expression Extractor, JSON Path Post-Processor.
● D escription:Test Fragments are used to define partsof the test that can be reused in other parts of
the test plan.
● Usage:Useful for modularizing the test plan and reusingcomponents.
hese components allow you to create comprehensive and flexible performance tests in JMeter. By
T
combining these elements, you can simulate complex scenarios andgatherdetailedperformancemetrics
for your application.
File
1. In JMeter, create a new test plan by selecting > New
.
99
End to End API Testing, Curated by Lamhot Siagian
100
End to End APIs and API Testing, Curated by Lamhot Siagian
Add a Listener
101
End to End API Testing, Curated by Lamhot Siagian
. S
1 File > Save
ave the test plan by selecting .
2. Click the green "Start" button (a triangle) in the JMeter toolbar to run the test.
3. View the results in the Listener you added.
Example Configuration
102
End to End APIs and API Testing, Curated by Lamhot Siagian
nswer:API performance testing involves evaluatingthe speed, responsiveness, and stability of an API
A
under various conditions. It helps ensure the API can handle the expected load and perform efficiently.
nswer:Performance testing ensures that the API canhandle high traffic, provides a good user experience,
A
identifies potential bottlenecks, and meets the performance criteria before going live.
nswer:Load testing measures the system’s performanceunder expected user loads, while stress testing
A
evaluates how the system behaves under extreme or beyond expected loads.
nswer:Create a Test Plan, add a Thread Group, configurethe number of threads and ramp-up period,
A
add an HTTP Request sampler, specify the API details, and add a Listener to capture the results.
nswer:Key metrics include response time, throughput,error rate, latency, and resource utilization (CPU,
A
memory).
nswer:Throughput refers to the number of requestsprocessed by the API per unit of time, usually
A
measured in transactions per second (TPS).
nswer:Latency is the time taken for a request totravel from the client to the server and back. It is the
A
delay between the request and the first byte of the response.
nswer:Use the Regular Expression Extractor to capturedynamic values from the response and store
A
them in variables for use in subsequent requests.
103
End to End API Testing, Curated by Lamhot Siagian
nswer:Listeners capture and display the resultsof the test execution. They provide various reports and
A
visualizations to analyze the performance data.
nswer:Increase the number of threads (users) inthe Thread Group, adjust the ramp-up period, and
A
configure the loop count to simulate a high load on the API.
nswer:The ramp-up period defines the time takento start all threads. It helps in gradually increasing the
A
load on the server to avoid sudden spikes.
nswer:Analyze metrics such as response time, CPUand memory usage, throughput, and error rates. Use
A
profiling tools to pinpoint slow-performing code or database queries.
nswer:Distributed testing involves using multiplemachines to generate a higher load than a single
A
machine can handle. It allows for testing larger-scale scenarios.
nswer:The main types are load testing, stress testing,endurance testing, spike testing, and volume
A
testing.
nswer:Ensure a controlled environment, use realistictest data, run multiple iterations, monitor system
A
resources, and analyze results to identify any anomalies.
nswer:Correlation involves capturing and reusingdynamic values from the server response in
A
subsequent requests. It ensures that the test script accurately simulates real-world scenarios.
nswer:Think Time simulates the real user’s waittime between actions. It adds pauses in the test script to
A
mimic user interactions more accurately.
104
End to End APIs and API Testing, Curated by Lamhot Siagian
nswer:Increase the number of threads abruptly in a short period to simulate a sudden spike in traffic and
A
observe how the API handles the load.
● efine clear performance criteria and goals.
D
● Use realistic test data and scenarios.
● Run tests in a production-like environment.
● Monitor and analyze system resources.
● Perform tests iteratively and continuously.
105
End to End API Testing, Curated by Lamhot Siagian
Chapter 8
ocreateacomprehensiveandwell-organizedtestframeworkforAPItestingwithCucumber,weneedto
T
consider several aspects: request handling, response verification, exception management, configurations,
userauthentication,processing,modeling,testframeworksetup,testassertions,logging,utilityfunctions,
test execution, debugging configurations, and a test driver.
Project Structure
s rc
├── main
│ └── java
│ └── com/yourcompany/yourproject
│ ├── config
│ │ └── Config.java
│ ├── exceptions
│ │ └── ApiException.java
│ ├── model
│ │ └── ApiResponse.java
│ ├── processor
│ │ └── ResponseProcessor.java
│ ├── util
│ │ ├── ApiClient.java
│ │ ├── AuthenticationUtil.java
│ │ ├── LoggerUtil.java
│ │ └── TestUtil.java
│ └── driver
│ └── TestDriver.java
└── test
└── java
└── com/yourcompany/yourproject
├── features
│ └── api.feature
├── runners
│ └── TestRunner.java
└── stepdefinitions
└── ApiStepDefinitions.java
106
End to End APIs and API Testing, Curated by Lamhot Siagian
Dependencies
<
p
roject
xmlns
="http://maven.apache.org/POM/4.0.0"
xmlns:
xsi
="http://www.w3.org/2001/XMLSchema-instance"
xsi
:schemaLocation
="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/maven-v4_0_0.xsd"
>
<
m
odelVersion
>4.0.0</
modelVersion
>
<
g
roupId
>com.example</
groupId
>
<
a
rtifactId
>bdd-api-automation</
artifactId
>
<
v
ersion
>1.0-SNAPSHOT</
version
>
<
d
ependencies
>
<!-- TestNG Dependency -->
<
d
ependency
>
<
g
roupId
>org.testng</
groupId
>
<
a
rtifactId
>testng</
artifactId
>
<
v
ersion
>7.4.0</
version
>
<
s
cope
>test</
scope
>
</
dependency
>
<!-- Rest Assured Dependency -->
<
d
ependency
>
<
g
roupId
>io.rest-assured</
groupId
>
<
a
rtifactId
>rest-assured</
artifactId
>
<
v
ersion
>4.3.3</
version
>
</
dependency
>
<!-- Cucumber Dependencies -->
<
d
ependency
>
<
g
roupId
>io.cucumber</
groupId
>
<
a
rtifactId
>cucumber-java</
artifactId
>
<
v
ersion
>6.10.4</
version
>
</
dependency
>
<
d
ependency
>
<
g
roupId
>io.cucumber</
groupId
>
<
a
rtifactId
>cucumber-testng</
artifactId
>
<
v
ersion
>6.10.4</
version
>
</
dependency
>
<!-- JSON Schema Validator Dependency -->
<
d
ependency
>
<
g
roupId
>io.rest-assured</
groupId
>
<
a
rtifactId
>json-schema-validator</
artifactId
>
<
v
ersion
>4.3.3</
version
>
</
dependency
>
<
d
ependency
>
<
g
roupId
>org.testng</
groupId
>
<
a
rtifactId
>testng</
artifactId
>
<
v
ersion
>7.4.0</
version
>
<
s
cope
>compile</
scope
>
</
dependency
>
<!-- JUnit for running tests -->
<
d
ependency
>
<
g
roupId
>junit</
groupId
>
<
a
rtifactId
>junit</
artifactId
>
<
v
ersion
>4.13.2</
version
>
<
s
cope
>test</
scope
>
</
dependency
>
<!-- Logging -->
<
d
ependency
>
<
g
roupId
>org.slf4j</
groupId
>
107
End to End API Testing, Curated by Lamhot Siagian
<a
rtifactId>slf4j-api</
artifactId
>
<
v
ersion>1.7.30</
version
>
</
dependency
>
<
d
ependency>
<
g
roupId>org.slf4j</
groupId
>
<
a
rtifactId>slf4j-simple</
artifactId
>
<
v
ersion>1.7.30</
version
>
</
dependency
>
</
dependencies
>
<
p
roperties
>
<
m
aven.compiler.source >17</
maven.compiler.source
>
<
m
aven.compiler.target >17</
maven.compiler.target
>
</
properties
>
</
project
>
Configuration
reate a configuration class to manage configurations in
C
src/main/java/com/yourcompany/yourproject/config/Config.java
.
package
config
;
public class
Config
{
public static final
String
BASE_URL
=
"http://api.yourservice.com"
;
public static final
String
AUTH_TOKEN
=
"your-auth-token"
;
}
Exception Handling
Create a custom exception class for API exceptions in
src/main/java/com/yourcompany/yourproject/exceptions/ApiException.java
.
package
exceptions
;
public class
ApiExceptionextends
RuntimeException
{
public
ApiException
(
String
message) {
super
(message);
}
public
ApiException
(
String
message,
Throwable
cause)
{
super
(message, cause);
}
}
Models
odel refers to the representation of the data structuresusedbytheAPI.ThesemodelsareusuallyJava
M
classes that mirror the JSON or XML payloads exchanged between theclientandtheserver.Bycreating
108
End to End APIs and API Testing, Curated by Lamhot Siagian
t hesemodelclasses,youcaneasilyserializeanddeserializeAPIrequestandresponsebodies,makingthe
test code cleaner and more maintainable.
package
model
;
public class
ApiResponse
{
private int
statusCode
;
private
String
body
;
public void
setStatusCode
(
int
statusCode) {
this
.
s
tatusCode
= statusCode;
}
public
String
getBody
() {
return
body
;
}
public void
setBody
(
S
tring
body) {
this
.
b
ody
= body;
}
}
Utility Classes
tility classes in an automation framework provide common functionalities that can be reused across
U
differentpartsofthetestscripts.Theyhelptoavoidcodeduplicationandmakethetestscriptscleanerand
more maintainable.
109
End to End API Testing, Curated by Lamhot Siagian
package
util
;
import
io.restassured.response.Response
;
import static
io.restassured.RestAssured
.*;
public class
ApiClient
{
public static
Response
get
(
String
endpoint) {
return
given
().when().get(endpoint);
}
public static
Response
post
(
String
endpoint,
Object
body) {
return
given
().body(body).when().post(endpoint);
}
Authentication Util
ser authentication is typically integrated within the request component. However, it should be made
U
explicit and visible to facilitate future modifications without affecting other components. This clarity also
simplifies adding support for testing different authentication types.
package
util
;
import
config.Config
;
public class
AuthenticationUtil
{
public static
String
getAuthToken
() {
// Return auth token from config or fetch dynamically
return
Config
.
AUTH_TOKEN
;
}
}
Logger Util
Loggersupportisbeneficialforwritingtestscripts,thoughit'snotstrictlymandatory.Log4jiswidelyused
i n Java projects for logging purposes and is especially helpful during debugging.
110
End to End APIs and API Testing, Curated by Lamhot Siagian
package
util
;
mport
i org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
public class
LoggerUtil
{
Test Util
I ntestscripts,thereareoftenrequirementstogeneratetimevaluesinvariousunits(milliseconds,seconds,
minutes, hours, etc.), sort responses, or handleotherroutinetasksessentialforapplicationtesting.These
functionalities can be efficiently managed within the test framework's utility component.
package
util
;
import
org.testng.Assert
;
public class
TestUtil
{
Response Processor
oumayneedtoexecutetestsindividually,aspartofasuite,orbyrunningdifferenttestmethodswithina
Y
test class. Ideally, the test framework should provide support for all these scenarios. If it doesn't, you'll
need to implement the necessary functionality to handle them.
111
End to End API Testing, Curated by Lamhot Siagian
package
processor
;
mport
i io.restassured.response.Response
;
import
model.ApiResponse
;
public class
ResponseProcessor
{
public static
ApiResponse
processResponse
(
Response
response) {
ApiResponse apiResponse
=
new
ApiResponse();
apiResponse
.setStatusCode(response.getStatusCode());
apiResponse
.setBody(response.getBody().asString());
return
apiResponse
;
}
}
Feature File
Create a feature file in
src/test/java/com/yourcompany/yourproject/features/api.feature
.
Feature
: API Testing
Scenario Outline
: Test API with multiple data sets
Given
I set up the API endpoint "<endpoint>"
When
I send a GET request
Then
the response status code should be <statusCode>
And
the response should contain "<expectedValue>"
Examples
:
|
endpoint
| statusCode
|
expectedValue
|
|
/api/test/1 |
200 |
value1 |
|
/api/test/2 |
404 |
error |
|
/api/test/3 |
200 |
value3 |
112
End to End APIs and API Testing, Curated by Lamhot Siagian
Step Definitions
package
steps
;
mport
i io.cucumber.java.en.
*;
import
model.ApiResponse
;
import
processor.ResponseProcessor
;
import
util.ApiClient
;
import
util.TestUtil
;
public class
ApiStepDefinitions
{
rivate
p String
endpoint
;
private
ApiResponse
apiResponse
;
Given
@ (
"
I set up the API endpoint {string}")
public void
i_set_up_the_api_endpoint
(
String
endpoint)
{
this
.
e
ndpoint
= endpoint;
}
When
@ (
"
I send a GET request"
)
public void
i_send_a_get_request
() {
apiResponse
=
ResponseProcessor
.
processResponse
(
ApiClient
.
get
(
endpoint
));
}
Then
@ (
"
the response status code should be {int}" )
public void
the_response_status_code_should_be(
int
statusCode) {
TestUtil
.
assertStatusCode
(
apiResponse
.getStatusCode(),
statusCode);
}
Then
@ (
"
the response should contain {string}")
public void
the_response_should_contain(
String
expectedValue) {
TestUtil
.
assertResponseContains
(
apiResponse
.getBody(),
expectedValue);
}
}
Test Runner
package
runners
;
import
org.junit.runner.
RunWith
;
mport
i io.cucumber.
testng.AbstractTestNGCucumberTests;
import
io.cucumber.
testng.CucumberOptions;
113
End to End API Testing, Curated by Lamhot Siagian
@CucumberOptions(
features =
"src/test/resources/features"
,
glue =
"steps"
)
public class
TestRunner
extends
AbstractTestNGCucumberTests
{
}
Test Driver
reate a test driver class if needed for custom test execution in
C
src/main/java/com/yourcompany/yourproject/driver/TestDriver.java
.
package
driver
;
public class
TestDriver
{
114
End to End APIs and API Testing, Curated by Lamhot Siagian
1. Q uestion:How would you design an API test frameworkusing Cucumber?Answer:I would
design the framework by organizing the project structure into separate packages for features, step
definitions, and utilities. The features package would contain the Cucumber feature files written in
Gherkin syntax. The step definitions package would map Gherkin steps to Java methods,
leveraging libraries like RestAssured for API interactions. The utilities package would include
common helper classes, such as configuration managers and custom assertions.
2. Question:What are the benefits of using Cucumberfor API testing?Answer:Cucumber allows for
Behavior-Driven Development (BDD), making test scenarios readable and understandable by
non-technical stakeholders. It facilitates collaboration between developers, testers, and business
analysts. The use of Gherkin syntax ensures that the test scenarios are written in plain language,
promoting clear communication of requirements and test cases.
3. Q uestion:How do you structure your request and responseclasses in a Cucumber-based API test
framework?Answer:I create model classes that representthe JSON payloads for requests and
responses. These model classes are used for serialization and deserialization using libraries like
Jackson or Gson. The step definitions interact with these model classes to send requests and
validate responses, ensuring a clean separation of concerns.
4. Question:How would you handle different HTTP methods(GET, POST, PUT, DELETE) in your
ApiClientUtil
f ramework?Answer:I would create a utility class,such as , which provides
methods for different HTTP methods. Each method would use RestAssured to send the respective
HTTP request, passing necessary headers, query parameters, and body data. This utility class
would be reusable across different step definitions.
Exception Handling
When(
@ "^I send a GET request to the endpoint
\"
([^
\"
]*)
\"
$"
)
public void
sendGetRequest
(
String
endpoint) {
try
{
115
End to End API Testing, Curated by Lamhot Siagian
esponse
R response
= ApiClientUtil.get(endpoint);
scenarioContext.setResponse(
response
);
}
catch
(
Exception
e) {
LoggerUtil.logError(
"Failed to send GET request"
,
e);
throw new
CustomException(
"Error occurred while
sending GET request to "
+ endpoint, e);
}
}
Configurations
7. Question:How do you manage different configurations(e.g., environment URLs, credentials) in
ConfigUtil
your test framework?Answer:I use a configurationutility class, such as , that loads
p config.properties
roperties from a configuration file (e.g., ).This class provides methods to
retrieve configuration values, making it easy to manage environment-specific settings and
credentials.
8. Question:How would you load configuration propertiesdynamically in your tests?Answer:I load
configuration properties dynamically by reading the properties file at the start of the test execution.
his can be done in a setup method annotated with
T @Beforein Cucumber or using a static
initializer block in the configuration utility class. This ensures that the properties are available
throughout the test execution.
User Authentication
9. Question:How do you handle user authentication inyour API tests?Answer:I handle user
a AuthUtil
uthentication by creating a utility class, such as , that manages the generation and
management of authentication tokens. This class provides methods to obtain tokens for different
authentication types (e.g., Basic Auth, OAuth) and includes these tokens in the request headers as
needed.
10. Question:How would you manage different types ofauthentication (e.g., Basic Auth, OAuth) in
AuthUtilclass for each
our test framework?Answer:I create separate methodsin the
y
authentication type. For Basic Auth, I encode the credentials and add them to the request headers.
For OAuth, I implement token retrieval and refresh logic. The step definitions call these methods to
include the appropriate authentication tokens in the API requests.
116
End to End APIs and API Testing, Curated by Lamhot Siagian
c lass would take the raw response as input, deserialize it into the corresponding model classes, and
perform necessary validation or transformation. This design promotes reusability and separation of
concerns.
Test Assertions
13. Question:What assertion libraries do you use in yourtest framework, and why?Answer:I use
assertion libraries like JUnit or TestNG for standard assertions and Hamcrest or AssertJ for more
expressive and readable assertions. These libraries provide a rich set of assertion methods that help
in writing clear and concise test validations.
14. Question:How do you implement custom assertions inyour API tests?Answer:I implement
TestUtil
c ustom assertions by creating utility methods in a class, such as . These methods
encapsulate complex validation logic, allowing reuse across multiple tests. Custom assertions
improve test readability and maintainability by abstracting repetitive validation logic.
Logger
Utilities
17. Question:What are some common utility classes youhave created for your API test framework?
ConfigUtilfor configuration management,
Answer:Common utility classes include
ApiClientUtilfor sending API requests,
AuthUtilforhandling authentication,
LoggerUtil
TestUtilfor custom assertions andtest-related utilities.
f or logging, and
18. Question:How do you manage reusable utility methodsin your test framework?Answer:I
manage reusable utility methods by organizing them into dedicated utility classes. Each utility class
focuses on a specific area of functionality, such as configuration management or API requests. This
modular approach promotes code reuse and maintainability.
Test Execution
19. Question:How do you organize and execute your Cucumbertests?Answer:I organize my
src/test/resourcesdirectory and step
Cucumber tests by placing feature files in the
src/test/javadirectory. I usea Cucumber runner class annotated with
definitions in the
117
End to End API Testing, Curated by Lamhot Siagian
RunWith(Cucumber.class)to execute the tests. The runner class specifies the location of
@
feature files and step definitions.
20. Question:How do you run your tests in parallel, andwhat are the challenges associated with
parallel test execution?Answer:I run tests in parallelusing tools like Cucumber-JVM Parallel
Plugin or JUnit’s parallel execution features. The challenges include managing shared resources,
ensuring thread safety, and handling test data dependencies. To address these challenges, I use
techniques like thread-local variables and isolate test data for each parallel test instance.
118
End to End APIs and API Testing, Curated by Lamhot Siagian
Chapter 9
Continuous Integration (CI) and Continuous Deployment (CD) are key practices in modern software
evelopment that help teams deliver code changes more frequently and reliably.
d
Introduction to CI/CD
ontinuous Integration (CI): Continuous Integration (CI) is a software development practice where
C
developers frequently commit code changes to a shared repository. Each commit triggers an automated
buildandtestingprocess,ensuringthatthenewcodeintegratessmoothlywiththeexistingcodebase.The
goal of CIistoidentifyandfixintegrationissuesearlyinthedevelopmentcycle,improvingcodequality
and reducing the time to deliver new features.
ontinuous Deployment (CD): Continuous Deployment (CD) extends CI by automating the release of
C
codechangestoproductionenvironments.OncethecodepassesallstagesoftestingintheCIpipeline,itis
automaticallydeployedtoproduction.ContinuousDeploymentaimstominimizemanualinterventionand
accelerate the delivery of new features to users, maintaining high quality and reliability.
PI testing is crucial in ensuring that the communication between differentsoftwaresystemsisreliable,
A
efficient, and secure. Integrating API testing into a CI/CD pipeline brings several benefits:
1. E arly Detection of Issues: Automated API tests runwith every code commit, identifying problems
early in the development cycle. This reduces the risk of deploying faulty APIs to production.
2. Consistency and Reliability: CI/CD ensures that APItests are executed consistently, leading to
more reliable and stable APIs. Automated tests can cover a wide range of scenarios and edge cases,
which might be missed during manual testing.
3. Faster Feedback Loop: Developers receive immediatefeedback on the impact of their changes on
the API, allowing them to address issues promptly. This speeds up the development process and
reduces the time spent on debugging and fixing errors.
4. Improved Collaboration: CI/CD fosters better collaborationamong development, QA, and
operations teams. Automated tests provide a common ground for verifying code quality, reducing
the chances of miscommunication and misunderstandings.
5. Scalability: As the number of APIs and their complexitygrow, manual testing becomes impractical.
CI/CD pipelines can scale to handle large volumes of API tests, ensuring comprehensive coverage
without increasing manual effort.
119
End to End API Testing, Curated by Lamhot Siagian
6. R egression Testing: Automated API tests ensure that new code changes do not break existing
functionality. Regression tests run automatically in the CI/CD pipeline, providing confidence that
the application remains stable over time.
7. Continuous Improvement: CI/CD pipelines facilitatecontinuous improvement by integrating new
tests and updating existing ones as the API evolves. This iterative approach helps maintain
high-quality APIs and adapts to changing requirements.
8. Reduced Deployment Risks: By automating the deploymentprocess, CD reduces the risk of
human errors during releases. APIs are deployed to production only after passing all automated
tests, ensuring a higher level of reliability.
9. Enhanced Security: Automated API tests can includesecurity tests to identify vulnerabilities and
ensure compliance with security standards. CI/CD pipelines can integrate tools for static and
dynamic analysis, improving the overall security posture of the API.
CD Tools
D(ContinuousDelivery)toolsaresoftwaresolutionsdesignedtoautomateandstreamlinetheprocessof
C
delivering software updates and features to production environments. They help teams build, test, and
deploy code more efficiently and reliably. Here are some popular CD tools:
Jenkins
Pros:
1. O pen Source and Free:Jenkins is open-source and freeto use, making it accessible for all types of
organizations.
2. Extensive Plugin Ecosystem:Jenkins has a vast pluginecosystem, allowing integration with many
other tools and services.
3. Highly Customizable:Due to its open-source nature,Jenkins can be customized to meet almost any
CI/CD requirement.
4. Large Community Support:Jenkins has a large, activecommunity that contributes to its plugins
and provides support.
Cons:
1. C omplex Setup and Maintenance:Jenkins requires manualsetup and ongoing maintenance, which
can be time-consuming.
2. Steep Learning Curve:The configuration and managementof Jenkins can be complex, especially
for beginners.
3. Performance Issues:Jenkins can experience performanceissues when scaling, especially with large
pipelines.
4. User Interface:The UI is considered outdated comparedto newer CI/CD tools.
GitLab CI/CD
Pros:
120
End to End APIs and API Testing, Curated by Lamhot Siagian
1. I ntegrated with GitLab:GitLab CI/CD is integrated with GitLab, providing a seamless experience
from code repository to CI/CD.
2. Ease of Use:GitLab CI/CD is easier to set up anduse compared to Jenkins, with a more modern UI.
3. Built-in Features:GitLab offers a wide range of built-infeatures such as version control, issue
tracking, and CI/CD.
4. Auto DevOps:GitLab provides Auto DevOps, which automatesCI/CD pipeline creation for
common use cases.
Cons:
1. R esource Intensive:Running GitLab CI/CD, especiallyon self-hosted instances, can be
resource-intensive.
2. Complexity for Advanced Use Cases:While GitLab CI/CDis easy to start with, complex pipelines
and integrations can become challenging.
3. Cost:While GitLab offers free tiers, advanced features,and larger pipelines may require a paid
subscription.
4. Runner Management:Managing GitLab Runners for CI/CDcan be cumbersome, especially at
scale.
AWS CodePipeline
Pros:
1. I ntegration with AWS Services:AWS CodePipeline integratesseamlessly with other AWS services,
making it ideal for AWS-centric environments.
2. Scalability:As a managed service, AWS CodePipelinescales automatically based on the workload.
3. Pay-as-You-Go:Pricing is based on usage, which canbe cost-effective for smaller projects.
4. Security and Compliance:AWS provides strong securityfeatures and compliance with various
standards.
Cons:
1. A WS Lock-in:Using AWS CodePipeline can lead to vendorlock-in, as it’s deeply integrated with
AWS services.
2. Learning Curve:Familiarity with AWS services andconcepts is required to effectively use
CodePipeline.
3. Less Flexibility:Compared to Jenkins, AWS CodePipelinehas fewer customization options and a
smaller ecosystem of plugins.
4. Cost for Larger Pipelines:Costs can accumulate quicklyfor larger projects or more complex
pipelines, especially if additional AWS services are required.
Travis CI
ravisCIisacontinuousintegrationserviceusedtobuildandtestsoftwareprojectshostedonGitHuband
T
Bitbucket. Here are some pros and cons of using Travis CI:
121
End to End API Testing, Curated by Lamhot Siagian
Pros
1. E ase of Use: Travis CI is straightforward to set up anduse,especiallyforopen-sourceprojects.It
integrates seamlessly with GitHub and Bitbucket repositories.
2. C onfigurationasCode:Configuringbuildsisdoneviaa.travis.ymlfile,whichisstoredinthe
repository. This makes it easy to version and review build configurations.
3. Language Support: Travis CI supports a widerangeofprogramminglanguagesandframeworks,
including JavaScript, Ruby, Python, PHP, Java, Go, and more.
4. Free for Open Source: Travis CI offers free unlimited builds for open-source projects, which is a
significant advantage for the open-source community.
5. Extensive Documentation: Travis CI provides comprehensive documentation and a robust
community, making it easier to find solutions to common issues.
6. Third-Party Integrations: It integrates well with other tools and services, such asSlack,HipChat,
and email for notifications, and can deploy to various cloud services.
7. Parallel Testing: Travis CI allows running multiple builds in parallel, which can speed uptheCI
process significantly.
Cons
1. L imited Free Plan for Private Repositories: For private repositories, the free plan has limitations,
and higher usage requires a paid subscription.
2. BuildSpeed:BuildtimescansometimesbeslowercomparedtootherCIservices,especiallyduring
peak times for free users.
3. C omplex Configuration: While .travis.ymlis powerful, it can become complex and hard to
manage for larger projects with many dependencies and build steps.
4. Resource Limitations: There are limitations on build times and resources (CPU,memory)forfree
plans, which can be restrictive for resource-intensive projects.
5. Lack of Advanced Features: Compared to some newer CI/CD tools, Travis CI may lack some
advanced features and flexibility, such as more sophisticated deployment workflows or more
granular control over build environments.
6. Vendor Lock-In: As with anyCIservice,therecanbesomelevelofvendorlock-in.Migratingtoa
different CI/CD platform can be time-consuming and require significant changes to the build
configuration.
CircleCI
Pros:
1. E ase of Use: CircleCI is user-friendly with an intuitiveinterface, making it easy for new users to get
started quickly.
2. Scalability: Offers excellent scalability options,allowing teams to run a large number of parallel
jobs.
3. Integration: Integrates well with many third-partytools and services like GitHub, Bitbucket,
Docker, and more.
122
End to End APIs and API Testing, Curated by Lamhot Siagian
. C
4 ustomization: Highly configurable pipelines with support for custom scripts and workflows.
5. Cloud and On-Premises: Provides both cloud-based andself-hosted solutions, giving flexibility
based on the team's needs.
Cons:
. P
1 ricing: Can get expensive, especially for largerteams or projects with high concurrency needs.
2. Configuration Complexity: YAML-based configurationfiles can become complex and difficult to
manage for very large projects.
3. Support: Users sometimes report slow support responsetimes.
Bamboo
Pros:
1. I ntegration with Atlassian Suite: Seamlessly integrateswith other Atlassian products like Jira and
Bitbucket, providing a cohesive development environment.
2. Deployment Projects: Offers robust deployment projectsthat allow for complex release
management.
3. Customizable Agents: Allows customization of buildagents to fit specific needs.
4. Flexibility: Highly flexible in terms of configurationsand scripting languages.
Cons:
.
1 ser Interface: The UI can be less intuitive comparedto other modern CI/CD tools.
U
2. Performance: Some users report performance issues,particularly with larger builds.
3. Cost: Requires a license, which can be costly, particularlyfor small teams or startups.
4. Resource Intensive: Self-hosted solution can requiresignificant resources and maintenance.
GitHub Actions
Pros:
1. I ntegration with GitHub: Provides seamless integrationwith GitHub repositories, making it easy
to set up and manage CI/CD pipelines directly within the platform.
2. Flexibility and Customization: Highly flexible witha wide range of pre-built actions and the
ability to create custom actions.
3. Community and Marketplace: Large community and extensivemarketplace with reusable
workflows and actions.
4. Cost: Offers a generous free tier, particularly beneficialfor open-source projects.
5. Ease of Use: Simple to get started with GitHub’s YAML-basedworkflows.
Cons:
123
End to End API Testing, Curated by Lamhot Siagian
1. C omplex Workflows: Managing complex workflows can become challenging, especially with
extensive YAML configurations.
2. Limited to GitHub: Primarily designed for GitHub repositories,so it might not be the best fit for
teams using other VCS platforms.
3. Performance: Some users report slow performance onthe free tier, particularly for
resource-intensive tasks.
4. Support: Support can be limited, with users relyingheavily on community resources for
troubleshooting.
● C ollaboration: VCS like Git enables multiple developersto work on the same codebase
simultaneously, facilitating team collaboration and reducing conflicts.
● History and Tracking: It maintains a complete historyof all changes, allowing developers to track
modifications, identify contributors, and understand the context of changes.
● Branching and Merging: VCS supports branching, enablingdevelopers to work on features or fixes
in isolation and merge them back into the main codebase when ready.
● Backup and Recovery: VCS acts as a backup system,allowing the recovery of previous versions of
the codebase in case of errors or issues.
● Integration with CI Tools: CI tools use VCS to triggerautomated builds and tests whenever
changes are committed, ensuring continuous integration and delivery.
● Example with GitHub:
○ Create a new repository on GitHub.
○ Push your local repository to GitHub using the remote URL provided.
Ensure your Maven project is configured for BDD. This typically involves adding dependencies for
pom.xmlfile.
Cucumber and JUnit in your
<
p
roject
xmlns
="http://maven.apache.org/POM/4.0.0"
xmlns:
xsi
="http://www.w3.org/2001/XMLSchema-instance"
xsi
:schemaLocation
="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/maven-v4_0_0.xsd"
>
<
m
odelVersion
>4.0.0</
modelVersion
>
<
g
roupId
>com.example</
groupId
>
<
a
rtifactId
>bdd-api-automation</
artifactId
>
<
v
ersion
>1.0-SNAPSHOT</
version
>
<
d
ependencies
>
<!-- TestNG Dependency -->
124
End to End APIs and API Testing, Curated by Lamhot Siagian
<
d
ependency
>
<
g
roupId
>org.testng</
groupId
>
<
a
rtifactId
>testng</
artifactId
>
<
v
ersion
>7.4.0</
version
>
<
s
cope
>test</
scope
>
</
dependency
>
<!-- Rest Assured Dependency -->
<
d
ependency
>
<
g
roupId
>io.rest-assured</
groupId
>
<
a
rtifactId
>rest-assured</
artifactId
>
<
v
ersion
>4.3.3</
version
>
</
dependency
>
<!-- Cucumber Dependencies -->
<
d
ependency
>
<
g
roupId
>io.cucumber</
groupId
>
<
a
rtifactId
>cucumber-java</
artifactId
>
<
v
ersion
>6.10.4</
version
>
</
dependency
>
<
d
ependency
>
<
g
roupId
>io.cucumber</
groupId
>
<
a
rtifactId
>cucumber-testng</
artifactId
>
<
v
ersion
>6.10.4</
version
>
</
dependency
>
<!-- JSON Schema Validator Dependency -->
<
d
ependency
>
<
g
roupId
>io.rest-assured</
groupId
>
<
a
rtifactId
>json-schema-validator</
artifactId
>
<
v
ersion
>4.3.3</
version
>
</
dependency
>
<
d
ependency
>
<
g
roupId
>org.testng</
groupId
>
<
a
rtifactId
>testng</
artifactId
>
<
v
ersion
>7.4.0</
version
>
<
s
cope
>compile</
scope
>
</
dependency
>
<!-- JUnit for running tests -->
<
d
ependency
>
<
g
roupId
>junit</
groupId
>
<
a
rtifactId
>junit</
artifactId
>
<
v
ersion
>4.13.2</
version
>
<
s
cope
>test</
scope
>
</
dependency
>
<!-- Logging -->
<
d
ependency
>
<
g
roupId
>org.slf4j</
groupId
>
<
a
rtifactId
>slf4j-api</
artifactId
>
<
v
ersion
>1.7.30</
version
>
</
dependency
>
<
d
ependency
>
<
g
roupId
>org.slf4j</
groupId
>
<
a
rtifactId
>slf4j-simple</
artifactId
>
<
v
ersion
>1.7.30</
version
>
</
dependency
>
<
d
ependency
>
<
g
roupId
>junit</
groupId
>
<
a
rtifactId
>junit</
artifactId
>
<
v
ersion
>4.13.1</
version
>
125
End to End API Testing, Curated by Lamhot Siagian
<
s
cope>compile</
scope
>
/
< dependency
>
</
dependencies
>
<
p
roperties
>
<
m
aven.compiler.source >17</
maven.compiler.source
>
<
m
aven.compiler.target >17</
maven.compiler.target
>
</
properties
>
<
b
uild
>
<
p
lugins
>
<
p
lugin>
<
groupId
>org.apache.maven.plugins</
groupId
>
<
artifactId
>maven-surefire-plugin</
artifactId
>
<
version
>3.0.0-M5</
version
>
<
configuration
>
<
includes
>
<
include
>**/runners/RunCucumberTest.java</
include
>
</
includes
>
</
configuration
>
</
plugin
>
</
plugins
>
</
build
>
</
project
>
Scenario
: Get user details
Given
I set the API endpoint to "/user"
When
I send a GET request
Then
I should receive a 200 status code
And
the response should contain user details
package
steps
;
mport
i io.cucumber.java.en.
Given
;
import
io.cucumber.java.en.
Then
;
import
io.cucumber.java.en.
When
;
import static
org.hamcrest.MatcherAssert.
assertThat
;
import static
org.hamcrest.Matchers
.
e
qualTo
;
126
End to End APIs and API Testing, Curated by Lamhot Siagian
mport
i io.restassured.RestAssured
;
import
io.restassured.response.Response
;
public class
APISteps
{
private
Response
response
;
Given
@ (
"
I set the API endpoint to {string}"
)
public void
i_set_the_API_endpoint_to(String endpoint)
{
RestAssured.baseURI =
"https://api.example.com"
+ endpoint;
}
When(
@ "I send a GET request"
)
public void
i_send_a_GET_request() {
response = RestAssured.get();
}
Then(
@ "I should receive a {int} status code"
)
public void
i_should_receive_a_status_code(
int
statusCode) {
assertThat(response.getStatusCode(), equalTo(statusCode));
}
Then(
@ "the response should contain user details"
)
public void
the_response_should_contain_user_details()
{
// Add assertions to verify the response body
}
}
mport
i org.junit.runner.
RunWith
;
import
io.cucumber.
junit.Cucumber;
import
io.cucumber.
junit.CucumberOptions;
RunWith
@ (Cucumber.
class
)
@CucumberOptions(features =
"src/test/resources/features"
,
glue =
"steps"
)
public class
RunCucumberTest
{
}
127
End to End API Testing, Curated by Lamhot Siagian
name
: CI/CD Pipeline
n
o :
push
:
branches
:
- master
pull_request
:
branches
:
- master
obs
j :
build
:
runs-on
: ubuntu-latest
steps
:
-
name
: Checkout code
uses
: actions/checkout@v2
-
name
: Set up JDK 17
uses
: actions/setup-java@v2
with
:
distribution
:
'temurin'
java-version
:
'17'
-
name
: Cache Maven packages
uses
: actions/cache@v2
with
:
path
: ~/.m2/repository
key
: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml')
}}
restore-keys
: ${{ runner.os }}-maven
-
name: Build with Maven
run
: mvn clean install --no-transfer-progress
-
name: Run tests
run
: mvn test --no-transfer-progress
-
name
: Archive test results
if
: always()
uses
: actions/upload-artifact@v2
with
:
name
: test-results
path
: target/surefire-reports/*.xml
deploy
:
needs
: build
runs-on
: ubuntu-latest
if
: github.ref == 'refs/heads/master'
128
End to End APIs and API Testing, Curated by Lamhot Siagian
steps
:
-
name
: Checkout code
uses
: actions/checkout@v2
-
name
: Set up JDK 17
uses
: actions/setup-java@v2
with
:
distribution
:
'temurin'
java-version
:
'17'
-
name: Deploy to production
run
: echo "Deploying to production..."
# Add your deployment steps here
- name
: Run tests
run
: mvn test --no-transfer-progress
- name
: Archive test results
if
: always()
uses
: actions/upload-artifact@v2
with
:
name
: test-results
path
: target/surefire-reports/*.xml
129
End to End API Testing, Curated by Lamhot Siagian
After making changes, you can push your changes to Git Hub.
https://github.com/Lamhot/api-bdd-testing/pull/1
130
End to End APIs and API Testing, Curated by Lamhot Siagian
nswer:
A
CI/CD stands for Continuous Integration andContinuousDeployment(orContinuousDelivery).CIisa
developmentpracticewheredevelopersintegratecodeintoasharedrepositoryfrequently.Eachintegration
is verified by an automated build and automated tests. CD is the next step, where code changes are
automatically built, tested, and deployed to production.
nswer:
A
CI/CD helps ensure code quality, reduce bugs,andimprovesoftwaredeliveryspeed.Byautomatingthe
build, test, and deployment processes, teams can catch issues earlyanddeliverupdatesmorefrequently
and reliably.
nswer:
A
Common tools include Jenkins, Travis CI, CircleCI, GitLab CI, Bamboo, and Azure DevOps for CI/CD,
along with Docker and Kubernetes for containerization and orchestration.
nswer:
A
Containerization involves packaging an application and its dependencies into a container that can run
consistently across different environments. Tools like Docker are used in CI/CD pipelines to ensure
consistent deployment and simplify scaling and orchestration.
nswer:
A
Success can be measured by metrics such as build frequency, build success rate, deployment frequency,
mean time to recovery (MTTR), and lead time for changes. Monitoring these metrics helps identify
bottlenecks and improve the pipeline.
nswer:
A
Challenges include integrating various tools, managing complex dependencies, handling environment
differences, ensuring testcoverageandreliability,anddealingwithculturalandorganizationalresistance
to change.
131
End to End API Testing, Curated by Lamhot Siagian
nswer:
A
Ensure quality by implementing comprehensive automated testing, including unit, integration, and
acceptance tests. Incorporate static code analysis, code reviews, and continuous monitoring. Regularly
review and improve pipeline configurations and processes.
8. How would you integrate API tests into a CI/CD pipeline?
nswer:
A
APItestscanbeintegratedintoaCI/CDpipelineusingtoolslikeJenkinsorGitLabCIbydefiningstepsin
the pipeline configuration file torunthetestsautomaticallyafterthebuildphase.Thiscanincludeusing
testing frameworks like Postman, Newman, or RestAssured.
nswer:
A
A build pipeline automates the process of building, testing, and deploying code. It ensures that code
changesareconsistentlyintegrated,tested,anddelivered,helpingtocatchissuesearlyandstreamlinethe
development process.
nswer:
A
Common stages include:
● ource: Code is committed and pushed to a versioncontrol system.
S
● Build: Code is compiled and built.
● Test: Automated tests are run.
● Deploy: Code is deployed to staging/production environments.
● Monitor: The deployed application is monitored forissues.
nswer:
A
EnsureAPIsecuritybyincorporatingsecuritytestingintotheCI/CDpipeline.Thiscanincludeusingtools
forvulnerabilityscanning,staticcodeanalysis,andrunningsecurityteststoidentifyandfixsecurityissues
early in the development process.
nswer:
A
Continuous testing involves running automated tests throughout the software development lifecycle. It
aims to provide rapid feedback on thequalityofthecode,ensuringthatnewcodechangesdonotbreak
existing functionality.
13. What is the difference between unit testing and integration testing in the context of APIs?
132
End to End APIs and API Testing, Curated by Lamhot Siagian
nswer:
A
Unit testing focuses on testing individual components or functions in isolation. Integration testing
examines how different components or services work together, ensuring they interact correctly and
produce the expected outcomes.
nswer:
A
Aversioncontrolsystem(VCS)likeGitallowsmultipledeveloperstoworkoncodesimultaneouslywhile
keeping track of changes. It is integral to CI/CDasittriggerspipelineactions(likebuildandtest)upon
code commits or pull requests.
nswer:
A
A rollback is the process of reverting to a previous stable version of the application in case the current
deployment causes issues. Automated rollback strategies can be part of a CI/CD pipeline to ensure
minimal downtime and quick recovery.
nswer:
A
Environment-specific configurations can be managed usingenvironmentvariables,configurationfiles,or
secret management tools like VaultorAWSSecretsManager.CI/CDtoolsallowforconfiguringdifferent
settings for different environments (development, staging, production).
133
End to End API Testing, Curated by Lamhot Siagian
Chapter 10
est Driven Development (TDD) is a software development methodology where tests are written before the
T
code that needs to be tested. It follows a repetitive cycle of writing a test, writing the minimum amount of
code to pass the test, and then refactoring the code. This process ensures that the codebase remains clean,
maintainable, and well-tested.
Principles of TDD
1. R ed: Write a test that defines a function or improvementsof a function, which fails initially because
the function doesn’t exist.
2. Green: Write the minimal code necessary to pass thetest.
3. Refactor: Clean up the code while ensuring that alltests still pass. Refactoring is crucial to maintain
code quality and readability.
Benefits of TDD
● I mproved Code Quality: Writing tests first ensuresthat the code meets the requirements and
handles edge cases effectively.
● Less Debugging: Since tests are written upfront, it’seasier to identify and fix issues early in the
development process.
● Documentation: Tests serve as a form of documentation,providing clear examples of how the code
is supposed to work.
● Design Improvement: TDD encourages better design decisionsas it requires developers to think
about the code’s behavior before implementation.
134
End to End APIs and API Testing, Curated by Lamhot Siagian
○ R un the test to see it fail. This step ensures that the test is valid and the functionality is not
yet implemented.
2. Green Phase:
○ Write the simplest code possible to make the test pass.
○ Run the tests to ensure the new code passes the test.
. Refactor Phase:
3
○ Refactor the code to improve its structure and readability.
○ Ensure that all tests still pass after refactoring.
Introduction to Microservice
Before you start, ensure you have the following tools installed:
.
1 o tostart.spring.io
G
2. SelectProject: Maven Project (or Gradle)
3. SelectLanguage: Java
4. SelectSpring Bootversion (e.g., 2.7.1)
5. ProvideProject Metadata: Group, Artifact, Name, Description,Package name, Packaging
(Jar/War), Java Version
6. Select dependencies, such as:
○ Spring Webfor RESTful web services
○ Spring Boot Actuatorfor monitoring and management
○ Spring Data JPAfor database interaction (optional)
. ClickGenerateto download a ZIP file containing yournew project.
7
135
End to End API Testing, Curated by Lamhot Siagian
a.CreateanewSpringBootprojectusingSpringInitializroryourpreferredmethod.Includethefollowing
ependencies:
d
● pring Web
S
● Spring Data JPA
● H2 Database
● Spring Boot DevTools (optional for hot reloading)
● Spring Boot Test
● Cucumber
?
< xml version
="1.0"
encoding="UTF-8"
?>
<
p
roject
xmlns
="http://maven.apache.org/POM/4.0.0"
xmlns:
xsi
="http://www.w3.org/2001/XMLSchema-instance"
xsi
:schemaLocation
="http://maven.apache.org/POM/4.0.0
https://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<
m
odelVersion>4.0.0</
modelVersion
>
<
p
arent
>
<
g
roupId
>org.springframework.boot</
groupId
>
<
a
rtifactId>spring-boot-starter-parent</
artifactId
>
<
v
ersion
>3.3.1</
version
>
<
r
elativePath/>
<!-- lookup parent from repository -->
</
parent
>
<
g
roupId
>com.example</
groupId
>
<
a
rtifactId
>spring.bdd.api</
artifactId
>
<
v
ersion
>0.0.1-SNAPSHOT</
version
>
<
n
ame
>spring.bdd.api</
name
>
<
d
escription
>Demo project for Spring Boot with BDD</
description
>
<
u
rl
/>
<
l
icenses
>
<
l
icense
/>
</
licenses
>
<
d
evelopers
>
<
d
eveloper/>
</
developers
>
<
s
cm
>
<
c
onnection/>
<
d
eveloperConnection />
<
t
ag
/>
<
u
rl
/>
</
scm
>
<
p
roperties
>
<
j
ava.version>17</
java.version
>
</
properties
>
<
d
ependencies>
<
d
ependency>
<
g
roupId>org.springframework.boot</
groupId
>
136
End to End APIs and API Testing, Curated by Lamhot Siagian
<
a
rtifactId
>spring-boot-starter-data-jpa</
artifactId
>
</
dependency
>
<
d
ependency
>
<
g
roupId
>org.springframework.boot</
groupId
>
<
a
rtifactId>spring-boot-starter-web</
artifactId
>
</
dependency
>
<
d
ependency>
<
g
roupId>com.h2database</
groupId
>
<
a
rtifactId >h2</
artifactId
>
<
s
cope
>runtime</
scope
>
</
dependency
>
</
dependencies
>
<
b
uild
>
<
p
lugins
>
<
p
lugin>
<
g
roupId >org.springframework.boot</
groupId
>
<
a
rtifactId >spring-boot-maven-plugin</
artifactId
>
</
plugin
>
</
plugins
>
</
build
>
</
project
>
Userentity class:
Create a
package
com.example.spring.bdd.api.entity
;
import
jakarta.persistence.
*;
Entity
@
@Table
(name =
"users"
)
public class
User
{
Id
@
@GeneratedValue
(strategy =
GenerationType
.
IDENTITY
)
private
Long
id
;
private
String
name
;
private
String
email
;
private
String
password
;
public
Long
getId
() {
return
id
;
}
public void
setId
(
Long
id) {
this
.
i
d
= id;
}
137
End to End API Testing, Curated by Lamhot Siagian
public
String
getName
() {
return
name
;
}
public void
setName
(
S
tring
name) {
this
.
n
ame
= name;
}
public
String
getEmail
() {
return
email
;
}
public void
setEmail
(
String
email) {
this
.
e
mail
= email;
}
public
String
getPassword
() {
return
password
;
}
public void
setPassword
(
String
password) {
this
.
p
assword
= password;
}
}
package
com.example.spring.bdd.api.repository
;
mport
i com.example.spring.bdd.api.entity.User
;
import
org.springframework.data.jpa.repository.JpaRepository
;
import
org.springframework.stereotype.
Repository
;
Repository
@
public interface
UserRepository
extends
JpaRepository
<
User
,
Long
> {
}
package
com.example.spring.bdd.api.service
;
mport
i com.example.spring.bdd.api.entity.User
;
import
com.example.spring.bdd.api.repository.UserRepository
;
import
org.springframework.beans.factory.annotation.
Autowired
;
import
org.springframework.stereotype.
Service
;
138
End to End APIs and API Testing, Curated by Lamhot Siagian
mport
i java.util.List
;
import
java.util.Optional
;
Service
@
public class
UserService
{
Autowired
@
private
UserRepository
userRepository
;
public
User
createUser
(
U
ser
user) {
return
userRepository.save(user);
}
public
List
<
User
>
getAllUsers
() {
return
userRepository
.findAll();
}
public
Optional
<
User
>
getUserById
(
Long
id) {
return
userRepository
.findById(id);
}
public
User
updateUser
(
L
ong
id,
User
userDetails)
{
User user
=
userRepository.findById(id).orElseThrow(()
->
new
RuntimeException(
"User not found"
));
user
.setName(userDetails.getName());
user
.setEmail(userDetails.getEmail());
user
.setPassword(userDetails.getPassword());
return
userRepository.save(
user
);
}
public void
deleteUser
(
L
ong
id) {
userRepository
.deleteById(id);
}
}
package
com.example.spring.bdd.api.controller
;
mport
i com.example.spring.bdd.api.entity.User
;
import
com.example.spring.bdd.api.service.UserService;
import
org.springframework.beans.factory.annotation.
Autowired
;
import
org.springframework.http.ResponseEntity;
import
org.springframework.web.bind.annotation.*;
mport
i java.util.List
;
import
java.util.Optional
;
RestController
@
@RequestMapping
(
"/api/users"
)
public class
UserController
{
139
End to End API Testing, Curated by Lamhot Siagian
Autowired
@
private
UserService
userService
;
PostMapping
@
public
User
createUser
(
@
RequestBody
User
user)
{
return
userService
.createUser(user);
}
GetMapping
@
public
List
<
User
>
getAllUsers
() {
return
userService
.getAllUsers();
}
GetMapping
@ (
"/{id}"
)
public
ResponseEntity <
User
>
getUserById(
@PathVariable
Long
id) {
Optional
<
User
>
user=
userService.getUserById(id);
return
user.map(
ResponseEntity
::
ok
).orElseGet(()
->
ResponseEntity
.
notFound
().build());
}
PutMapping
@ (
"/{id}"
)
public
ResponseEntity <
User
>
updateUser(
@
PathVariable
Longid,
@RequestBody
User
userDetails) {
try
{
User updatedUser
=
userService.updateUser(id,
userDetails);
return
ResponseEntity.
ok
(
updatedUser
);
}
catch
(RuntimeException
e) {
return
ResponseEntity.
notFound
().build();
}
}
DeleteMapping
@ (
"
/{id}"
)
public
ResponseEntity<
Void
>
deleteUser(
@PathVariable
Long
id) {
try
{
userService
.deleteUser(id);
return
ResponseEntity
.
noContent
().build();
}
catch
(
RuntimeException
e) {
return
ResponseEntity
.
notFound
().build();
}
}
}
application.properties
Add H2 configuration in :
pring.application.name
s =
spring.bdd.api
# src/main/resources/application.properties
spring.h2.console.enabled
=
t
rue
# default path: h2-console
spring.h2.console.path
=
/
h2-ui
spring.datasource.url
=
jdbc:h2:file:./testdb
140
End to End APIs and API Testing, Curated by Lamhot Siagian
pring.datasource.driverClassName
s =
org.h2.Driver
spring.datasource.username
=
sa
spring.datasource.password
=
pring.jpa.show-sql
s =
true
spring.jpa.properties.hibernate.dialect
=
org.hibernate.dialect.H2Dialect
spring.jpa.hibernate.ddl-auto
=
update
@SpringBootApplicationannotated class.
he entry point for your Spring Boot application is the
T
Here’s an example:
package
com.example.spring.bdd.api
;
mport
i org.springframework.boot.SpringApplication
;
import
org.springframework.boot.autoconfigure.
SpringBootApplication
;
SpringBootApplication
@
public class
Application
{
}
141
End to End API Testing, Curated by Lamhot Siagian
8. Run your app and make sure the app is running.
curl --location
'http://localhost:8080/api/users'
\
--header
'Content-Type: application/json'
\
--data-raw
'{
"id"
:
1
,
"name"
:
"John Doe"
,
"email"
:
"john.doe@example.com"
,
"password"
:
"password123"
}
'
142
End to End APIs and API Testing, Curated by Lamhot Siagian
143
End to End API Testing, Curated by Lamhot Siagian
You can use a testing framework like Cucumber along with Spring Boot Test to write BDD tests.
<
d
ependency
>
<
g
roupId
>io.cucumber</
groupId
>
<
a
rtifactId>cucumber-java</
artifactId
>
<
v
ersion
>7.0.0</
version
>
<
s
cope
>test</
scope
>
</
dependency
>
<
d
ependency
>
<
g
roupId
>io.cucumber</
groupId
>
<
a
rtifactId>cucumber-spring</
artifactId
>
<
v
ersion
>7.0.0</
version
>
<
s
cope
>test</
scope
>
</
dependency
>
<
d
ependency
>
<
g
roupId
>io.cucumber</
groupId
>
<
a
rtifactId>cucumber-junit</
artifactId
>
<
v
ersion
>7.0.0</
version
>
<
s
cope
>test</
scope
>
</
dependency
>
src/test/resources/features/user.feature
2. Create a feature file :
Feature
: User Management
Scenario
: Create a new user
Given
I create a user with name "John Doe" and
email "john.doe@example.com"
Then
the user is created successfully
Scenario
: Get all users
When
I get all users
Then
I receive a list of users
Scenario
: Get a user by ID
Given
a user with name "John Doe" and email "john.doe@example.com"
exists
When
I get the user by ID
Then
I receive the user details
Scenario
: Update a user
Given
a user with name "Jane Doe" and email "jane.doe@example.com"
exists
When
I update the user's name to "Jane Smith" and
email to
"jane.smith@example.com"
Then
the user is updated successfully
Scenario
: Delete a user
Given
a user with name "John Doe" and email "john.doe@example.com"
exists
When
I delete the user by ID
Then
the user is deleted successfully
144
End to End APIs and API Testing, Curated by Lamhot Siagian
package
com.example.spring.bdd.api.steps
;
mport
i com.example.spring.bdd.api.Application
;
import
com.example.spring.bdd.api.entity.User
;
import
com.example.spring.bdd.api.repository.UserRepository
;
import
io.cucumber.java.
Before
;
import
io.cucumber.java.en.
Given
;
import
io.cucumber.java.en.
Then
;
import
io.cucumber.java.en.
When
;
import
org.junit.jupiter.api.Assertions
;
import
org.springframework.beans.factory.annotation.
Autowired
;
import
org.springframework.boot.test.context.
SpringBootTest
;
import
org.springframework.boot.test.web.client.TestRestTemplate;
import
org.springframework.http.HttpStatus
;
import
org.springframework.http.ResponseEntity;
import
java.util.List
;
SpringBootTest
@ (classes =
Application.
class
, webEnvironment
=
SpringBootTest
.
WebEnvironment
.
DEFINED_PORT
)
public class
UserSteps
{
Autowired
@
private
TestRestTemplate
restTemplate
;
Autowired
@
private
UserRepository
userRepository
;
rivate
p ResponseEntity
<
U
ser
>
responseEntity
;
private
ResponseEntity
<
U
ser
[]>
responseEntityList
;
private
User
createdUser;
Before
@
public void
setUp
() {
userRepository
.deleteAll();
}
Given
@ (
"
I create a user with name {string} and email {string}")
public void
i_create_a_user_with_name_and_email (
String
name,
String
email) {
User user
=
new
User();
user
.setName(name);
user
.setEmail(email);
responseEntity
=restTemplate
.postForEntity(
"http://localhost:8080/api/users"
,
user
,
User
.
c
lass
);
createdUser
=
responseEntity.getBody();
}
Then
@ (
"
the user is created successfully" )
public void
the_user_is_created_successfully ()
{
Assertions
.
a
ssertNotNull(
createdUser
.getId());
Assertions
.
a
ssertEquals
(
H
ttpStatus
.
CREATED
,
responseEntity
.getStatusCode());
145
End to End API Testing, Curated by Lamhot Siagian
}
When
@ (
"
I get all users"
)
public void
i_get_all_users
() {
responseEntityList
=
restTemplate
.getForEntity(
"http://localhost:8080/api/users"
,
User
[].
class
);
}
Then
@ (
"
I receive a list of users")
public void
i_receive_a_list_of_users() {
Assertions
.
a
ssertTrue
(
responseEntityList
.getBody().
length
>
0
)
;
Assertions
.
a
ssertEquals(
H
ttpStatus
.
OK
,
responseEntityList
.getStatusCode());
}
Given
@ (
"
a user with name {string} and email {string}exists")
public void
a_user_with_name_and_email_exists
(
String
name,
String
email) {
User user
=
new
User();
user
.setName(name);
user
.setEmail(email);
createdUser
=
userRepository
.save(
user
);
}
When
@ (
"
I get the user by ID")
public void
i_get_the_user_by_id () {
responseEntity
=restTemplate.getForEntity(
"http://localhost:8080/api/users/"
+
createdUser
.getId(),
User.
class
);
}
Then
@ (
"
I receive the user details" )
public void
i_receive_the_user_details () {
User user
=
responseEntity .getBody();
Assertions
.
a
ssertNotNull(
user
);
Assertions
.
a
ssertEquals
(
c
reatedUser.getId(),
user
.getId());
Assertions
.
a
ssertEquals
(
c
reatedUser.getName(),
user
.getName());
Assertions
.
a
ssertEquals
(
c
reatedUser.getEmail(),
user.getEmail());
Assertions
.
a
ssertEquals
(
H
ttpStatus.
O
K
,
responseEntity.getStatusCode());
}
When
@ (
"
I update the user's name to {string} and
email to {string}")
public void
i_update_the_user_s_name_to_and_email_to
(
String
newName,
String
newEmail) {
createdUser
.setName(newName);
createdUser
.setEmail(newEmail);
restTemplate
.put(
"http://localhost:8080/api/users/"
+
createdUser
.getId(),
createdUser
);
}
Then
@ (
"
the user is updated successfully")
public void
the_user_is_updated_successfully()
{
User updatedUser
=
userRepository.findById(
createdUser
.getId()).orElse(
null
);
Assertions
.
a
ssertNotNull(
updatedUser
);
Assertions
.
a
ssertEquals
(
c
reatedUser
.getId(),
updatedUser
.getId());
Assertions
.
a
ssertEquals
(
c
reatedUser
.getName(),
updatedUser
.getName());
Assertions
.
a
ssertEquals
(
c
reatedUser
.getEmail(),
updatedUser
.getEmail());
}
@When
(
"
I delete the user by ID"
)
146
End to End APIs and API Testing, Curated by Lamhot Siagian
public void
i_delete_the_user_by_id
() {
restTemplate
.delete(
"http://localhost:8080/api/users/"
+
createdUser
.getId());
}
Then
@ (
"
the user is deleted successfully")
public void
the_user_is_deleted_successfully()
{
boolean
userExists
=
userRepository.existsById(
createdUser
.getId());
Assertions
.
a
ssertFalse
(
userExists
);
}
}
src/test/java/com/example/demo/CucumberTest.java
Create a test runner :
package
com.example.spring.bdd.api.runner
;
mport
i com.example.spring.bdd.api.Application;
import
io.cucumber.junit.Cucumber ;
import
io.cucumber.junit.CucumberOptions
;
import
io.cucumber.spring.CucumberContextConfiguration
;
import
org.junit.runner.
RunWith
;
import
org.springframework.boot.test.context.SpringBootTest
;
import
org.springframework.test.context.ContextConfiguration
;
RunWith
@ (
C
ucumber
.
class
)
@CucumberContextConfiguration
@ContextConfiguration
(classes = {
Application
.
class
})
@CucumberOptions
(features =
"src/test/resources/features"
,
glue =
"com.example.spring.bdd.api.steps"
)
public class
CucumberTest{
}
147
End to End API Testing, Curated by Lamhot Siagian
References
. https://en.wikipedia.org/wiki/List_of_HTTP_status_codes
1
2. https://toolsqa.com/postman/response-in-postman/
3. https://blog.postman.com/what-are-http-methods/
4. https://testfully.io/blog/http-methods/
5. https://en.wikipedia.org/wiki/HTTP
6. https://katalon.com/resources-center/blog/test-case-template-examples
7. https://www.guru99.com/testing-rest-api-manually.html
8. https://www.softwaretestinghelp.com/rest-api-testing-with-bdd-cucumber/
9. https://nonamesecurity.com/learn/what-is-api-security-testing/
10. https://nonamesecurity.com/wp-content/uploads/2023/06/Product-Brief_SecurityTesting.pdf
11. https://nordicapis.com/how-to-implement-input-validation-for-apis/
12. https://apidog.com/blog/rate-limiting-vs-throttling/
13. https://www.testingxperts.com/blog/api-security-testing#What%20is%20API%20Security%20Test
ing
148