How to use logUIAction method of com.paypal.selion.platform.html.AbstractElement class

Best SeLion code snippet using com.paypal.selion.platform.html.AbstractElement.logUIAction

Source:AbstractElement.java Github

copy

Full Screen

...330 return getLocator();331 }332 return resolvedName;333 }334 protected void logUIAction(UIActions actionPerformed) {335 logUIActions(actionPerformed, null);336 }337 protected void logUIActions(UIActions actionPerformed, String value) {338 logger.entering(new Object[] { actionPerformed, value });339 String valueToUse = (value == null) ? "" : value + " in ";340 Reporter.log(LOG_DEMARKER + actionPerformed.getAction() + valueToUse + resolveControlNameToUseForLogs(), false);341 logger.exiting();342 }343 protected void processScreenShot() {344 logger.entering();345 processAlerts(Grid.getWebTestSession().getBrowser());346 dispatcher.beforeScreenshot(this);347 String title = "Default Title";348 try {349 title = Grid.driver().getTitle();350 } catch (WebDriverException thrown) { // NOSONAR351 logger.log(Level.FINER, "An exception occurred while getting page title", thrown);352 }353 boolean logPages = Boolean.parseBoolean(Config.getConfigProperty(ConfigProperty.LOG_PAGES));354 if (Boolean.parseBoolean(Config.getConfigProperty(ConfigProperty.AUTO_SCREEN_SHOT))) {355 SeLionReporter.log(title, true, logPages);356 } else {357 SeLionReporter.log(title, false, logPages);358 }359 dispatcher.afterScreenshot(this);360 logger.exiting();361 }362 private void processAlerts(String browser) {363 logger.entering(browser);364 if (doesNotHandleAlerts(browser)) {365 logger.exiting(ALERTS_ARE_NOT_SUPPORTED_ERR_MSG);366 return;367 }368 try {369 Grid.driver().switchTo().alert();370 logger.warning("Encountered an alert. Skipping processing of screenshots");371 logger.exiting();372 return;373 } catch (NoAlertPresentException exception) {374 // Gobble the exception and do nothing with it. No alert was triggered. So it is safe to proceed with taking375 // screenshots.376 }377 }378 private boolean doesNotHandleAlerts(String browserFlavor) {379 logger.entering(browserFlavor);380 BrowserFlavors browser = BrowserFlavors.getBrowser(browserFlavor);381 boolean returnValue = Arrays.asList(BrowserFlavors.getBrowsersWithoutAlertSupport()).contains(browser);382 logger.exiting(returnValue);383 return returnValue;384 }385 protected void validatePresenceOfAlert() {386 String browser = Grid.getWebTestSession().getBrowser();387 logger.finest("Validating presence of alert with browser " + browser);388 if (doesNotHandleAlerts(browser)) {389 logger.info(ALERTS_ARE_NOT_SUPPORTED_ERR_MSG);390 return;391 }392 try {393 Grid.driver().switchTo().alert();394 String errorMsg = "Encountered an alert. Cannot wait for an element when an operation triggers an alert.";395 throw new InvalidElementStateException(errorMsg);396 } catch (NoAlertPresentException exception) {397 // Gobble the exception and do nothing with it. No alert was triggered. So it is safe to proceed ahead.398 }399 }400 /**401 * Basic click event on the Element. Functionally equivalent to {@link #clickonly()}402 */403 public void click() {404 clickonly();405 }406 /**407 * Basic click event on the Element. Doesn't wait for anything to load.408 *409 */410 public void clickonly() {411 click(new Object[] {});412 }413 /**414 * The click function and wait for expected {@link Object} items to load.415 *416 * @param expected417 * parameters in the form of an element locator {@link String}, a {@link WebPage}, an418 * {@link AbstractElement}, or an {@link ExpectedCondition}419 */420 @SuppressWarnings("unchecked")421 public void click(Object... expected) {422 dispatcher.beforeClick(this, expected);423 getElement().click();424 if (Boolean.parseBoolean(Config.getConfigProperty(ConfigProperty.ENABLE_GUI_LOGGING))) {425 logUIAction(UIActions.CLICKED);426 }427 // If there are no expected objects, then it means user wants this428 // method to behave as a clickonly. So lets skip processing of alerts and leave429 // that to the user.430 if (expected == null || expected.length == 0) {431 return;432 }433 if (parent != null) {434 WebDriverWaitUtils.waitUntilPageIsLoaded(parent.getCurrentPage());435 }436 validatePresenceOfAlert();437 try {438 for (Object expect : expected) {439 if (expect instanceof AbstractElement) {440 AbstractElement a = (AbstractElement) expect;441 WebDriverWaitUtils.waitUntilElementIsPresent(a.getLocator());442 continue;443 }444 if (expect instanceof String) {445 String s = (String) expect;446 WebDriverWaitUtils.waitUntilElementIsPresent(s);447 continue;448 }449 if (expect instanceof ExpectedCondition<?>) {450 long timeOutInSeconds = Grid.getExecutionTimeoutValue() / 1000;451 WebDriverWait wait = new WebDriverWait(Grid.driver(), timeOutInSeconds);452 wait.until(ExpectedCondition.class.cast(expect));453 continue;454 }455 if (expect instanceof WebPage) {456 WebDriverWaitUtils.waitUntilPageIsValidated((WebPage) expect);457 continue;458 }459 }460 } finally {461 // Attempt at taking screenshots even when there are time-outs triggered from the wait* methods.462 processScreenShot();463 dispatcher.afterClick(this, expected);464 }465 }466 /**467 * The click function and wait based on the ExpectedCondition.468 *469 * @param expectedCondition470 * ExpectedCondition<?> instance to be passed.471 *472 * @return The return value of473 * {@link org.openqa.selenium.support.ui.FluentWait#until(com.google.common.base.Function)} if the function474 * returned something different from null or false before the timeout expired.<br>475 *476 * <pre>477 * Grid.driver().get(&quot;https://www.paypal.com&quot;);478 * TextField userName = new TextField(&quot;login_email&quot;);479 * TextField password = new TextField(&quot;login_password&quot;);480 * Button btn = new Button(&quot;submit.x&quot;);481 *482 * userName.type(&quot;exampleId@paypal.com&quot;);483 * password.type(&quot;123Abcde&quot;);484 * btn.clickAndExpect(ExpectedConditions.titleIs(&quot;MyAccount - PayPal&quot;));485 * </pre>486 */487 public Object clickAndExpect(ExpectedCondition<?> expectedCondition) {488 dispatcher.beforeClick(this, expectedCondition);489 getElement().click();490 if (Boolean.parseBoolean(Config.getConfigProperty(ConfigProperty.ENABLE_GUI_LOGGING))) {491 logUIAction(UIActions.CLICKED);492 }493 if (parent != null) {494 WebDriverWaitUtils.waitUntilPageIsLoaded(parent.getCurrentPage());495 }496 validatePresenceOfAlert();497 long timeout = Grid.getExecutionTimeoutValue() / 1000;498 WebDriverWait wait = new WebDriverWait(Grid.driver(), timeout);499 Object variable = wait.until(expectedCondition);500 processScreenShot();501 dispatcher.afterClick(this, expectedCondition);502 return variable;503 }504 /**505 * Click function that will wait for one of the ExpectedConditions to match.506 * {@link org.openqa.selenium.TimeoutException} exception will be thrown if no conditions are matched within the507 * allowed time {@link ConfigProperty#EXECUTION_TIMEOUT}508 *509 * @param conditions510 * {@link List}&lt;{@link ExpectedCondition}&lt;?&gt;&gt; of supplied conditions passed.511 * @return first {@link org.openqa.selenium.support.ui.ExpectedCondition} that was matched512 */513 public ExpectedCondition<?> clickAndExpectOneOf(final List<ExpectedCondition<?>> conditions) {514 dispatcher.beforeClick(this, conditions);515 getElement().click();516 if (Boolean.parseBoolean(Config.getConfigProperty(ConfigProperty.ENABLE_GUI_LOGGING))) {517 logUIAction(UIActions.CLICKED);518 }519 // If there are no expected objects, then it means user wants this method520 // to behave as a clickonly. So lets skip processing of alerts and leave521 // that to the user.522 if (conditions == null || conditions.size() <= 0) {523 return null;524 }525 if (parent != null) {526 WebDriverWaitUtils.waitUntilPageIsLoaded(parent.getCurrentPage());527 }528 validatePresenceOfAlert();529 long timeout = Grid.getExecutionTimeoutValue() / 1000;530 try {531 WebDriverWait wait = new WebDriverWait(Grid.driver(), timeout);532 wait.ignoring(NoSuchElementException.class);533 wait.ignoring(ExpectOneOfException.class);534 ExpectedCondition<?> matchedCondition = wait.until(new Function<WebDriver, ExpectedCondition<?>>() {535 // find the first condition that matches and return it536 @Override537 public ExpectedCondition<?> apply(WebDriver webDriver) {538 StringBuilder sb = new StringBuilder();539 int i = 1;540 for (final ExpectedCondition<?> condition : conditions) {541 try {542 Object value = condition.apply(webDriver);543 if (value instanceof Boolean) {544 if (Boolean.TRUE.equals(value)) {545 return condition;546 }547 } else if (value != null) {548 return condition;549 }550 } catch (WebDriverException e) {551 sb.append("\n\tObject " + i + ":\n");552 sb.append("\t" + ExceptionUtils.getRootCauseMessage(e).split("\n")[0] + "\n");553 sb.append("\t\t" + StringUtils.substringBetween(ExceptionUtils.getStackTrace(e), "\n"));554 }555 i++;556 }557 throw new ExpectOneOfException(sb.toString());558 }559 });560 return matchedCondition;561 } finally {562 // Attempt at taking screenshots even when there are time-outs triggered from the wait* methods.563 processScreenShot();564 dispatcher.afterClick(this, conditions);565 }566 }567 /**568 * The click function and wait for one of the expected {@link Object} items to load.569 *570 * @param expected571 * parameters in the form of an element locator {@link String}, a {@link WebPage}, or an572 * {@link AbstractElement}573 * @return the first object that was matched574 */575 public Object clickAndExpectOneOf(final Object... expected) {576 dispatcher.beforeClick(this, expected);577 getElement().click();578 if (Boolean.parseBoolean(Config.getConfigProperty(ConfigProperty.ENABLE_GUI_LOGGING))) {579 logUIAction(UIActions.CLICKED);580 }581 // If there are no expected objects, then it means user wants this method582 // to behave as a clickonly. So lets skip processing of alerts and leave583 // that to the user.584 if (expected == null || expected.length == 0) {585 return null;586 }587 if (parent != null) {588 WebDriverWaitUtils.waitUntilPageIsLoaded(parent.getCurrentPage());589 }590 validatePresenceOfAlert();591 long timeout = Grid.getExecutionTimeoutValue() / 1000;592 try {593 WebDriverWait wait = new WebDriverWait(Grid.driver(), timeout);...

Full Screen

Full Screen

logUIAction

Using AI Code Generation

copy

Full Screen

1public class HomePage extends AbstractPage {2 private static final String PAGE_TITLE = "Home Page";3 private static final String PAGE_NAME = "homePage";4 private static final String PAGE_FRAME = null;5 private static final String PAGE_WINDOW = null;6 private static final String PAGE_WINDOW_NAME = null;7 public HomePage() {8 super(PAGE_TITLE, PAGE_URL, PAGE_NAME, PAGE_FRAME, PAGE_WINDOW, PAGE_WINDOW_NAME);9 }10 public HomePage(String pageTitle, String pageUrl, String pageName, String pageFrame, String pageWindow, String pageWindowName) {11 super(pageTitle, pageUrl, pageName, pageFrame, pageWindow, pageWindowName);12 }13 public HomePage(String pageTitle, String pageUrl, String pageName, String pageFrame, String pageWindow, String pageWindowName, boolean isSecure) {14 super(pageTitle, pageUrl, pageName, pageFrame, pageWindow, pageWindowName, isSecure);15 }16 public HomePage(String pageName) {17 super(pageName);18 }19 public HomePage(String pageName, boolean isSecure) {20 super(pageName, isSecure);21 }22 public HomePage(String

Full Screen

Full Screen

logUIAction

Using AI Code Generation

copy

Full Screen

1public class LogUIActionTest extends AbstractTest {2 public void testLogUIAction() {3 Button button = new Button("id=button");4 button.logUIAction("Clicking on button");5 Label label = new Label("id=label");6 label.logUIAction("Getting text of label");7 }8}9public class LogUIActionTest extends AbstractTest {10 public void testLogUIAction() {11 Table table = new Table("id=table");12 table.logUIAction("Getting table row count");13 }14}

Full Screen

Full Screen

Automation Testing Tutorials

Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful