org.opens.tanaguru.rules.elementchecker.attribute.AttributeWithValuePresenceChecker.java Source code

Java tutorial

Introduction

Here is the source code for org.opens.tanaguru.rules.elementchecker.attribute.AttributeWithValuePresenceChecker.java

Source

/*
 *  Tanaguru - Automated webpage assessment
 *  Copyright (C) 2008-2015  Tanaguru.org
 * 
 *  This file is part of Tanaguru.
 * 
 *  Tanaguru is free software: you can redistribute it and/or modify
 *  it under the terms of the GNU Affero General Public License as
 *  published by the Free Software Foundation, either version 3 of the
 *  License, or (at your option) any later version.
 * 
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU Affero General Public License for more details.
 * 
 *  You should have received a copy of the GNU Affero General Public License
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
 * 
 *  Contact us by mail: tanaguru AT tanaguru DOT org
 */
package org.opens.tanaguru.rules.elementchecker.attribute;

import org.apache.commons.lang3.StringUtils;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;
import org.opens.tanaguru.entity.audit.TestSolution;
import org.opens.tanaguru.processor.SSPHandler;
import org.opens.tanaguru.ruleimplementation.TestSolutionHandler;
import org.opens.tanaguru.rules.elementchecker.ElementCheckerImpl;

/**
 * This checker controls the presence of an attribute for a set of elements.
 *
 */
public class AttributeWithValuePresenceChecker extends ElementCheckerImpl {

    /**
     * the attribute the test is about
     */
    private final String attributeName;

    /**
     * the attribute value the test is about
     */
    private final String attributeValue;

    /**
     * The message code associated with a processRemark when the attribute is
     * detected on an element
     */
    private final String messageCodeOnAttrDetected;

    /**
     * The message code associated with a processRemark when the attribute is
     * not detected on an element
     */
    private final String messageCodeOnAttrNotDetected;

    /**
     * This flag determines whether each source code remark have to be related
     * with the element or the attribute itself. Default is false
     */
    private boolean createSourceCodeRemarkOnAttribute = false;

    /**
     *
     * @param attributeName
     * @param attributeValue
     * @param detectedSolution
     * @param notDetectedSolution
     * @param messageCodeOnAttrDetected
     * @param messageCodeOnAttrNotDetected
     * @param eeAttributeNameList
     */
    public AttributeWithValuePresenceChecker(String attributeName, String attributeValue,
            TestSolution detectedSolution, TestSolution notDetectedSolution, String messageCodeOnAttrDetected,
            String messageCodeOnAttrNotDetected, String... eeAttributeNameList) {
        super(detectedSolution, notDetectedSolution, eeAttributeNameList);
        this.attributeName = attributeName;
        this.attributeValue = attributeValue;

        this.messageCodeOnAttrDetected = messageCodeOnAttrDetected;
        this.messageCodeOnAttrNotDetected = messageCodeOnAttrNotDetected;
    }

    /**
     *
     * @param attributeName
     * @param attributeValue
     * @param detectedSolution
     * @param notDetectedSolution
     * @param messageCodeOnAttrDetected
     * @param messageCodeOnAttrNotDetected
     * @param createSourceCodeRemarkOnAttribute
     * @param eeAttributeNameList
     */
    public AttributeWithValuePresenceChecker(String attributeName, String attributeValue,
            TestSolution detectedSolution, TestSolution notDetectedSolution, String messageCodeOnAttrDetected,
            String messageCodeOnAttrNotDetected, boolean createSourceCodeRemarkOnAttribute,
            String... eeAttributeNameList) {
        super(detectedSolution, notDetectedSolution, eeAttributeNameList);
        this.attributeName = attributeName;
        this.attributeValue = attributeValue;

        this.messageCodeOnAttrDetected = messageCodeOnAttrDetected;
        this.messageCodeOnAttrNotDetected = messageCodeOnAttrNotDetected;

        this.createSourceCodeRemarkOnAttribute = createSourceCodeRemarkOnAttribute;
    }

    @Override
    public void doCheck(SSPHandler sspHandler, Elements elements, TestSolutionHandler testSolutionHandler) {
        checkAttributeWithValuePresence(elements, testSolutionHandler);
    }

    /**
     * This methods checks whether a given attribute is present for a set of
     * elements
     *
     * @param elements
     * @param testSolutionHandler
     */
    private void checkAttributeWithValuePresence(Elements elements, TestSolutionHandler testSolutionHandler) {

        if (elements.isEmpty()) {
            testSolutionHandler.addTestSolution(TestSolution.NOT_APPLICABLE);
            return;
        }

        TestSolution testSolution = TestSolution.PASSED;

        for (Element el : elements) {
            if (!el.hasAttr(attributeName)
                    || (el.hasAttr(attributeName) && !el.attr(attributeName).equals(attributeValue))) {

                testSolution = setTestSolution(testSolution, getFailureSolution());

                if (StringUtils.isNotBlank(messageCodeOnAttrNotDetected)) {
                    createSourceCodeRemark(getFailureSolution(), el, messageCodeOnAttrNotDetected);

                }
            } else if (StringUtils.isNotBlank(messageCodeOnAttrDetected)) {
                testSolution = setTestSolution(testSolution, getSuccessSolution());

                createSourceCodeRemark(getSuccessSolution(), el, messageCodeOnAttrDetected);
            }
        }

        testSolutionHandler.addTestSolution(testSolution);

    }

    /**
     *
     * @param testSolution
     * @param element
     * @param message
     */
    private void createSourceCodeRemark(TestSolution testSolution, Element element, String message) {
        if (createSourceCodeRemarkOnAttribute) {
            addSourceCodeRemarkOnAttribute(testSolution, element, message, attributeName);
        } else {
            addSourceCodeRemark(testSolution, element, message);
        }
    }

}