Azure Management API by default provides a testing tool with pretty good tracing option. Following picture shows how default trace looks like in action. First open the API Management in Azure Portal and navigate to your API (in my case Echo API). On the top right, you will find Test button.
data:image/s3,"s3://crabby-images/ea359/ea35923ddb3d821f2db0fc92b50f64d2b2acdb76" alt="image image"
After you click on send button, operation will be executed including or specified policies. As next click on “Trace” to see trace output.
data:image/s3,"s3://crabby-images/7f60b/7f60b9c41e2efd0e6c1afe47c11946d003dbc1fd" alt="image image"
An example of the trace is shown below:
data:image/s3,"s3://crabby-images/c7bac/c7bac0afbd92cd6eb397eede7743caf0cf92227d" alt="image image"
This trace is very powerful, but sometimes, you might want to have more custom information. To do this you can use a trace-policy.
Select some operation or click all operations and open policy editor as code:
data:image/s3,"s3://crabby-images/60dd4/60dd49dd5b05cdf30a52e669ba0ec95e88c500fe" alt="image image"
data:image/s3,"s3://crabby-images/29e4d/29e4d36635bb2d3bad5ae926bace49f1de84b6e5" alt="image image"
Here is what you will see, if no policies are defined in policy editor:
data:image/s3,"s3://crabby-images/75aa5/75aa5948d80dfe8d9e136c61e1d580fed4e315fb" alt="image image"
Then in the list of policies add new inbound policy:
<trace source="Anything"> @(context.Request.Body?.As<string>(true) ?? "No Body") </trace> |
As source, you can specify any string, which will appear in the trace output.
data:image/s3,"s3://crabby-images/55efa/55efaaa2a84148abee166f4c8a492f37226231e7" alt="image image"
If you add trace policy to outbound policies, you can grab out response body as shown in following snippet:
<trace source="ResponseBody"> @(context.Response.Body?.As<string>(true) ?? "No body") </trace> |
Posted
Jan 12 2017, 05:43 AM
by
Damir Dobric