package com.yahoo.dtf.actions.selenium.conditionals; import com.yahoo.dtf.actions.conditionals.Condition; import com.yahoo.dtf.actions.conditionals.Conditional; import com.yahoo.dtf.actions.selenium.commands.SeleniumLocatorTag; import com.yahoo.dtf.exception.DTFException; /** * @dtf.tag isEditable * @dtf.skip.index * * @dtf.since 1.0 * @dtf.author Rodney Gomes * * @dtf.tag.desc <p> * Determines whether the specified input element is editable, ie * hasn't been disabled. This method will fail if the specified * element isn't an input element. * </p> * * @dtf.tag.example * <selenium baseurl="http://www.google.com"> * <open url="/"/> * <waitForPageToLoad timeout="30000"/> * <assert><isEditable locator="q"/></assert> * </selenium> */ public class Iseditable extends SeleniumLocatorTag implements Conditional { @Override public boolean evaluate() throws DTFException { if (!getSelenium().isEditable(getLocator()) ) { String msg = getLocator() + " not editable on page."; registerContext(Condition.ASSERT_EXP_CTX, msg); return false; } return true; } /** * By registering the context ASSERT_EXP_CTX you can set the message to * be returned explaining the failure to assert a condition. */ public String explanation() throws DTFException { return getContext(Condition.ASSERT_EXP_CTX).toString(); } }