Author: apetrelli
Date: Fri Apr  3 21:39:19 2009
New Revision: 761809

URL: http://svn.apache.org/viewvc?rev=761809&view=rev
Log:
TILES-382
Finished tests for tiles-freemarker.

Added:
    
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertDefinitionFMModelTest.java
   (with props)
    
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertTemplateFMModelTest.java
   (with props)
    
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutAttributeFMModelTest.java
   (with props)
    
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutListAttributeFMModelTest.java
   (with props)
    
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/SetCurrentContainerFMModelTest.java
   (with props)
    
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/TilesFMModelRepositoryTest.java
   (with props)

Added: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertDefinitionFMModelTest.java
URL: 
http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertDefinitionFMModelTest.java?rev=761809&view=auto
==============================================================================
--- 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertDefinitionFMModelTest.java
 (added)
+++ 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertDefinitionFMModelTest.java
 Fri Apr  3 21:39:19 2009
@@ -0,0 +1,140 @@
+/**
+ * 
+ */
+package org.apache.tiles.freemarker.template;
+
+import static org.easymock.classextension.EasyMock.*;
+
+import java.io.IOException;
+import java.io.StringWriter;
+import java.util.HashMap;
+import java.util.Locale;
+import java.util.Map;
+
+import javax.servlet.GenericServlet;
+import javax.servlet.ServletContext;
+import javax.servlet.http.HttpServletRequest;
+
+import org.apache.tiles.Attribute;
+import org.apache.tiles.TilesContainer;
+import org.apache.tiles.access.TilesAccess;
+import org.apache.tiles.freemarker.io.NullWriter;
+import org.apache.tiles.servlet.context.ServletUtil;
+import org.apache.tiles.template.InsertDefinitionModel;
+import org.junit.Before;
+import org.junit.Test;
+
+import freemarker.core.Environment;
+import freemarker.ext.servlet.FreemarkerServlet;
+import freemarker.ext.servlet.HttpRequestHashModel;
+import freemarker.ext.servlet.ServletContextHashModel;
+import freemarker.template.DefaultObjectWrapper;
+import freemarker.template.ObjectWrapper;
+import freemarker.template.Template;
+import freemarker.template.TemplateDirectiveBody;
+import freemarker.template.TemplateException;
+import freemarker.template.TemplateHashModel;
+
+/**
+ * @author antonio
+ *
+ */
+public class InsertDefinitionFMModelTest {
+
+    /**
+     * The FreeMarker environment.
+     */
+    private Environment env;
+    
+    /**
+     * The locale object.
+     */
+    private Locale locale;
+
+    /**
+     * The template.
+     */
+    private Template template;
+
+    /**
+     * The template model.
+     */
+    private TemplateHashModel model;
+    
+    /**
+     * The writer.
+     */
+    private StringWriter writer;
+
+    /**
+     * The object wrapper.
+     */
+    private ObjectWrapper objectWrapper;
+
+    /**
+     * @throws java.lang.Exception If something goes wrong.
+     */
+    @Before
+    public void setUp() throws Exception {
+        template = createMock(Template.class);
+        model = createMock(TemplateHashModel.class);
+        expect(template.getMacros()).andReturn(new HashMap<Object, Object>());
+        writer = new StringWriter();
+        objectWrapper = DefaultObjectWrapper.getDefaultInstance();
+    }
+
+    /**
+     * Test method for {...@link 
org.apache.tiles.freemarker.template.InsertDefinitionFMModel#execute(freemarker.core.Environment,
 java.util.Map, freemarker.template.TemplateModel[], 
freemarker.template.TemplateDirectiveBody)}.
+     * @throws IOException If something goes wrong.
+     * @throws TemplateException If something goes wrong.
+     */
+    @Test
+    public void testExecute() throws TemplateException, IOException {
+        InsertDefinitionModel tModel = createMock(InsertDefinitionModel.class);
+        InsertDefinitionFMModel fmModel = new InsertDefinitionFMModel(tModel);
+        TilesContainer container = createMock(TilesContainer.class);
+
+        HttpServletRequest request = createMock(HttpServletRequest.class);
+        
expect(request.getAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME)).andReturn(null).times(2);
+        request.setAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME, 
container);
+        expectLastCall().times(2);
+        replay(request);
+        HttpRequestHashModel requestModel = new HttpRequestHashModel(request, 
objectWrapper);
+        
+        GenericServlet servlet = createMock(GenericServlet.class);
+        ServletContext servletContext = createMock(ServletContext.class);
+        expect(servlet.getServletContext()).andReturn(servletContext).times(3);
+        
expect(servletContext.getAttribute(TilesAccess.CONTAINER_ATTRIBUTE)).andReturn(container).times(2);
+        replay(servlet, servletContext);
+        ServletContextHashModel servletContextModel = new 
ServletContextHashModel(servlet, objectWrapper);
+        
expect(model.get(FreemarkerServlet.KEY_REQUEST)).andReturn(requestModel).times(2);
+        
expect(model.get(FreemarkerServlet.KEY_APPLICATION)).andReturn(servletContextModel).times(2);
+        initEnvironment();
+
+        TemplateDirectiveBody body = createMock(TemplateDirectiveBody.class);
+        Map<String, Object> params = new HashMap<String, Object>();
+        Attribute attribute = createMock(Attribute.class);
+        params.put("name", objectWrapper.wrap("myName"));
+        params.put("template", objectWrapper.wrap("myTemplate"));
+        params.put("role", objectWrapper.wrap("myRole"));
+        params.put("preparer", objectWrapper.wrap("myPreparer"));
+     
+        tModel.start(container, env);
+        tModel.end(container, "myName", "myTemplate", "myRole", "myPreparer", 
env);
+        body.render(isA(NullWriter.class));
+        
+        replay(tModel, body, container, attribute);
+        fmModel.execute(env, params, null, body);
+        verify(template, model, request, tModel, body, container, servlet, 
servletContext, attribute);
+    }
+
+    /**
+     * Initializes the FreeMarker environment.
+     */
+    private void initEnvironment() {
+        replay(template, model);
+        env = new Environment(template, model, writer);
+        locale = Locale.ITALY;
+        env.setLocale(locale);
+    }
+}

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertDefinitionFMModelTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertDefinitionFMModelTest.java
------------------------------------------------------------------------------
    svn:keywords = Date Author Id Revision HeadURL

