Skip to main content

This CGIT instance is deprecated, and repositories have been moved to Gitlab or Github. See the repository descriptions for specific locations.

summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
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.java194
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

Back to the top