diff options
Diffstat (limited to 'bundles/org.eclipse.wst.wsi/src/org/eclipse/wst/wsi/internal/core/profile/validator/impl/wsdl/AP2946.java')
-rw-r--r-- | bundles/org.eclipse.wst.wsi/src/org/eclipse/wst/wsi/internal/core/profile/validator/impl/wsdl/AP2946.java | 194 |
1 files changed, 194 insertions, 0 deletions
diff --git a/bundles/org.eclipse.wst.wsi/src/org/eclipse/wst/wsi/internal/core/profile/validator/impl/wsdl/AP2946.java b/bundles/org.eclipse.wst.wsi/src/org/eclipse/wst/wsi/internal/core/profile/validator/impl/wsdl/AP2946.java new file mode 100644 index 000000000..4555739d3 --- /dev/null +++ b/bundles/org.eclipse.wst.wsi/src/org/eclipse/wst/wsi/internal/core/profile/validator/impl/wsdl/AP2946.java @@ -0,0 +1,194 @@ +/******************************************************************************* + * 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.wsdl; + +import java.util.ArrayList; +import java.util.List; + +import javax.wsdl.Binding; +import javax.wsdl.BindingInput; +import javax.wsdl.BindingOperation; +import javax.wsdl.BindingOutput; +import javax.wsdl.extensions.ExtensibilityElement; +import javax.wsdl.extensions.mime.MIMEContent; +import javax.wsdl.extensions.mime.MIMEMultipartRelated; +import javax.wsdl.extensions.mime.MIMEPart; + +import org.eclipse.wst.wsi.internal.core.WSIException; +import org.eclipse.wst.wsi.internal.core.WSITag; +import org.eclipse.wst.wsi.internal.core.analyzer.AssertionFailException; +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.impl.AssertionProcess; +import org.eclipse.wst.wsi.internal.core.report.AssertionResult; + +/** + * AP2946 + * + * <context>For a candidate wsdl:binding with at least one mime:content element</context> + * <assertionDescription>In a DESCRIPTION, a mime:content element + * includes the part attribute.</assertionDescription> + */ +public class AP2946 extends AssertionProcess implements WSITag +{ + private final WSDLValidatorImpl validator; + + /** + * @param WSDLValidatorImpl + */ + public AP2946(WSDLValidatorImpl 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 + { + // A variable that indicates a binding contains at least one + // mime:content element + boolean mimeContentsFound = false; + + // Getting a wsdl:binding + Binding binding = (Binding) entryContext.getEntry().getEntryDetail(); + + // Getting its wsdl:operation elements + List ops = binding.getBindingOperations(); + + // Going through the operation elements + for (int i = 0; i < ops.size(); i++) + { + BindingOperation bindingOperation = (BindingOperation) ops.get(i); + + // Getting wsdl:input and wsdl:output elements of an operation + BindingInput bindingInput = bindingOperation.getBindingInput(); + BindingOutput bindingOutput = bindingOperation.getBindingOutput(); + + // Collecting all the mime:content elements from wsdl:input and wsdl:output + List inputMimeContents = getMimeContentElements( + bindingInput == null ? null : bindingInput.getExtensibilityElements()); + List outputMimeContents = getMimeContentElements( + bindingOutput == null ? null : bindingOutput.getExtensibilityElements()); + + // If the wsdl:input contains mime:content elements + if (!inputMimeContents.isEmpty()) + { + mimeContentsFound = true; + // If there is a mime:content that does not include + // the part attribute, the assertion failed + if (hasInvalidMimeContent(inputMimeContents)) + throw new AssertionFailException("The invalid mime:content element" + + " is in the wsdl:input of the \"" + bindingOperation.getName() + + "\" binding operation."); + } + + // If the wsdl:output contains mime:content elements + if (!outputMimeContents.isEmpty()) + { + mimeContentsFound = true; + // If there is a mime:content that does not include + // the part attribute, the assertion failed + if (hasInvalidMimeContent(outputMimeContents)) + throw new AssertionFailException("The invalid mime:content element" + + " is in the wsdl:output of the \"" + bindingOperation.getName() + + "\" binding operation."); + } + } + + // If the binding contains no mime:content elements, + // the assertion is not applicable + if (!mimeContentsFound) + throw new AssertionNotApplicableException(); + } + catch (AssertionNotApplicableException anae) + { + result = AssertionResult.RESULT_NOT_APPLICABLE; + } + catch (AssertionFailException afe) + { + result = AssertionResult.RESULT_FAILED; + failureDetail = validator.createFailureDetail( + afe.getMessage(), entryContext); + } + // Return assertion result + return validator.createAssertionResult( + testAssertion, result, failureDetail); + } + + /** + * Collects all mime:content elements. + * @param extElems a list of extensibility elements that can contain mime:contentS. + * @return the list of mime:content elements found. + */ + private List getMimeContentElements(List extElems) + { + List mimeContentElements = new ArrayList(); + + if (extElems != null) + { + // Going through all the extensibility elements + for (int i = 0; i < extElems.size(); i++) + { + ExtensibilityElement extElem = (ExtensibilityElement) extElems.get(i); + // If the element is mime:multipartRelated + if (extElem.getElementType().equals(WSDL_MIME_MULTIPART)) + { + // Getting the mime:part elements of the mime:multipartRelated + List mimeParts = ((MIMEMultipartRelated) extElem).getMIMEParts(); + // Going through all the mime:part elements + for (int j = 0; j < mimeParts.size(); j++) + { + // Collecting all the mime:content elements of this mime:part + List elems = getMimeContentElements( + ((MIMEPart) mimeParts.get(j)).getExtensibilityElements()); + // Adding the elements to the list being returned + mimeContentElements.addAll(elems); + } + } + // Else if the element is mime:content + else if (extElem.getElementType().equals(WSDL_MIME_CONTENT)) + { + // Adding the element to the list being returned + mimeContentElements.add(extElem); + } + } + } + + return mimeContentElements; + } + + /** + * Validates mime:content elements. + * @param mimeContents a list of mime:content elements. + * @return true if any mime:content does not include the part attribute, + * false otherwise + */ + private boolean hasInvalidMimeContent(List mimeContents) + { + // Going through a list of mime:content elements + for (int i = 0; i < mimeContents.size(); i++) + { + // If a mime:content does not include the part attribute, return true + if (((MIMEContent) mimeContents.get(i)).getPart() == null) + return true; + } + // There are no invalid mime:contentS, return false + return false; + } +}
\ No newline at end of file |