Added: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertTemplateFMModelTest.java
URL: 
http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertTemplateFMModelTest.java?rev=761809&view=auto
==============================================================================
--- 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertTemplateFMModelTest.java
 (added)
+++ 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertTemplateFMModelTest.java
 Fri Apr  3 21:39:19 2009
@@ -0,0 +1,140 @@
+/**
+ * 
+ */
+package org.apache.tiles.freemarker.template;
+
+import static org.easymock.classextension.EasyMock.*;
+
+import java.io.IOException;
+import java.io.StringWriter;
+import java.util.HashMap;
+import java.util.Locale;
+import java.util.Map;
+
+import javax.servlet.GenericServlet;
+import javax.servlet.ServletContext;
+import javax.servlet.http.HttpServletRequest;
+
+import org.apache.tiles.Attribute;
+import org.apache.tiles.TilesContainer;
+import org.apache.tiles.access.TilesAccess;
+import org.apache.tiles.freemarker.io.NullWriter;
+import org.apache.tiles.servlet.context.ServletUtil;
+import org.apache.tiles.template.InsertTemplateModel;
+import org.junit.Before;
+import org.junit.Test;
+
+import freemarker.core.Environment;
+import freemarker.ext.servlet.FreemarkerServlet;
+import freemarker.ext.servlet.HttpRequestHashModel;
+import freemarker.ext.servlet.ServletContextHashModel;
+import freemarker.template.DefaultObjectWrapper;
+import freemarker.template.ObjectWrapper;
+import freemarker.template.Template;
+import freemarker.template.TemplateDirectiveBody;
+import freemarker.template.TemplateException;
+import freemarker.template.TemplateHashModel;
+
+/**
+ * @author antonio
+ *
+ */
+public class InsertTemplateFMModelTest {
+
+    /**
+     * The FreeMarker environment.
+     */
+    private Environment env;
+    
+    /**
+     * The locale object.
+     */
+    private Locale locale;
+
+    /**
+     * The template.
+     */
+    private Template template;
+
+    /**
+     * The template model.
+     */
+    private TemplateHashModel model;
+    
+    /**
+     * The writer.
+     */
+    private StringWriter writer;
+
+    /**
+     * The object wrapper.
+     */
+    private ObjectWrapper objectWrapper;
+
+    /**
+     * @throws java.lang.Exception If something goes wrong.
+     */
+    @Before
+    public void setUp() throws Exception {
+        template = createMock(Template.class);
+        model = createMock(TemplateHashModel.class);
+        expect(template.getMacros()).andReturn(new HashMap<Object, Object>());
+        writer = new StringWriter();
+        objectWrapper = DefaultObjectWrapper.getDefaultInstance();
+    }
+
+    /**
+     * Test method for {...@link 
org.apache.tiles.freemarker.template.InsertTemplateFMModel#execute(freemarker.core.Environment,
 java.util.Map, freemarker.template.TemplateModel[], 
freemarker.template.TemplateDirectiveBody)}.
+     * @throws IOException If something goes wrong.
+     * @throws TemplateException If something goes wrong.
+     */
+    @Test
+    public void testExecute() throws TemplateException, IOException {
+        InsertTemplateModel tModel = createMock(InsertTemplateModel.class);
+        InsertTemplateFMModel fmModel = new InsertTemplateFMModel(tModel);
+        TilesContainer container = createMock(TilesContainer.class);
+
+        HttpServletRequest request = createMock(HttpServletRequest.class);
+        
expect(request.getAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME)).andReturn(null).times(2);
+        request.setAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME, 
container);
+        expectLastCall().times(2);
+        request.setAttribute(ServletUtil.FORCE_INCLUDE_ATTRIBUTE_NAME, true);
+        replay(request);
+        HttpRequestHashModel requestModel = new HttpRequestHashModel(request, 
objectWrapper);
+        
+        GenericServlet servlet = createMock(GenericServlet.class);
+        ServletContext servletContext = createMock(ServletContext.class);
+        expect(servlet.getServletContext()).andReturn(servletContext).times(3);
+        
expect(servletContext.getAttribute(TilesAccess.CONTAINER_ATTRIBUTE)).andReturn(container).times(2);
+        replay(servlet, servletContext);
+        ServletContextHashModel servletContextModel = new 
ServletContextHashModel(servlet, objectWrapper);
+        
expect(model.get(FreemarkerServlet.KEY_REQUEST)).andReturn(requestModel).times(3);
+        
expect(model.get(FreemarkerServlet.KEY_APPLICATION)).andReturn(servletContextModel).times(2);
+        initEnvironment();
+
+        TemplateDirectiveBody body = createMock(TemplateDirectiveBody.class);
+        Map<String, Object> params = new HashMap<String, Object>();
+        Attribute attribute = createMock(Attribute.class);
+        params.put("template", objectWrapper.wrap("myTemplate"));
+        params.put("role", objectWrapper.wrap("myRole"));
+        params.put("preparer", objectWrapper.wrap("myPreparer"));
+     
+        tModel.start(container, env);
+        tModel.end(container, "myTemplate", "myRole", "myPreparer", env);
+        body.render(isA(NullWriter.class));
+        
+        replay(tModel, body, container, attribute);
+        fmModel.execute(env, params, null, body);
+        verify(template, model, request, tModel, body, container, servlet, 
servletContext, attribute);
+    }
+
+    /**
+     * Initializes the FreeMarker environment.
+     */
+    private void initEnvironment() {
+        replay(template, model);
+        env = new Environment(template, model, writer);
+        locale = Locale.ITALY;
+        env.setLocale(locale);
+    }
+}

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertTemplateFMModelTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertTemplateFMModelTest.java
------------------------------------------------------------------------------
    svn:keywords = Date Author Id Revision HeadURL

