org.specrunner.htmlunit.assertions.PluginPresent Maven / Gradle / Ivy
/*
SpecRunner - Acceptance Test Driven Development Tool
Copyright (C) 2011-2016 Thiago Santos
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see
*/
package org.specrunner.htmlunit.assertions;
import java.util.List;
import org.specrunner.context.IContext;
import org.specrunner.htmlunit.AbstractPluginFind;
import org.specrunner.htmlunit.IFinder;
import org.specrunner.plugins.ActionType;
import org.specrunner.plugins.PluginException;
import org.specrunner.plugins.type.Assertion;
import org.specrunner.result.IResultSet;
import org.specrunner.result.status.Failure;
import org.specrunner.result.status.Success;
import com.gargoylesoftware.htmlunit.SgmlPage;
import com.gargoylesoftware.htmlunit.WebClient;
import com.gargoylesoftware.htmlunit.html.HtmlElement;
/**
* Check if an id, name, value, xpath, etc is present.
*
* @author Thiago Santos
*
*/
public class PluginPresent extends AbstractPluginFind {
/**
* Exact number of elements selected.
*/
private Integer count;
/**
* Minimum number of elements selected.
*/
private Integer min;
/**
* Maximum number of elements selected.
*/
private Integer max;
/**
* Gets the exact count match.
*
* @return The count.
*/
public Integer getCount() {
return count;
}
/**
* Sets the exact count match.
*
* @param count
* The count.
*/
public void setCount(Integer count) {
this.count = count;
}
/**
* Gets the minimum count.
*
* @return The minimum.
*/
public Integer getMin() {
return min;
}
/**
* Sets the minimum.
*
* @param min
* The minimum.
*/
public void setMin(Integer min) {
this.min = min;
}
/**
* Set maximum counter.
*
* @return The maximum.
*/
public Integer getMax() {
return max;
}
/**
* Sets the maximum.
*
* @param max
* The maximum.
*/
public void setMax(Integer max) {
this.max = max;
}
@Override
public ActionType getActionType() {
return Assertion.INSTANCE;
}
@Override
protected void doEnd(IContext context, IResultSet result, WebClient client, SgmlPage page) throws PluginException {
IFinder finder = getFinderInstance(context);
List> list = finder.find(context, result, client, page);
printBefore(context, list);
int failure = 0;
if (getCount() != null) {
if (list.size() != getCount()) {
result.addResult(Failure.INSTANCE, context.peek(), new PluginException("The expected count of elements was '" + count + "', but '" + list.size() + "' was received."));
failure++;
}
} else {
if (list.isEmpty()) {
result.addResult(Failure.INSTANCE, context.peek(), new PluginException("Element not found."));
failure++;
}
}
if (getMin() != null && list.size() < getMin()) {
result.addResult(Failure.INSTANCE, context.peek(), new PluginException("The expected minimum of elements was '" + getMin() + "', but '" + list.size() + "' was received."));
failure++;
}
if (getMax() != null && list.size() > getMax()) {
result.addResult(Failure.INSTANCE, context.peek(), new PluginException("The expected maximum of elements was '" + getMax() + "', but '" + list.size() + "' was received."));
failure++;
}
if (failure == 0) {
result.addResult(Success.INSTANCE, context.peek());
}
}
@Override
protected void process(IContext context, IResultSet result, WebClient client, SgmlPage page, HtmlElement[] elements) throws PluginException {
// useless.
}
}