org.jboss.arquillian.ajocado.waiting.conditions.AttributeEquals Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of graphene-selenium-impl Show documentation
Show all versions of graphene-selenium-impl Show documentation
Testing Ajax with flavour of sexy type-safe API
/**
* JBoss, Home of Professional Open Source
* Copyright 2011, Red Hat, Inc. and individual contributors
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.arquillian.ajocado.waiting.conditions;
import static org.apache.commons.lang3.StringEscapeUtils.escapeEcmaScript;
import static org.jboss.arquillian.ajocado.javascript.JavaScript.js;
import org.jboss.arquillian.ajocado.framework.GrapheneSelenium;
import org.jboss.arquillian.ajocado.framework.GrapheneSeleniumContext;
import org.jboss.arquillian.ajocado.javascript.JavaScript;
import org.jboss.arquillian.ajocado.locator.attribute.AttributeLocator;
import org.jboss.arquillian.ajocado.waiting.ajax.JavaScriptCondition;
import org.jboss.arquillian.ajocado.waiting.selenium.SeleniumCondition;
import org.jboss.arquillian.core.spi.Validate;
/**
*
*
* Implementation of Condition for waiting if element's attribute given by attributeLocator has value equal to given value.
*
*
*
* Implements Condition and JavaScriptCondition used in SeleniumWaiting and AjaxWaiting.
*
*
* @author Lukas Fryc
* @version $Revision$
*/
public class AttributeEquals implements SeleniumCondition, JavaScriptCondition {
/**
* Proxy to local selenium instance
*/
private GrapheneSelenium selenium = GrapheneSeleniumContext.getProxy();
/** The element locator. */
private AttributeLocator> attributeLocator;
/** The value. */
private String value;
/**
* Instantiates a new AttributeEquals
*/
protected AttributeEquals() {
}
/*
* (non-Javadoc)
*
* @see org.jboss.arquillian.ajocado.waiting.Condition#isTrue()
*/
@Override
public boolean isTrue() {
Validate.notNull(attributeLocator, "attributeLocator should not be null");
Validate.notNull(value, "message should not be null");
return selenium.getAttribute(attributeLocator).equals(value);
}
/*
* (non-Javadoc)
*
* @see org.jboss.arquillian.ajocado.waiting.ajax.JavaScriptCondition#getJavaScriptCondition()
*/
@Override
public JavaScript getJavaScriptCondition() {
String escapedElementLocator = escapeEcmaScript(this.attributeLocator.getAssociatedElement().inSeleniumRepresentation());
String escapedAttributeLocator = escapeEcmaScript(this.attributeLocator.inSeleniumRepresentation());
String escapedValue = escapeEcmaScript(this.value);
return js("selenium.isElementPresent('{0}') && (selenium.getAttribute('{1}') == '{2}')").parametrize(
escapedElementLocator, escapedAttributeLocator, escapedValue);
}
/**
* Factory method.
*
* @return single instance of AttributeEquals
*/
public static AttributeEquals getInstance() {
return new AttributeEquals();
}
/**
*
* Returns the AttributeEquals instance with given attributeLocator preset.
*
*
*
* From this element's attribute will be obtained the value.
*
*
* @param attributeLocator the attribute locator
* @return the AttributeEquals object with preset locator
*/
public AttributeEquals locator(AttributeLocator> attributeLocator) {
Validate.notNull(attributeLocator, "attributeLocator should not be null");
AttributeEquals copy = copy();
copy.attributeLocator = attributeLocator;
return copy;
}
/**
*
* Returns the AttributeEquals instance with preset value.
*
*
*
* For equality with this value the condition will wait.
*
*
* @param value it should wait for equality
* @return the AttributeEquals object with preset value
*/
public AttributeEquals text(String value) {
Validate.notNull(value, "value should not be null");
AttributeEquals copy = copy();
copy.value = value;
return copy;
}
/**
* Returns the exact copy of this AttributeEquals object.
*
* @return the copy of this AttributeEquals object
*/
private AttributeEquals copy() {
AttributeEquals copy = new AttributeEquals();
copy.attributeLocator = attributeLocator;
copy.value = value;
return copy;
}
}