Welcome to the new Parasoft forums! We hope you will enjoy the site and try out some of the new features, like sharing an idea you may have for one of our products or following a category.

.NET WCF SOAP Client FAQ

LegacyForum
LegacyForum Posts: 1,664 ✭✭
edited December 2016 in SOAtest
Windows Communication Foundation FAQ
Common questions:

1.) What is a binding?

In WCF, a binding describes the transport, security, and message encoding for a web service's endpoint. The SOAP Client needs to know the endpoint's binding in order to communicate with the endpoint. The SOAP Client can determine the endpoint's binding automatically from a WSDL document or from a .NET WCF client configuration file.


2.) How do I create a .NET WCF client configuration file?
The Microsoft Service Model Metadata Tool (svcutil.exe) can generate a client configuration file given the URL of the service's WSDL document. The Microsoft Service Configuration Editor can be used to create and edit WCF configuration files using a graphical user interface. Both of these tools are part of the Microsoft Windows SDK which is included with Visual Studio and can also be downloaded from Microsoft. The web service's developer may also be able to provide you with a client configuration file for the web service that you are testing.


3.) Do I have to use a .NET WCF client configuration file?

Not necessarily. If the web service's WSDL document sufficiently describes the web service then the SOAP Client only needs to be constrained to that WSDL without using a client configuration file. However, if the web service uses certificate-based authentication then you must setup a .NET WCF client configuration file that describes the locations of the certificates installed on your local machine. WCF bindings also define various limits including a limit on the maximum received message size. You can control such limits in a .NET Client configuration file. You also need to un-constrain your SOAP Client test from the WSDL document to prevent the binding information in the WSDL from taking precedence over what you have in your configuration file.


4.) How do I configure certificate based authentication?
First, you need to install any client and server certificates using the Windows Certificate Manager. You can open the Windows Certificate Manger by clicking "Start->Run...", enter "certmgr.msc", then click OK. Typically you would install the server's certificate in the Trusted People store and any client certificates in the Personal store. Next, the locations of those certificates must be specified in your client configuration file. The MSDN website has detailed information about how to do this including including configuration file examples.

Working with Certificates: http://msdn.microsoft.com/en-us/library/ms731899.aspx
How to: Specify Client Credential Values: http://msdn.microsoft.com/en-us/library/ms732391.aspx
Transport Security with Certificate Authentication: http://msdn.microsoft.com/en-us/library/ms731074.aspx
Message Security with a Certificate Client: http://msdn.microsoft.com/en-us/library/ms733098.aspx


5.) Can I use a .NET WCF SOAP Client to test older .NET web services?

Only WSE 3.0. .NET WCF clients are wire-level compatible with WSE 3.0 services. The following custom binding can be used to test a WSE 3.0 web service using Secure Conversation and MutualCertificate11:


CODE
<binding name="SecureConversationMutualCertificate11SignEncryptConfig">
<security authenticationMode="SecureConversation" messageProtectionOrder="SignBeforeEncrypt"
requireSecurityContextCancellation="false">
<secureConversationBootstrap authenticationMode="MutualCertificate"
securityHeaderLayout="Strict" messageProtectionOrder="SignBeforeEncrypt"
requireSignatureConfirmation="true" />
</security>
<textMessageEncoding messageVersion="Soap11WSAddressingAugust2004" />
<httpTransport />
</binding>


The MSDN website has more detail:
http://msdn2.microsoft.com/en-us/library/ms730299.aspx


6.) Can I use a .NET WCF SOAP Client to test Glassfish Metro/WSIT based services?

Yes! Metro WSIT services are interoperable with .NET WCF clients including SOAtest's SOAP Client tool. However, there is a known bug in Metro where whitespace and newlines cause the security validation for the request message to fail. This problem can be avoided by chaining an Extension tool to the Request SOAP Envelope output of your SOAP Client test that to remove the extra whitespace:


CODE
from com.parasoft.api import *
from java.lang import *

def removeAllNewLineCharacters(input, context):
noNewLines = str(input).replace("\r", "").replace("\n", "")
result = String(noNewLines).replaceAll(">\s*<", "><")
Application.showMessage(result) # for debugging
return result


More information about the Metro/WSIT issue can be found here:
http://forums.java.net/jive/thread.jspa?messageID=302907
http://forums.java.net/jive/thread.jspa?messageID=328858
http://forums.java.net/jive/thread.jspa?messageID=273113



Common errors:

1.) "Could not find endpoint in client configuration file"

