This article is not about understanding the details of .NET WCF service, soapUI and Fiddler as all these three are quite popular things among .NET developers. And tools like soapUI and Fiddler may already be in the arsenal of many web developers and QA engineers. Those who are new to these two tools should refer to following articles:
However, we will take a look into how Fiddler can be used to Monitor SOAP Request and SOAP Response transmitting behind the soapUI.
Let’s start with a simple WCF service in place. No need to have a WCF .NET Client as of now to test and monitor HTTP traffic of WCF service calls.
- Open soapUI and set the following settings. Make sure the service’s wsdl path is correct.
data:image/s3,"s3://crabby-images/705a6/705a67d948892a731aa693282adb5930acfb49f0" alt="Loading wsdl definition Loading wsdl definition"
- After loading the definition of WSDL, service definitions will appear like shown below:
data:image/s3,"s3://crabby-images/6723d/6723d3e10ea15f384ffeadffc308bd39ddfc6810" alt="Service requests definitions Service requests definitions"
- Double click on Request # node and navigate to the request window on the right.
data:image/s3,"s3://crabby-images/d1078/d1078024fffcb336b466a9890b33eb4021eac9d8" alt="Submitting the request Submitting the request"
- Fill the method parameters denoted by “?”.
- Open Fiddler and make sure it is ready to capture HTTP(S) traffic.
- Submit request to the specified endpoint and SOAP Response can be seen on the right pane.
data:image/s3,"s3://crabby-images/cf919/cf91943d39a957e2ae23384a14b9800ec47bd83e" alt="Service Request-Response in soapUI Service Request-Response in soapUI"
- If you see the Fiddler window, there is no traffic captured. This is really frustrating if you have been testing your services using soapUI when you do not see the underlying details of the SOAP Request and SOAP Response in the wire.
- All you need to do following proxy settings in the soapUI File –> Preferences –> Proxy Settings window.
data:image/s3,"s3://crabby-images/a4099/a409982b1ba6b2ea288a696db14b2b76370254a9" alt="soapUI Proxy Settings soapUI Proxy Settings"
- Re-submit web service request on soapUI.
- Now you see WCF Request-Response traffic in the Fiddler window
. You are now all in your territory to view the details of service request-response headers, body, and many more!
data:image/s3,"s3://crabby-images/cf1e7/cf1e72b8b32282788ef07f294c53627b729a9bb1" alt="SOAP Request-Response view in Fiddler SOAP Request-Response view in Fiddler"
But why did we add Port No. 8888 in the proxy settings of soapUI? It is because Fiddler by default listens on port no. 8888.
data:image/s3,"s3://crabby-images/d6fd2/d6fd264e1ca995338bbd7908f043b3b8f766b6bc" alt="Fiddler default listening port no. Fiddler default listening port no."
If you have configured your Fiddler proxy tool to listen on some other port number, then you should use that one.
I hope you enjoyed this testing tip. No need to reiterate how blissful it is to test web services using soapUI and Fiddler if you are a web service developer/provider to remote clients.
CodeProject
Filed under:
.Net Technologies,
ASP.Net,
CodeProject,
Dot Net Tips,
Dot Net Tools,
WCF Tagged:
Debugging,
Fiddler,
soapUI,
WCF,
Web Service