Test case for https://issues.apache.org/bugzilla/show_bug.cgi?id=49345
authormarkt <markt@13f79535-47bb-0310-9956-ffa450edef68>
Mon, 31 May 2010 17:29:17 +0000 (17:29 +0000)
committermarkt <markt@13f79535-47bb-0310-9956-ffa450edef68>
Mon, 31 May 2010 17:29:17 +0000 (17:29 +0000)
Fix to follow

git-svn-id: https://svn.apache.org/repos/asf/tomcat/trunk@949808 13f79535-47bb-0310-9956-ffa450edef68

test/org/apache/el/TestValueExpressionImpl.java

index 481aff7..3238910 100644 (file)
@@ -53,4 +53,32 @@ public class TestValueExpressionImpl extends TestCase {
         assertEquals("name", vr.getProperty());
     }
 
+    public void testBug49345() {
+        ExpressionFactory factory = ExpressionFactory.newInstance();
+        ELContext context = new ELContextImpl();
+        
+        TesterBeanA beanA = new TesterBeanA();
+        TesterBeanB beanB = new TesterBeanB();
+        beanB.setName("Tomcat");
+        beanA.setBean(beanB);
+        
+        ValueExpression var =
+            factory.createValueExpression(beanA, TesterBeanA.class);
+        context.getVariableMapper().setVariable("beanA", var);
+
+        ValueExpression ve = factory.createValueExpression(
+                context, "${beanA.bean.name}", String.class);
+
+        // First check the basics work
+        String result = (String) ve.getValue(context);
+        assertEquals("Tomcat", result);
+        
+        // Now check the value reference
+        ValueReference vr = ve.getValueReference(context);
+        assertNotNull(vr);
+        
+        assertEquals(beanB, vr.getBase());
+        assertEquals("name", vr.getProperty());
+    }
 }