All Downloads are FREE. Search and download functionalities are using the official Maven repository.

nl.hsac.fitnesse.fixture.slim.XmlHttpTest Maven / Gradle / Ivy

package nl.hsac.fitnesse.fixture.slim;

import nl.hsac.fitnesse.fixture.util.XMLValidator;
import nl.hsac.fitnesse.fixture.util.XmlHttpResponse;
import org.apache.commons.lang3.StringUtils;

import java.util.ArrayList;
import java.util.List;

/**
 * Fixture to make HTTP requests returning XNL using Slim scripts and/or scenarios.
 * Example use: make SOAP calls using #postTo().
 */
public class XmlHttpTest extends HttpTest {
    /**
     * Creates new.
     */
    public XmlHttpTest() {
        setContentType(XmlHttpResponse.CONTENT_TYPE_XML_TEXT_UTF8);
    }

    /**
     * Register a prefix to use in XPath expressions.
     * @param prefix prefix to be used in xPath expressions.
     * @param namespace XML namespace the prefix should point to.
     */
    public void registerPrefixForNamespace(String prefix, String namespace) {
        getEnvironment().registerNamespace(prefix, getUrl(namespace));
    }

    @Override
    protected String formatValue(String value) {
        String formatted = super.formatValue(value);
        if (value != null && value.trim().startsWith("<")) {
            formatted = getEnvironment().getHtmlForXml(value);
        }
        return formatted;
    }

    /**
     * Gets a HTML list with all matches to the supplied XPath.
     * @param xPathExpr expression to evaluate.
     * @return list containing all results of expression evaluation against last response received, null if there were no matches.
     * @throws RuntimeException if no valid response was available or XPath could not be evaluated.
     */
    public String allXPathMatches(String xPathExpr) {
        String result = null;
        List allXPath = listXPathMatches(xPathExpr);
        if (allXPath != null && !allXPath.isEmpty()) {
            StringBuilder sb = new StringBuilder();
            sb.append("
    "); for (String match : allXPath) { sb.append("
  • "); sb.append(match); sb.append("
  • "); } sb.append("
"); result = sb.toString(); } return result; } public ArrayList listXPathMatches(String xPathExpr) { List results = getResponse().getAllXPath(xPathExpr); return results instanceof ArrayList? (ArrayList) results : new ArrayList<>(results); } /** * Gets XPath value, without ensuring response was valid. * @param xPathExpr expression to evaluate. * @return result of expression evaluation against last response received. */ public String rawXPath(String xPathExpr) { return getResponse().getRawXPath(xPathExpr); } /** * @param xPathExpr expression to evaluate. * @return result of expression evaluation against last response received. * @throws RuntimeException if no valid response was available or XPath could not be evaluated. */ public String xPath(String xPathExpr) { return getResponse().getXPath(xPathExpr); } /** * @param xPathExpr expression to evaluate. * @return result of expression evaluation against last response received. * @throws RuntimeException if no valid response was available or XPath could not be evaluated. */ public Double xPathDouble(String xPathExpr) { return getResponse().getXPathDouble(xPathExpr); } /** * @param xPathExpr expression to evaluate. * @return result of expression evaluation against last response received. * @throws RuntimeException if no valid response was available or XPath could not be evaluated. */ public Double xPathInt(String xPathExpr) { return getResponse().getXPathDouble(xPathExpr); } /** * @param baseName base of filename to generate (a number might be added to the name to make it unique). * @param xPath expression to evaluate. * @return link to created file. */ public String createFileFromBase64ContentOf(String baseName, String xPath) { String base64Content = xPath(xPath); if (StringUtils.isEmpty(base64Content)) { throw new SlimFixtureException(false, "No content from xPath: " + xPath); } else { return createFileFromBase64(baseName, base64Content); } } /** * Validate the loaded xml against a schema in file xsdFileName * @param xsdFileName filename of the xsd to use * @return true if the response xml validates against the schema. Throws a descriptive exception otherwise */ public boolean validateResponseAgainstXsdFile(String xsdFileName) { String xsdContent = new FileFixture().textIn(xsdFileName); return new XMLValidator().validateAgainst(getResponse().getResponse(), xsdContent); } /** * Validate the loaded xml against a schema provided from the wiki page * @param xsdSchema xsd schema to use * @return true if the response xml validates against the schema. Throws a descriptive exception otherwise */ public boolean validateResponseAgainstXsd(String xsdSchema) { String xsdContent = cleanupValue(xsdSchema); return new XMLValidator().validateAgainst(getResponse().getResponse(), xsdContent); } @Override protected boolean postProcessResponse() { // always called after post or get, so easy place to ensure namespaces are registered getEnvironment().setContext(getResponse()); boolean result = super.postProcessResponse(); return result; } public boolean repeatUntilXPathIs(final String xPath, final String expectedValue) { RepeatCompletion completion; if (expectedValue == null) { completion = new RepeatLastCall() { @Override public boolean isFinished() { return xPath(xPath) == null; } }; } else { String cleanedExpected = cleanupValue(expectedValue); completion = new RepeatLastCall() { @Override public boolean isFinished() { Object actual = xPath(xPath); return compareActualToExpected(cleanedExpected, actual); } }; } return repeatUntil(completion); } @Override public XmlHttpResponse getResponse() { return (XmlHttpResponse) super.getResponse(); } @Override protected XmlHttpResponse createResponse() { return new XmlHttpResponse(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy