[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