[richfaces-svn-commits] JBoss Rich Faces SVN: r355 - in trunk/richfaces/menu-components/src/test/java/org/richfaces: component and 2 other directories.
richfaces-svn-commits at lists.jboss.org
richfaces-svn-commits at lists.jboss.org
Wed Apr 11 08:58:24 EDT 2007
Author: F.antonov
Date: 2007-04-11 08:58:24 -0400 (Wed, 11 Apr 2007)
New Revision: 355
Added:
trunk/richfaces/menu-components/src/test/java/org/richfaces/renderkit/
trunk/richfaces/menu-components/src/test/java/org/richfaces/renderkit/html/
trunk/richfaces/menu-components/src/test/java/org/richfaces/renderkit/html/MenuItemRendererBaseTest.java
Modified:
trunk/richfaces/menu-components/src/test/java/org/richfaces/component/MenuItemComponentTest.java
Log:
Menu components test cases development.
Modified: trunk/richfaces/menu-components/src/test/java/org/richfaces/component/MenuItemComponentTest.java
===================================================================
--- trunk/richfaces/menu-components/src/test/java/org/richfaces/component/MenuItemComponentTest.java 2007-04-11 12:29:47 UTC (rev 354)
+++ trunk/richfaces/menu-components/src/test/java/org/richfaces/component/MenuItemComponentTest.java 2007-04-11 12:58:24 UTC (rev 355)
@@ -21,36 +21,18 @@
package org.richfaces.component;
-import java.io.IOException;
-import java.io.Serializable;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
-import java.util.Map;
import java.util.Set;
-import junit.framework.Assert;
-import junit.framework.Test;
-import junit.framework.TestCase;
-import junit.framework.TestSuite;
-
-import javax.faces.component.UICommand;
import javax.faces.component.UIComponent;
import javax.faces.component.UIForm;
import javax.faces.component.html.HtmlForm;
import javax.faces.component.html.HtmlOutputText;
-import javax.faces.context.FacesContext;
-import javax.faces.convert.IntegerConverter;
-import javax.faces.el.ValueBinding;
-import javax.faces.event.AbortProcessingException;
-import javax.faces.event.ActionEvent;
-import javax.faces.event.FacesEvent;
-import javax.faces.event.FacesListener;
import javax.faces.event.PhaseId;
-import javax.faces.render.Renderer;
import org.richfaces.component.html.HtmlMenuItem;
-import org.richfaces.renderkit.html.MenuItemRenderer;
import com.gargoylesoftware.htmlunit.html.HtmlPage;
import com.gargoylesoftware.htmlunit.html.HtmlElement;
@@ -59,21 +41,18 @@
import org.ajax4jsf.tests.AbstractAjax4JsfTestCase;
import org.ajax4jsf.tests.MockViewRoot;
-import org.ajax4jsf.ajax.UIActionParameter;
-import org.ajax4jsf.framework.renderer.ComponentVariables;
-import org.ajax4jsf.framework.renderer.ComponentsVariableResolver;
import org.apache.commons.collections.Buffer;
import org.apache.commons.lang.StringUtils;
-import org.apache.shale.test.mock.MockActionListener;
+
/**
* Unit test for MenuItem Component.
*/
public class MenuItemComponentTest
extends AbstractAjax4JsfTestCase
{
- private static Set javaScripts = new HashSet();
+ private static Set javaScripts = new HashSet<String>();
static {
javaScripts.add("prototype.js");
@@ -119,6 +98,7 @@
*/
public void testMenuItemRender() throws Exception
{
+ menuItem.setMode(MenuComponent.MODE_NONE);
HtmlPage page = renderView();
assertNotNull(page);
//System.out.println(page.asXml());
@@ -128,7 +108,7 @@
}
/**
- * MenuItem facets test.
+ * MenuItem facet test.
*/
public void testMenuItemIconFacet() throws Exception
{
@@ -143,11 +123,12 @@
}
/**
- * Test for MenuItem component in disabled mode.
+ * Test for MenuItem disabled component.
*/
public void testDisabledMenuItem() throws Exception
{
- menuItem.setDisabled(true);
+ menuItem.setDisabled(true);
+ menuItem.getAttributes().put("iconDisabled", "menuItemIconDisabled");
HtmlPage page = renderView();
assertNotNull(page);
System.out.println(page.asXml());
@@ -176,15 +157,18 @@
}
/**
- * Test for MenuItem component in enabled mode.
+ * Test for enabled MenuItem component in "server" mode.
*/
- public void testEnabledMenuItem() throws Exception
+ public void testEnabledMenuItemServerMode() throws Exception
{
assertEquals(false, menuItem.isDisabled());
menuItem.getAttributes().put("iconClass", "iconClass");
+ menuItem.setMode(MenuComponent.MODE_SERVER);
+ menuItem.getAttributes().put("target", "target");
+ menuItem.getAttributes().put("selectStyle", "menuItemSelectStyle");
HtmlPage page = renderView();
assertNotNull(page);
- //System.out.println(page.asXml());
+ System.out.println(page.asXml());
HtmlElement anchor = page.getHtmlElementById(menuItem.getClientId(facesContext) + ":anchor");
assertNotNull(anchor);
@@ -204,9 +188,50 @@
assertEquals("div", div.getNodeName());
classAttr = div.getAttributeValue("class");
assertTrue(classAttr.contains("dr-menu-item dr-menu-item-enabled rich-menu-item rich-menu-item-enabled"));
+ classAttr = div.getAttributeValue("onclick");
+ assertNotNull(classAttr);
+ assertTrue(classAttr.length() > 0);
+ classAttr = div.getAttributeValue("onmouseover");
+ assertTrue(classAttr.contains("menuItemSelectStyle"));
}
/**
+ * Test for enabled MenuItem component in "ajax" mode.
+ */
+ public void testEnabledMenuItemAJAXMode() throws Exception
+ {
+ menuItem.setMode(MenuComponent.MODE_AJAX);
+ menuItem.getAttributes().put("style", "menuItemStyle");
+ HtmlPage page = renderView();
+ assertNotNull(page);
+ //System.out.println(page.asXml());
+
+ HtmlElement div = page.getHtmlElementById(menuItem.getClientId(facesContext));
+ assertNotNull(div);
+ String classAttr = div.getAttributeValue("onclick");
+ assertTrue(classAttr.contains("AJAX"));
+ classAttr = div.getAttributeValue("style");
+ assertTrue(classAttr.contains("menuItemStyle"));
+ }
+
+ /**
+ * Test for enabled MenuItem component in "none" mode.
+ */
+ public void testEnabledMenuItemNoneMode() throws Exception
+ {
+ menuItem.setMode(MenuComponent.MODE_NONE);
+ HtmlPage page = renderView();
+ assertNotNull(page);
+ //System.out.println(page.asXml());
+
+ HtmlElement div = page.getHtmlElementById(menuItem.getClientId(facesContext));
+ assertNotNull(div);
+ String classAttr = div.getAttributeValue("onclick");
+ assertNotNull(classAttr);
+ assertTrue(classAttr.length() > 0);
+ }
+
+ /**
* CSS link test.
*/
public void testRenderStyle() throws Exception {
@@ -249,9 +274,9 @@
}
/**
- * doDecode method trst.
+ * DoDecode method trst. Component in "AJAX" mode. Immediate is true.
*/
- public void testMenuItemDoDecode() throws Exception {
+ public void testMenuItemDoDecodeAJAXMode() throws Exception {
menuItem.setImmediate(true);
menuItem.setMode(MenuComponent.MODE_AJAX);
@@ -265,4 +290,21 @@
assertEquals(1, events.size());
}
+ /**
+ * DoDecode method trst. Component in "server" mode. Immediate is false.
+ */
+ public void testMenuItemDoDecodeServerMode() throws Exception {
+
+ menuItem.setImmediate(false);
+ menuItem.setMode(MenuComponent.MODE_SERVER);
+
+ externalContext.getRequestParameterMap().put(menuItem.getClientId(facesContext) + ":hidden", "Action");
+ menuItem.decode(facesContext);
+
+ MockViewRoot mockViewRoot = (MockViewRoot) facesContext.getViewRoot();
+ Buffer events = mockViewRoot.getEventsQueue(facesContext, PhaseId.INVOKE_APPLICATION);
+ assertNotNull(events);
+ assertEquals(1, events.size());
+ }
+
}
Added: trunk/richfaces/menu-components/src/test/java/org/richfaces/renderkit/html/MenuItemRendererBaseTest.java
===================================================================
--- trunk/richfaces/menu-components/src/test/java/org/richfaces/renderkit/html/MenuItemRendererBaseTest.java (rev 0)
+++ trunk/richfaces/menu-components/src/test/java/org/richfaces/renderkit/html/MenuItemRendererBaseTest.java 2007-04-11 12:58:24 UTC (rev 355)
@@ -0,0 +1,127 @@
+/**
+ * License Agreement.
+ *
+ * JBoss RichFaces 3.0 - Ajax4jsf Component Library
+ *
+ * Copyright (C) 2007 Exadel, Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License version 2.1 as published by the Free Software Foundation.
+ *
+ * This library 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 library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+package org.richfaces.renderkit.html;
+
+import javax.faces.component.UIComponent;
+import javax.faces.component.UIComponentBase;
+
+import org.ajax4jsf.tests.AbstractAjax4JsfTestCase;
+import org.richfaces.component.MenuComponent;
+import org.richfaces.component.UIMenuItem;
+import org.richfaces.component.html.HtmlMenuItem;
+
+/**
+ * Unit test for MenuItem renderer.
+ */
+public class MenuItemRendererBaseTest
+ extends AbstractAjax4JsfTestCase
+{
+
+ private UIMenuItem menuItem;
+ private MenuComponent menu;
+ private static MenuItemRendererBase renderer = new MenuItemRendererBase();
+
+ /**
+ * Simple implementation of MenuComponent interfase.
+ */
+ private class MenuComponentImpl extends UIComponentBase implements MenuComponent {
+
+ public String getFamily() {
+ // TODO Auto-generated method stub
+ return null;
+ }
+
+ public String getMode() {
+ return MenuComponent.MODE_AJAX;
+ }
+
+ }
+
+ /**
+ * Create the test case
+ *
+ * @param testName name of the test case
+ */
+ public MenuItemRendererBaseTest(String testName)
+ {
+ super(testName);
+ }
+
+ public void setUp() throws Exception {
+ super.setUp();
+
+ menu = new MenuComponentImpl();
+
+ menuItem = (UIMenuItem) application.createComponent(HtmlMenuItem.COMPONENT_TYPE);
+ menuItem.setId("menuItem");
+ menuItem.setValue("Menu Item");
+
+ ((UIComponent) menu).getChildren().add(menuItem);
+ }
+
+ public void tearDown() throws Exception {
+ super.tearDown();
+ menuItem = null;
+ menu = null;
+ }
+
+ /**
+ * Test for resolveSubmitMode method.
+ */
+ public void testResolveSubmitModeMethod() throws Exception
+ {
+ menuItem.setMode(null);
+ assertEquals(menuItem.getParent(), menu);
+ String resultMode = renderer.resolveSubmitMode(menuItem);
+ assertEquals(resultMode, MenuComponent.MODE_AJAX);
+
+ menuItem.setMode(MenuComponent.MODE_NONE);
+ resultMode = renderer.resolveSubmitMode(menuItem);
+ assertEquals(resultMode, MenuComponent.MODE_NONE);
+ }
+
+ /**
+ * Test for processInlineStyles method.
+ */
+ public void testProcessInlineStylesMethod() throws Exception
+ {
+ String style = "some style";
+ String selectStyle = "some select style";
+ String result = renderer.processInlineStyles(facesContext, menuItem, true);
+ assertEquals(result, "");
+
+ menuItem.getAttributes().put("selectStyle", selectStyle);
+ result = renderer.processInlineStyles(facesContext, menuItem, false);
+ assertTrue(! result.contains(selectStyle));
+ assertTrue(! result.contains(style));
+
+ result = renderer.processInlineStyles(facesContext, menuItem, true);
+ assertTrue(result.contains(selectStyle));
+ assertTrue(! result.contains(style));
+
+ menuItem.getAttributes().put("style", style);
+ result = renderer.processInlineStyles(facesContext, menuItem, true);
+ assertTrue(result.contains(selectStyle));
+ assertTrue(result.contains(style));
+ }
+
+}
More information about the richfaces-svn-commits
mailing list