Added: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutAttributeFMModelTest.java
URL: 
http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutAttributeFMModelTest.java?rev=761809&view=auto
==============================================================================
--- 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutAttributeFMModelTest.java
 (added)
+++ 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutAttributeFMModelTest.java
 Fri Apr  3 21:39:19 2009
@@ -0,0 +1,145 @@
+/**
+ * 
+ */
+package org.apache.tiles.freemarker.template;
+
+import static org.easymock.EasyMock.expect;
+import static org.easymock.classextension.EasyMock.*;
+
+import java.io.IOException;
+import java.io.StringWriter;
+import java.util.HashMap;
+import java.util.Locale;
+import java.util.Map;
+import java.util.Stack;
+
+import javax.servlet.GenericServlet;
+import javax.servlet.ServletContext;
+import javax.servlet.http.HttpServletRequest;
+
+import org.apache.tiles.TilesContainer;
+import org.apache.tiles.access.TilesAccess;
+import org.apache.tiles.freemarker.context.FreeMarkerUtil;
+import org.apache.tiles.servlet.context.ServletUtil;
+import org.apache.tiles.template.PutAttributeModel;
+import org.junit.Before;
+import org.junit.Test;
+
+import freemarker.core.Environment;
+import freemarker.ext.servlet.FreemarkerServlet;
+import freemarker.ext.servlet.HttpRequestHashModel;
+import freemarker.ext.servlet.ServletContextHashModel;
+import freemarker.template.DefaultObjectWrapper;
+import freemarker.template.ObjectWrapper;
+import freemarker.template.Template;
+import freemarker.template.TemplateDirectiveBody;
+import freemarker.template.TemplateException;
+import freemarker.template.TemplateHashModel;
+
+/**
+ * @author antonio
+ *
+ */
+public class PutAttributeFMModelTest {
+
+    /**
+     * The FreeMarker environment.
+     */
+    private Environment env;
+    
+    /**
+     * The locale object.
+     */
+    private Locale locale;
+
+    /**
+     * The template.
+     */
+    private Template template;
+
+    /**
+     * The template model.
+     */
+    private TemplateHashModel model;
+    
+    /**
+     * The writer.
+     */
+    private StringWriter writer;
+
+    /**
+     * The object wrapper.
+     */
+    private ObjectWrapper objectWrapper;
+
+    /**
+     * @throws java.lang.Exception If something goes wrong.
+     */
+    @Before
+    public void setUp() throws Exception {
+        template = createMock(Template.class);
+        model = createMock(TemplateHashModel.class);
+        expect(template.getMacros()).andReturn(new HashMap<Object, Object>());
+        writer = new StringWriter();
+        objectWrapper = DefaultObjectWrapper.getDefaultInstance();
+    }
+
+    /**
+     * Test method for {...@link 
org.apache.tiles.freemarker.template.PutAttributeFMModel#execute(freemarker.core.Environment,
 java.util.Map, freemarker.template.TemplateModel[], 
freemarker.template.TemplateDirectiveBody)}.
+     * @throws IOException If something goes wrong.
+     * @throws TemplateException If something goes wrong.
+     */
+    @Test
+    public void testExecute() throws TemplateException, IOException {
+        TilesContainer container = createMock(TilesContainer.class);
+        PutAttributeModel tModel = createMock(PutAttributeModel.class);
+        PutAttributeFMModel fmModel = new PutAttributeFMModel(tModel);
+
+        HttpServletRequest request = createMock(HttpServletRequest.class);
+        Stack<Object> composeStack = new Stack<Object>();
+        
expect(request.getAttribute(FreeMarkerUtil.COMPOSE_STACK_ATTRIBUTE_NAME)).andReturn(composeStack);
+        
expect(request.getAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME)).andReturn(null);
+        request.setAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME, 
container);
+        replay(request);
+        HttpRequestHashModel requestModel = new HttpRequestHashModel(request, 
objectWrapper);
+
+        GenericServlet servlet = createMock(GenericServlet.class);
+        ServletContext servletContext = createMock(ServletContext.class);
+        expect(servlet.getServletContext()).andReturn(servletContext).times(2);
+        
expect(servletContext.getAttribute(TilesAccess.CONTAINER_ATTRIBUTE)).andReturn(container);
+        replay(servlet, servletContext);
+        ServletContextHashModel servletContextModel = new 
ServletContextHashModel(servlet, objectWrapper);
+        
expect(model.get(FreemarkerServlet.KEY_REQUEST)).andReturn(requestModel).times(2);
+        
expect(model.get(FreemarkerServlet.KEY_APPLICATION)).andReturn(servletContextModel);
+        initEnvironment();
+
+        TemplateDirectiveBody body = createMock(TemplateDirectiveBody.class);
+        Map<String, Object> params = new HashMap<String, Object>();
+        Integer value = new Integer(1);
+        params.put("name", objectWrapper.wrap("myName"));
+        params.put("value", objectWrapper.wrap(value));
+        params.put("expression", objectWrapper.wrap("myExpression"));
+        params.put("role", objectWrapper.wrap("myRole"));
+        params.put("type", objectWrapper.wrap("myType"));
+        params.put("cascade", objectWrapper.wrap(false));
+     
+        tModel.start(composeStack);
+        tModel.end(container, composeStack, "myName", value, "myExpression",
+                "", "myRole", "myType", false, env);
+        body.render(isA(StringWriter.class));
+        
+        replay(tModel, body, container);
+        fmModel.execute(env, params, null, body);
+        verify(template, model, request, tModel, body, container);
+    }
+
+    /**
+     * Initializes the FreeMarker environment.
+     */
+    private void initEnvironment() {
+        replay(template, model);
+        env = new Environment(template, model, writer);
+        locale = Locale.ITALY;
+        env.setLocale(locale);
+    }
+}

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutAttributeFMModelTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutAttributeFMModelTest.java
------------------------------------------------------------------------------
    svn:keywords = Date Author Id Revision HeadURL

