blob: f411c9c74f363b6186c9abbf8f397932b327c31b [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2002-2005 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM - Initial API and implementation
*******************************************************************************/
package org.eclipse.wst.wsi.internal.core.profile.validator.impl.envelope;
import java.util.List;
import javax.wsdl.BindingOperation;
import javax.wsdl.extensions.mime.MIMEMultipartRelated;
import org.eclipse.wst.wsi.internal.core.WSIException;
import org.eclipse.wst.wsi.internal.core.WSITag;
import org.eclipse.wst.wsi.internal.core.analyzer.AssertionNotApplicableException;
import org.eclipse.wst.wsi.internal.core.profile.TestAssertion;
import org.eclipse.wst.wsi.internal.core.profile.validator.EntryContext;
import org.eclipse.wst.wsi.internal.core.profile.validator.MessageValidator;
import org.eclipse.wst.wsi.internal.core.profile.validator.impl.AssertionProcess;
import org.eclipse.wst.wsi.internal.core.profile.validator.impl.BaseMessageValidator;
import org.eclipse.wst.wsi.internal.core.report.AssertionResult;
import org.eclipse.wst.wsi.internal.core.util.EntryType;
/**
* AP1920
*
* <context>For an envelope in a response message
* containing a soap:Fault element</context>
* <assertionDescription>In a description, if and only if, the wsdl:output
* element is described using WSDL MIME binding, then the envelope in the
* response message can contain faults with attachments.</assertionDescription>
*/
public class AP1920 extends AssertionProcess
{
private final BaseMessageValidator validator;
/**
* @param WSDLValidatorImpl
*/
public AP1920(BaseMessageValidator impl)
{
super(impl);
this.validator = impl;
}
/* Validates the test assertion.
* @see org.wsi.test.profile.validator.impl.BaseValidatorImpl.AssertionProcess#validate(org.wsi.test.profile.TestAssertion, org.wsi.test.profile.validator.EntryContext)
*/
public AssertionResult validate(
TestAssertion testAssertion,
EntryContext entryContext)
throws WSIException
{
try
{
if (!entryContext.getMessageEntry().isMimeContent())
{
throw new AssertionNotApplicableException();
}
// check for a fault element within the message
if((entryContext.getMessageEntryDocument() == null) ||
entryContext.getMessageEntryDocument().
getElementsByTagNameNS(WSITag.ELEM_SOAP_FAULT.getNamespaceURI(),
WSITag.ELEM_SOAP_FAULT.getLocalPart()).getLength() != 1)
throw new AssertionNotApplicableException();
BindingOperation bindingOperation = validator.getOperationMatch(
EntryType.getEntryType(MessageValidator.TYPE_MESSAGE_REQUEST),
entryContext.getRequestDocument());
// If there is no matched operation, the assertion is not applicable
if (bindingOperation == null)
throw new AssertionNotApplicableException();
// If the envelope in a response message contains a fault with attachments
// and the corresponding wsdl:output element in the description is not
// described using the WSDL MIME binding, the assertion is failed
if ((entryContext.getMessageEntry().getMimeParts().count() > 1) &&
(getMultipartRelatedBindings(bindingOperation) == null))
{
result = AssertionResult.RESULT_FAILED;
failureDetail =
validator.createFailureDetail("The message contains \"" +
entryContext.getMessageEntry().getMimeParts().count() + "\" part(s)",
entryContext);
}
}
catch(AssertionNotApplicableException e)
{
result = AssertionResult.RESULT_NOT_APPLICABLE;
}
// Return assertion result
return validator.createAssertionResult(
testAssertion, result, failureDetail);
}
/**
* Returns Multipart related bindings, if does not found, returns null.
* @param op binding operation
* @return Multipart related bindings, if does not found, returns null.
*/
private MIMEMultipartRelated getMultipartRelatedBindings(
BindingOperation op)
{
// Finding operation extensibility elems
// in the binding depending on message type
List extElems = op.getBindingOutput().getExtensibilityElements();
// check list on first element
if((extElems == null) || (extElems.size() == 0) ||
!(extElems.get(0) instanceof MIMEMultipartRelated))
return null;
return (MIMEMultipartRelated) extElems.get(0);
}
}