[
https://issues.jboss.org/browse/ARQAJO-119?page=com.atlassian.jira.plugin...
]
Lukáš Fryč edited comment on ARQAJO-119 at 3/15/12 12:28 PM:
-------------------------------------------------------------
Juraj, I do not have strict opinion here, just discuss the consequences:
You can use these principles to solve the issue with current API:
* install
[{{CommandInterceptor}}|https://github.com/arquillian/arquillian-graphene/blob/master/api/src/main/java/org/jboss/arquillian/ajocado/command/CommandInterceptor.java]
to catch all {{ElementNotFoundException}} and install it to {{GrapheneSelenium}}
* use the right condition - when {{elementVisible}} fails when the element is not present,
I consider it right behavior - you should rather use {{elementPresent}}
When we would change the behavior:
* then each of the [listed
methods|https://github.com/arquillian/arquillian-graphene/blob/master/imp...]
should probably use {{isElementPresent}} condition before the actual condition, right?
was (Author: lfryc):
Juraj, I do not have strict opinion here, just discuss the consequences:
You can use these principles to solve the issue with current API:
* install
[{{CommandInterceptor}}|https://github.com/arquillian/arquillian-graphene/blob/master/api/src/main/java/org/jboss/arquillian/ajocado/command/CommandInterceptor.java]
to catch all {{ElementNotFoundException}} and install it to {{GrapheneSelenium}}
isVisible JS condition should not fail when element is not present
------------------------------------------------------------------
Key: ARQAJO-119
URL:
https://issues.jboss.org/browse/ARQAJO-119
Project: Arquillian Ajocado
Issue Type: Enhancement
Components: api, core
Affects Versions: 1.0.0.CR3
Reporter: Juraj Huska
Priority: Minor
Labels: waiting_on_user
The method isVisible of object selenium is failing (throwing exception element not
found), when the element is not present on the page.
This behavior is quite unhandy in for invocations such as:
{code}
waitModel.failWith("Popup did not show").until(elementVisible.locator(popup));
{code}
It is only the example, but this will fail and no wait is done at all. To simulate it
without failing, one has to write:
{code}
waitModel.failWith("Popup did not show").until(elementPresent.locator( jq(
popup.getRawLocator + ":visible" ) ));
{code}
So he *has to use elementPresent condition and add :visible locator*, even when he really
just wants to verify whether the element is visible, since it is obvious that the element
can be present and not be visible at the same time.
So my propose will be to *catch* the ElementNotFoundException in selenium invocation of
isVisible and to *return false*, when the element is not present. For me this sounds quite
reasonably. *Is there any problem with it? Will it be problem to change the Selenium API,
and to make it not consistent with standard Selenium 1,2 ?*
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators:
https://issues.jboss.org/secure/ContactAdministrators!default.jspa
For more information on JIRA, see:
http://www.atlassian.com/software/jira