This test failure will happen if your SOAP Client test is using a .NET WCF client configuration file that does not describe the endpoint configured for your test. Verify that the client configuration file describes the same endpoint as the test. Check the capitalization of each character in the endpoint URL (case-sensitive). Also verify that your test is using a valid .NET WCF client configuration file. A service configuration file (web.config) or WSE configuration file will not work.


2.) "Could not find endpoint in WSDL"
This test failure will happen if your SOAP Client test is constrained to a WSDL document that does not describe the endpoint configured for your test. You may need to correct the endpont in your test to match the endpoint in the WSDL document. If the endpoint in the WSDL document is incorrect then the WSDL should be corrected. If you cannot correct the WSDL then you should un-constrain the SOAP Client test from the bad WSDL then configure your test to use a .NET WCF client configuration file that describes the correct endpoint.


3.) "The X.509 certificate CN=localhost chain building failed. The certificate that was used has a trust chain that cannot be verified. Replace the certificate or change the certificateValidationMode."

As the test failure suggests, you likely need to configure the certificateValidationMode property in your client configuration file. Typically you would add the server's certificate to the Trusted People store using the Windows certificate manager then set the certificateValidationMode property in your configuration file to PeerOrChainTrust. The MSDN website has an example:
http://msdn.microsoft.com/en-us/library/ms587504.aspx
http://msdn.microsoft.com/en-us/library/sy...dationmode.aspx

4.) "Identity check failed for outgoing message. The expected DNS identity of the remote endpoint was 'host1' but the remote endpoint provided DNS clam 'host2'. If this is a legitimate remote endpoint, you can fix the problem by explicitly specifying DNS identity 'host2' as the Identity property of EndpointAddress when creating channel proxy.

The endpoint's DNS identity in the WSDL may be incorrect. As the test failure suggests, you likely need to explicitly configure the Identity property in your client configuration file. You will also need to un-constrain your test from the WSDL to prevent the endpoint information in the WSDL from taking precedence over what you have in your configuration file.
Specifying Identity at the Client: http://msdn.microsoft.com/en-us/library/ms733130.aspx


5.) "The maximum message size quota for incoming messages (65536) has been exceeded. To increase the quota, use the MaxReceivedMessageSize property on the appropriate binding element."

As the test failure suggests, you need to configure the MaxReceivedMessageSize property in your client configuration file. You will also need to un-constrain your test from the WSDL to prevent the binding information in the WSDL from taking precedence over what you have in your configuration file. The MSDN website has an example:
http://msdn.microsoft.com/en-us/library/sy...essagesize.aspx


6.) "The maximum read depth (32) has been exceeded because XML data being read has more levels of nesting than is allowed by the quota. This quota may be increased by changing the MaxDepth property on the XmlDictionaryReaderQuotas object used when creating the XML reader."

As the test failure suggests, you need to configured the MaxDepth property in your client configuration file. You will also need to un-constrain your test from the WSDL to prevent the binding information in the WSDL from taking precedence over what you have in your configuration file. The MSDN website has an example:
http://msdn.microsoft.com/en-us/library/sy...aderquotas.aspx


7.) "Out of memory" errors when load testing .NET WCF SOAP Clients.

You may need to reduce the size of the Java heap so that the .NET runtime can allocate more memory for the .NET heap. Refer to this form post for how to configure the Java heap size: http://forums.parasoft.com/index.php?showtopic=437
Tagged:

Comments

  • PBeland
    PBeland Posts: 14

    We had the MaxReceivedMessageSize problem. We fixed it by changing from ".NET WCF HTTP" transport to "HTML 1.1"

  • benken_parasoft
    benken_parasoft Posts: 1,309 ✭✭✭
    edited July 2017

    The ".NET WCF" transport option is required to ensure proper communication with .NET WCF web services, especially ones following complex WS-* standards or Microsoft proprietary (non-WSI) bindings. Even if your web service is deployed over HTTP, ".NET WCF" handles more than just the raw HTTP communication. It also transforms the request to satisfy the required security and encoding requirements, adding required SOAP headers and signatures, for example. The ".NET WCF" transport can also be used to verify interoperatbility with .NET clients, even for web services not using .NET.

    Otherwise, if you don't care about verifying .NET interoperability, or your .NET service is using a trivial WS-I compliant binding (BasicHttpBinding), then using the generic "HTTP 1.1" transport would be fine. The "HTTP 1.1" transport option can be used to make any HTTP request, not specific to SOAP or any vendor-specific web service stack.

Tagged