/*
* 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.tanaguru.ruleimplementation;
import java.util.Collection;
import javax.annotation.Nonnull;
import javax.persistence.NoResultException;
import org.tanaguru.entity.audit.TestSolution;
import org.tanaguru.processor.SSPHandler;
import org.tanaguru.rules.domelement.DomElement;
import org.tanaguru.rules.domelement.extractor.DomElementExtractor;
import org.tanaguru.rules.elementchecker.ElementChecker;
/**
* <p>
* This class should be overridden by concrete {@link RuleImplementation}
* classes which implement tests with page scope.
* </p>
* <p>It is based from the js extractor results launched while fetching the DOM.</p>
* <p>The selection consists in parsing the JSON object and create POJO
* DomElement collection to work on</p>
* <p>It embeds a {@link ElementChecker} set by constructor argument to perform
* the check.
* </p>
*/
public abstract class AbstractPageRuleFromPreProcessImplementation
extends AbstractPageRuleWithSelectorAndCheckerImplementation {
/* the extracted domElements*/
Collection<DomElement> domElements;
/**
* The default constructor
*
*/
public AbstractPageRuleFromPreProcessImplementation() {
super();
}
/**
* The constructor
*
* @param elementChecker
*/
public AbstractPageRuleFromPreProcessImplementation(
@Nonnull ElementChecker elementChecker) {
super();
setElementChecker(elementChecker);
}
/**
* No selection is performed here.
*
* @param sspHandler
*/
@Override
protected void select(SSPHandler sspHandler) {
try {
domElements = DomElementExtractor.extractDomElements(sspHandler);
} catch (NoResultException nre) {
return;
}
doSelect(domElements, sspHandler);
}
/**
*
* @param domElements
* @param sspHandler
*/
protected abstract void doSelect(
Collection<DomElement>domElements,
SSPHandler sspHandler);
/**
* Perform the check using the {@link ElementChecker}
*
* @param sspHandler
* @param testSolutionHandler
*/
@Override
protected void check(
SSPHandler sspHandler,
TestSolutionHandler testSolutionHandler) {
if (domElements == null) {
testSolutionHandler.addTestSolution(TestSolution.NOT_TESTED);
return;
}
super.check(sspHandler, testSolutionHandler);
}
}