Added: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutListAttributeFMModelTest.java
URL: 
http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutListAttributeFMModelTest.java?rev=761809&view=auto
==============================================================================
--- 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutListAttributeFMModelTest.java
 (added)
+++ 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutListAttributeFMModelTest.java
 Fri Apr  3 21:39:19 2009
@@ -0,0 +1,141 @@
+/**
+ * 
+ */
+package org.apache.tiles.freemarker.template;
+
+import static org.easymock.classextension.EasyMock.*;
+
+import java.io.IOException;
+import java.io.StringWriter;
+import java.util.HashMap;
+import java.util.Locale;
+import java.util.Map;
+import java.util.Stack;
+
+import javax.servlet.GenericServlet;
+import javax.servlet.ServletContext;
+import javax.servlet.http.HttpServletRequest;
+
+import org.apache.tiles.TilesContainer;
+import org.apache.tiles.access.TilesAccess;
+import org.apache.tiles.freemarker.context.FreeMarkerUtil;
+import org.apache.tiles.freemarker.io.NullWriter;
+import org.apache.tiles.servlet.context.ServletUtil;
+import org.apache.tiles.template.PutListAttributeModel;
+import org.junit.Before;
+import org.junit.Test;
+
+import freemarker.core.Environment;
+import freemarker.ext.servlet.FreemarkerServlet;
+import freemarker.ext.servlet.HttpRequestHashModel;
+import freemarker.ext.servlet.ServletContextHashModel;
+import freemarker.template.DefaultObjectWrapper;
+import freemarker.template.ObjectWrapper;
+import freemarker.template.Template;
+import freemarker.template.TemplateDirectiveBody;
+import freemarker.template.TemplateException;
+import freemarker.template.TemplateHashModel;
+
+/**
+ * @author antonio
+ *
+ */
+public class PutListAttributeFMModelTest {
+
+    /**
+     * The FreeMarker environment.
+     */
+    private Environment env;
+    
+    /**
+     * The locale object.
+     */
+    private Locale locale;
+
+    /**
+     * The template.
+     */
+    private Template template;
+
+    /**
+     * The template model.
+     */
+    private TemplateHashModel model;
+    
+    /**
+     * The writer.
+     */
+    private StringWriter writer;
+
+    /**
+     * The object wrapper.
+     */
+    private ObjectWrapper objectWrapper;
+
+    /**
+     * @throws java.lang.Exception If something goes wrong.
+     */
+    @Before
+    public void setUp() throws Exception {
+        template = createMock(Template.class);
+        model = createMock(TemplateHashModel.class);
+        expect(template.getMacros()).andReturn(new HashMap<Object, Object>());
+        writer = new StringWriter();
+        objectWrapper = DefaultObjectWrapper.getDefaultInstance();
+    }
+
+    /**
+     * Test method for {...@link 
org.apache.tiles.freemarker.template.PutListAttributeFMModel#execute(freemarker.core.Environment,
 java.util.Map, freemarker.template.TemplateModel[], 
freemarker.template.TemplateDirectiveBody)}.
+     * @throws IOException If something goes wrong.
+     * @throws TemplateException If something goes wrong.
+     */
+    @Test
+    public void testExecute() throws TemplateException, IOException {
+        TilesContainer container = createMock(TilesContainer.class);
+        PutListAttributeModel tModel = createMock(PutListAttributeModel.class);
+        PutListAttributeFMModel fmModel = new PutListAttributeFMModel(tModel);
+
+        HttpServletRequest request = createMock(HttpServletRequest.class);
+        Stack<Object> composeStack = new Stack<Object>();
+        
expect(request.getAttribute(FreeMarkerUtil.COMPOSE_STACK_ATTRIBUTE_NAME)).andReturn(composeStack);
+        
expect(request.getAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME)).andReturn(null);
+        request.setAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME, 
container);
+        replay(request);
+        HttpRequestHashModel requestModel = new HttpRequestHashModel(request, 
objectWrapper);
+
+        GenericServlet servlet = createMock(GenericServlet.class);
+        ServletContext servletContext = createMock(ServletContext.class);
+        expect(servlet.getServletContext()).andReturn(servletContext).times(2);
+        
expect(servletContext.getAttribute(TilesAccess.CONTAINER_ATTRIBUTE)).andReturn(container);
+        replay(servlet, servletContext);
+        ServletContextHashModel servletContextModel = new 
ServletContextHashModel(servlet, objectWrapper);
+        
expect(model.get(FreemarkerServlet.KEY_REQUEST)).andReturn(requestModel).times(2);
+        
expect(model.get(FreemarkerServlet.KEY_APPLICATION)).andReturn(servletContextModel);
+        initEnvironment();
+
+        TemplateDirectiveBody body = createMock(TemplateDirectiveBody.class);
+        Map<String, Object> params = new HashMap<String, Object>();
+        params.put("name", objectWrapper.wrap("myName"));
+        params.put("role", objectWrapper.wrap("myRole"));
+        params.put("inherit", objectWrapper.wrap(false));
+        params.put("cascade", objectWrapper.wrap(false));
+     
+        tModel.start(composeStack, "myRole", false);
+        tModel.end(container, composeStack, "myName", false, env);
+        body.render(isA(NullWriter.class));
+        
+        replay(tModel, body, container);
+        fmModel.execute(env, params, null, body);
+        verify(template, model, request, tModel, body, container);
+    }
+
+    /**
+     * Initializes the FreeMarker environment.
+     */
+    private void initEnvironment() {
+        replay(template, model);
+        env = new Environment(template, model, writer);
+        locale = Locale.ITALY;
+        env.setLocale(locale);
+    }
+}

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutListAttributeFMModelTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/PutListAttributeFMModelTest.java
------------------------------------------------------------------------------
    svn:keywords = Date Author Id Revision HeadURL

