/* * JBoss, Home of Professional Open Source * Copyright 2010-2016, 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.richfaces.tests.metamer.ftest.a4jLog; import static org.richfaces.fragment.log.Log.LogEntryLevel.INFO; import static org.richfaces.fragment.log.Log.LogEntryLevel.values; import static org.richfaces.tests.metamer.ftest.extension.configurator.use.annotation.ValuesFrom.FROM_ENUM; import static org.richfaces.tests.metamer.ftest.extension.configurator.use.annotation.ValuesFrom.FROM_FIELD; import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertTrue; import java.util.Set; import org.jboss.arquillian.graphene.Graphene; import org.openqa.selenium.WebElement; import org.openqa.selenium.support.FindBy; import org.openqa.selenium.support.ui.Select; import org.richfaces.fragment.common.TextInputComponentImpl; import org.richfaces.fragment.common.Utils; import org.richfaces.fragment.hotkey.RichFacesHotkey; import org.richfaces.fragment.log.Log.LogEntryLevel; import org.richfaces.fragment.log.RichFacesLog; import org.richfaces.tests.metamer.ftest.AbstractWebDriverTest; import org.richfaces.tests.metamer.ftest.extension.attributes.coverage.annotations.CoversAttributes; import org.richfaces.tests.metamer.ftest.extension.configurator.templates.annotation.Templates; import org.richfaces.tests.metamer.ftest.extension.configurator.use.annotation.UseWithField; import org.richfaces.tests.metamer.ftest.extension.configurator.use.annotation.Uses; import org.richfaces.tests.metamer.ftest.webdriver.Attributes; import org.testng.annotations.Test; /** * Test case for page /faces/components/a4jLog/simple.xhtml * * @author <a href="https://community.jboss.org/people/ppitonak">Pavol Pitonak</a> * @since 4.3.0.M2 */ public class TestLog extends AbstractWebDriverTest { private final Attributes<LogAttributes> attributes = getAttributes(); @FindBy(css = "input[id$=debugButton]") private WebElement debugButton; @FindBy(css = "input[id$=errorButton]") private WebElement errorButton; @FindBy private RichFacesHotkey hotkey; @FindBy(css = "input[id$=infoButton]") private WebElement infoButton; @FindBy(css = "input[id$=nameInput]") private TextInputComponentImpl input; @FindBy(css = "div.rf-log select") private Select levelSelect; private LogEntryLevel levelToSet; @FindBy(css = "div.rf-log") private RichFacesLog log; @FindBy(css = "span[id$=out]") private WebElement output; private Boolean setLevelByAttribute; @FindBy(css = "input[id$=submitButton]") private WebElement submitButton; @FindBy(css = "input[id$=warnButton]") private WebElement warnButton; private void checkForEachLevel() { for (LogEntryLevel levelToTrigger : values()) { log.clear(); input.clear().sendKeys(levelToTrigger.toString()); triggerMessage(levelToTrigger); assertEquals(log.getLogEntries().size(), levelToTrigger.ordinal() >= levelToSet.ordinal() ? 1 : 0); if (!log.getLogEntries().isEmpty()) { assertEquals(log.getLogEntries().getItem(0).getLevel(), levelToTrigger, "Message type in log."); assertEquals(log.getLogEntries().getItem(0).getContent(), levelToTrigger.toString(), "Message content."); } } } private String getSecondWindowHandle(String originalWindow) { Set<String> windowHandles = driver.getWindowHandles(); windowHandles.remove(originalWindow); return windowHandles.iterator().next(); } @Override public String getComponentTestPagePath() { return "a4jLog/simple.xhtml"; } private void submit() { Graphene.guardAjax(submitButton).click(); } @Test @Templates(value = "plain") public void testClearButton() { testSubmit(); log.clear(); assertTrue(log.getLogEntries().isEmpty(), "There should be no messages in log after clear button was clicked."); } @Test @CoversAttributes({ "level", "mode", "hotkey" }) @Templates("plain") @UseWithField(field = "levelToSet", valuesFrom = FROM_ENUM, value = "") public void testHotkeyAndPopupMode() { String originalWindow = driver.getWindowHandle(); try { attsSetter() .setAttribute(LogAttributes.level).toValue(levelToSet.toString().toLowerCase()) .setAttribute(LogAttributes.mode).toValue("popup") .setAttribute(LogAttributes.hotkey).toValue("d") .asSingleAction().perform(); hotkey.setHotkey("ctrl+shift+d"); assertEquals(driver.getWindowHandles().size(), 1, "There should be only 1 browser window."); hotkey.invoke(); assertEquals(driver.getWindowHandles().size(), 2, "There should be 2 browser windows."); String logWindowHandle = getSecondWindowHandle(originalWindow); for (LogEntryLevel levelToTrigger : values()) { driver.switchTo().window(logWindowHandle); RichFacesLog logInsidePopup = Graphene.createPageFragment(RichFacesLog.class, driver.findElement(Utils.BY_BODY)); logInsidePopup.clear(); driver.switchTo().window(originalWindow); input.clear().sendKeys(levelToTrigger.toString()); triggerMessage(levelToTrigger); driver.switchTo().window(logWindowHandle); assertEquals(logInsidePopup.getLogEntries().size(), levelToTrigger.ordinal() >= levelToSet.ordinal() ? 1 : 0); if (!logInsidePopup.getLogEntries().isEmpty()) { assertEquals(logInsidePopup.getLogEntries().getItem(0).getLevel(), levelToTrigger, "Message type in log."); assertEquals(logInsidePopup.getLogEntries().getItem(0).getContent(), levelToTrigger.toString(), "Message content."); } } } finally { // close generated window with a4j:log if (driver.getWindowHandles().size() > 1) { Set<String> windowHandles = driver.getWindowHandles(); for (String windowHandle : windowHandles) { if (windowHandle.equals(originalWindow)) { continue; } driver.switchTo().window(windowHandle); driver.close(); } driver.switchTo().window(originalWindow); assertEquals(driver.getWindowHandles().size(), 1, "There should be only 1 browser window."); } } } @Test(groups = "smoke") @CoversAttributes({ "level", "mode" }) @Templates(value = "plain") @Uses({ @UseWithField(field = "levelToSet", valuesFrom = FROM_ENUM, value = ""), @UseWithField(field = "setLevelByAttribute", valuesFrom = FROM_FIELD, value = "booleans") }) public void testLevel() { if (setLevelByAttribute) { attributes.set(LogAttributes.level, levelToSet.toString().toLowerCase()); } else { log.changeLevel(levelToSet); } String selectedLevel = levelSelect.getFirstSelectedOption().getText(); assertEquals(selectedLevel, levelToSet.toString().toLowerCase(), "Log level in select wasn't changed."); checkForEachLevel(); } @Test @Templates(value = "plain") public void testLevelDefault() { levelToSet = INFO; attributes.set(LogAttributes.level, ""); String selectedLevel = levelSelect.getFirstSelectedOption().getText(); assertEquals(selectedLevel, levelToSet.toString().toLowerCase(), "Log level in select wasn't changed."); checkForEachLevel(); } @Test @CoversAttributes("rendered") @Templates(value = "plain") public void testRendered() { attributes.set(LogAttributes.rendered, false); assertNotVisible(log.advanced().getRootElement(), "Log should be not rendered."); } @Test @CoversAttributes("style") @Templates(value = "plain") public void testStyle() { testStyle(log.advanced().getRootElement()); } @Test @CoversAttributes("styleClass") @Templates(value = "plain") public void testStyleClass() { testStyleClass(log.advanced().getRootElement()); } @Test public void testSubmit() { input.clear().sendKeys("RichFaces 4"); submit(); Graphene.waitGui().until().element(output).text().equalTo("Hello RichFaces 4!"); assertTrue(log.getLogEntries().size() > 0, "There should be at least one message in log after submit button was clicked."); } @Test public void testSubmitUnicode() { input.clear().sendKeys("ľščťžýáíéôúäň"); submit(); Graphene.waitGui().until().element(output).text().equalTo("Hello ľščťžýáíéôúäň!"); assertTrue(log.getLogEntries().size() > 0, "There should be at least one message in log after submit button was clicked."); } private void triggerMessage(LogEntryLevel levelToTrigger) { switch (levelToTrigger) { case DEBUG: debugButton.click(); break; case INFO: infoButton.click(); break; case WARN: warnButton.click(); break; case ERROR: errorButton.click(); break; default: break; } } }