/* * Copyright 2005-2012 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.springframework.ws.test.client; import java.io.IOException; import java.net.URI; import java.util.Map; import javax.xml.namespace.QName; import javax.xml.transform.Source; import org.springframework.core.io.Resource; import org.springframework.util.Assert; import org.springframework.ws.WebServiceMessage; import org.springframework.ws.test.support.matcher.PayloadDiffMatcher; import org.springframework.ws.test.support.matcher.SchemaValidatingMatcher; import org.springframework.ws.test.support.matcher.SoapEnvelopeDiffMatcher; import org.springframework.ws.test.support.matcher.SoapHeaderMatcher; import org.springframework.xml.transform.ResourceSource; /** * Factory methods for {@link RequestMatcher} classes. Typically used to provide input for {@link * MockWebServiceServer#expect(RequestMatcher)}. * * @author Arjen Poutsma * @since 2.0 */ public abstract class RequestMatchers { private RequestMatchers() { } /** * Expects any request. * * @return the request matcher */ public static RequestMatcher anything() { return new RequestMatcher() { public void match(URI uri, WebServiceMessage request) throws IOException, AssertionError { } }; } // Payload /** * Expects the given {@link javax.xml.transform.Source} XML payload. * * @param payload the XML payload * @return the request matcher */ public static RequestMatcher payload(Source payload) { Assert.notNull(payload, "'payload' must not be null"); return new WebServiceMessageMatcherAdapter(new PayloadDiffMatcher(payload)); } /** * Expects the given {@link org.springframework.core.io.Resource} XML payload. * * @param payload the XML payload * @return the request matcher */ public static RequestMatcher payload(Resource payload) throws IOException { Assert.notNull(payload, "'payload' must not be null"); return payload(new ResourceSource(payload)); } /** * Expects the payload to validate against the given XSD schema(s). * * @param schema the schema * @param furtherSchemas further schemas, if necessary * @return the request matcher */ public static RequestMatcher validPayload(Resource schema, Resource... furtherSchemas) throws IOException { return new WebServiceMessageMatcherAdapter(new SchemaValidatingMatcher(schema, furtherSchemas)); } /** * Expects the given XPath expression to (not) exist or be evaluated to a value. * * @param xpathExpression the XPath expression * @return the XPath expectations, to be further configured */ public static RequestXPathExpectations xpath(String xpathExpression) { return new XPathExpectationsHelperAdapter(xpathExpression, null); } /** * Expects the given XPath expression to (not) exist or be evaluated to a value. * * @param xpathExpression the XPath expression * @param namespaceMapping the namespaces * @return the XPath expectations, to be further configured */ public static RequestXPathExpectations xpath(String xpathExpression, Map<String, String> namespaceMapping) { return new XPathExpectationsHelperAdapter(xpathExpression, namespaceMapping); } // SOAP /** * Expects the given {@link javax.xml.transform.Source} XML SOAP envelope. * * @param soapEnvelope the XML SOAP envelope * @return the request matcher * @since 2.1.1 */ public static RequestMatcher soapEnvelope(Source soapEnvelope) { Assert.notNull(soapEnvelope, "'soapEnvelope' must not be null"); return new WebServiceMessageMatcherAdapter(new SoapEnvelopeDiffMatcher(soapEnvelope)); } /** * Expects the given {@link org.springframework.core.io.Resource} XML SOAP envelope. * * @param soapEnvelope the XML SOAP envelope * @return the request matcher * @since 2.1.1 */ public static RequestMatcher soapEnvelope(Resource soapEnvelope) throws IOException { Assert.notNull(soapEnvelope, "'soapEnvelope' must not be null"); return soapEnvelope(new ResourceSource(soapEnvelope)); } /** * Expects the given SOAP header in the outgoing message. * * @param soapHeaderName the qualified name of the SOAP header to expect * @return the request matcher */ public static RequestMatcher soapHeader(QName soapHeaderName) { Assert.notNull(soapHeaderName, "'soapHeaderName' must not be null"); return new WebServiceMessageMatcherAdapter(new SoapHeaderMatcher(soapHeaderName)); } // Other /** * Expects a connection to the given URI. * * @param uri the String uri expected to connect to * @return the request matcher */ public static RequestMatcher connectionTo(String uri) { Assert.notNull(uri, "'uri' must not be null"); return connectionTo(URI.create(uri)); } /** * Expects a connection to the given URI. * * @param uri the String uri expected to connect to * @return the request matcher */ public static RequestMatcher connectionTo(URI uri) { Assert.notNull(uri, "'uri' must not be null"); return new UriMatcher(uri); } }