Added: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/SetCurrentContainerFMModelTest.java
URL: 
http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/SetCurrentContainerFMModelTest.java?rev=761809&view=auto
==============================================================================
--- 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/SetCurrentContainerFMModelTest.java
 (added)
+++ 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/SetCurrentContainerFMModelTest.java
 Fri Apr  3 21:39:19 2009
@@ -0,0 +1,127 @@
+/**
+ * 
+ */
+package org.apache.tiles.freemarker.template;
+
+import static org.easymock.classextension.EasyMock.*;
+
+import java.io.IOException;
+import java.io.StringWriter;
+import java.util.HashMap;
+import java.util.Locale;
+import java.util.Map;
+
+import javax.servlet.GenericServlet;
+import javax.servlet.ServletContext;
+import javax.servlet.http.HttpServletRequest;
+
+import org.apache.tiles.Attribute;
+import org.apache.tiles.TilesContainer;
+import org.apache.tiles.servlet.context.ServletUtil;
+import org.junit.Before;
+import org.junit.Test;
+
+import freemarker.core.Environment;
+import freemarker.ext.servlet.FreemarkerServlet;
+import freemarker.ext.servlet.HttpRequestHashModel;
+import freemarker.ext.servlet.ServletContextHashModel;
+import freemarker.template.DefaultObjectWrapper;
+import freemarker.template.ObjectWrapper;
+import freemarker.template.Template;
+import freemarker.template.TemplateDirectiveBody;
+import freemarker.template.TemplateException;
+import freemarker.template.TemplateHashModel;
+
+/**
+ * @author antonio
+ *
+ */
+public class SetCurrentContainerFMModelTest {
+
+    /**
+     * The FreeMarker environment.
+     */
+    private Environment env;
+    
+    /**
+     * The locale object.
+     */
+    private Locale locale;
+
+    /**
+     * The template.
+     */
+    private Template template;
+
+    /**
+     * The template model.
+     */
+    private TemplateHashModel model;
+    
+    /**
+     * The writer.
+     */
+    private StringWriter writer;
+
+    /**
+     * The object wrapper.
+     */
+    private ObjectWrapper objectWrapper;
+
+    /**
+     * @throws java.lang.Exception If something goes wrong.
+     */
+    @Before
+    public void setUp() throws Exception {
+        template = createMock(Template.class);
+        model = createMock(TemplateHashModel.class);
+        expect(template.getMacros()).andReturn(new HashMap<Object, Object>());
+        writer = new StringWriter();
+        objectWrapper = DefaultObjectWrapper.getDefaultInstance();
+    }
+
+    /**
+     * Test method for {...@link 
org.apache.tiles.freemarker.template.SetCurrentContainerFMModel#execute(freemarker.core.Environment,
 java.util.Map, freemarker.template.TemplateModel[], 
freemarker.template.TemplateDirectiveBody)}.
+     * @throws IOException If something goes wrong.
+     * @throws TemplateException If something goes wrong.
+     */
+    @Test
+    public void testExecute() throws TemplateException, IOException {
+        SetCurrentContainerFMModel fmModel = new SetCurrentContainerFMModel();
+        TilesContainer container = createMock(TilesContainer.class);
+
+        HttpServletRequest request = createMock(HttpServletRequest.class);
+        request.setAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME, 
container);
+        replay(request);
+        HttpRequestHashModel requestModel = new HttpRequestHashModel(request, 
objectWrapper);
+        
+        GenericServlet servlet = createMock(GenericServlet.class);
+        ServletContext servletContext = createMock(ServletContext.class);
+        expect(servlet.getServletContext()).andReturn(servletContext).times(2);
+        
expect(servletContext.getAttribute("myContainerKey")).andReturn(container);
+        replay(servlet, servletContext);
+        ServletContextHashModel servletContextModel = new 
ServletContextHashModel(servlet, objectWrapper);
+        
expect(model.get(FreemarkerServlet.KEY_REQUEST)).andReturn(requestModel);
+        
expect(model.get(FreemarkerServlet.KEY_APPLICATION)).andReturn(servletContextModel);
+        initEnvironment();
+
+        TemplateDirectiveBody body = createMock(TemplateDirectiveBody.class);
+        Map<String, Object> params = new HashMap<String, Object>();
+        Attribute attribute = createMock(Attribute.class);
+        params.put("containerKey", objectWrapper.wrap("myContainerKey"));
+        
+        replay(body, container, attribute);
+        fmModel.execute(env, params, null, body);
+        verify(template, model, request, body, container, servlet, 
servletContext, attribute);
+    }
+
+    /**
+     * Initializes the FreeMarker environment.
+     */
+    private void initEnvironment() {
+        replay(template, model);
+        env = new Environment(template, model, writer);
+        locale = Locale.ITALY;
+        env.setLocale(locale);
+    }
+}

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/SetCurrentContainerFMModelTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/SetCurrentContainerFMModelTest.java
------------------------------------------------------------------------------
    svn:keywords = Date Author Id Revision HeadURL

