What tools can be used for troubleshooting REST API's?
The first and best tool to start with is the existing documentation.
Native Resources
Leveraging the existing Semarchy documentation within your API-related project will help create a solid foundation for understanding the available tools, architecture, and implementation patterns. Refer to our official documentation for the most accurate details on using Semarchy REST API's.
1. Semarchy xDM Integration Guide
contains thorough documentation on our REST client, including an Overview
section as well as complete examples.
2.Semarchy xDM Administration Guide
contains extensive details on Managing REST Clients
.
3. Within the application, select REST API
to access in-application resources, the Documentation
section loads by default.
data:image/s3,"s3://crabby-images/f0eb0/f0eb073acebefb36a7d7a3807db28cb907019968" alt="Click on REST API"
4. Click on Getting Started
to see additional menu options.
data:image/s3,"s3://crabby-images/63a3f/63a3f3ecc373f7a9b236791b96b4d15767c2b5db" alt="Getting Started Menu"
Selecting one of the menu options enables the user to download OpenAPI specifications
for the selected object, as well as access fully-functional context-based API examples.
data:image/s3,"s3://crabby-images/0d45b/0d45bd2d28490dbd1904ea45bc2276c6a3557b14" alt="What tools can be used for troubleshooting REST API's?"
5. Use the REST Client Validate
and Test
options
Use the built-in testing solution by selecting Test
from a configured REST Client
.
data:image/s3,"s3://crabby-images/b3bc2/b3bc2f9f85b0997b17ce8319780bbfd9a3d6a00c" alt="What tools can be used for troubleshooting REST API's?"
Match the displayed errorId
to the Semarchy Error Log
.
data:image/s3,"s3://crabby-images/d910d/d910d34fb093f9e1b48fa9ca083190bcb86e522f" alt="Use built-in REST Client Test"
data:image/s3,"s3://crabby-images/cc745/cc745532329047a6fd69dd7a5b80349eda233fd7" alt="Error - No data location with name (XYZ..) exists"
Secondary tools and use-cases
1. Postman
Postman
is a great tool for troubleshooting syntax, connection access, performance, and others. The examples below show validation results for successful, and unsuccessful GET
operations.
data:image/s3,"s3://crabby-images/50ac0/50ac06e374d24d9c7dd611ea25279842940aa8a5" alt="Postman - Get Operation - Query Single Record - Status 200 OK"
On failures, review matching error in Semarchy Error Log
.
data:image/s3,"s3://crabby-images/8fa52/8fa521ada13c9a6ad274bca55b8c8ca19d6ccc79" alt="Postman - Get Operation - Query Single Record - Status 500 Internal Server Error"
data:image/s3,"s3://crabby-images/4083a/4083ad9c25049c90e8595f00521fe4f695fe23f7" alt="Semarchy Error Log"
data:image/s3,"s3://crabby-images/cff91/cff9192404002ecff6f7b0462f7fbbd44e7d7bcf" alt="Semarchy Error Log Details"
In the example below, we use Postman to validate the POST URL
, Body
(payload), Status
, and (return)Body
.
data:image/s3,"s3://crabby-images/ef6e5/ef6e518170e68a78c27c76bfa347645077ce54a2" alt="Postman - Validate URL, Body and Status"
2. Using Jayway JsonPath Evaluator
Jayway
is a simple, web-based path evaluator.
The example below illustrates a scenario in which the Response Output
is configured as surrounded/encapsulated by unnecessary quotation marks.
data:image/s3,"s3://crabby-images/04f60/04f60ec15e5a2d8089a0d03e281086bfeb7a04b5" alt="Improperly-configured Response Output"
Entering the specific values into Jayway, we can see that "Content"
is an invalid path.
data:image/s3,"s3://crabby-images/8c7c1/8c7c1f6417d5f89a52e7a1a68b766dea2d189dee" alt="Jayway - "Content" is an invalid JSON Path"
3. Using JSON Path Finder
JSON Path Finder
is very useful in scenarios where a need exists to identify a valid JSON Path. Using the example above, once the path has been confirmed to be inaccurate, find the correct value using JSON Path Finder. The illustration below shows incorrect JSON being entered on the left, and the correct path highlighted on the right. The correct path is Content
, vs "Content"
.
data:image/s3,"s3://crabby-images/e848b/e848b061a4306f9aea459e55191cefb3b052ae3a" alt="JSON Path Finder - returns correct JSON path"