Added: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/TilesFMModelRepositoryTest.java
URL: 
http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/TilesFMModelRepositoryTest.java?rev=761809&view=auto
==============================================================================
--- 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/TilesFMModelRepositoryTest.java
 (added)
+++ 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/TilesFMModelRepositoryTest.java
 Fri Apr  3 21:39:19 2009
@@ -0,0 +1,35 @@
+/**
+ * 
+ */
+package org.apache.tiles.freemarker.template;
+
+import static org.junit.Assert.*;
+
+import org.junit.Test;
+
+/**
+ * @author antonio
+ *
+ */
+public class TilesFMModelRepositoryTest {
+
+    /**
+     * Test method for {...@link 
org.apache.tiles.freemarker.template.TilesFMModelRepository#TilesFMModelRepository()}.
+     */
+    @Test
+    public void testTilesFMModelRepository() {
+        TilesFMModelRepository repository = new TilesFMModelRepository();
+        assertNotNull(repository.getAddAttribute());
+        assertNotNull(repository.getAddListAttribute());
+        assertNotNull(repository.getDefinition());
+        assertNotNull(repository.getGetAsString());
+        assertNotNull(repository.getImportAttribute());
+        assertNotNull(repository.getInsertAttribute());
+        assertNotNull(repository.getInsertDefinition());
+        assertNotNull(repository.getInsertTemplate());
+        assertNotNull(repository.getPutAttribute());
+        assertNotNull(repository.getPutListAttribute());
+        assertNotNull(repository.getSetCurrentContainer());
+    }
+
+}

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/TilesFMModelRepositoryTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/TilesFMModelRepositoryTest.java
------------------------------------------------------------------------------
    svn:keywords = Date Author Id Revision HeadURL


Reply via email to