You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@tiles.apache.org by ap...@apache.org on 2009/03/30 23:45:34 UTC
svn commit: r760193 - in
/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker:
context/FreeMarkerUtilTest.java template/
template/AddAttributeFMModelTest.java
Author: apetrelli
Date: Mon Mar 30 21:45:34 2009
New Revision: 760193
URL: http://svn.apache.org/viewvc?rev=760193&view=rev
Log:
TILES-382
First bunch of new FreeMarker support tests.
Added:
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/context/FreeMarkerUtilTest.java (with props)
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddAttributeFMModelTest.java (with props)
Added: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/context/FreeMarkerUtilTest.java
URL: http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/context/FreeMarkerUtilTest.java?rev=760193&view=auto
==============================================================================
--- tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/context/FreeMarkerUtilTest.java (added)
+++ tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/context/FreeMarkerUtilTest.java Mon Mar 30 21:45:34 2009
@@ -0,0 +1,462 @@
+/**
+ *
+ */
+package org.apache.tiles.freemarker.context;
+
+import static org.junit.Assert.*;
+import static org.easymock.classextension.EasyMock.*;
+import static org.apache.tiles.freemarker.context.FreeMarkerUtil.*;
+
+import java.io.IOException;
+import java.io.StringWriter;
+import java.util.HashMap;
+import java.util.Locale;
+import java.util.Stack;
+
+import javax.servlet.GenericServlet;
+import javax.servlet.ServletContext;
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpSession;
+
+import org.apache.tiles.TilesContainer;
+import org.apache.tiles.freemarker.io.NullWriter;
+import org.apache.tiles.impl.NoSuchContainerException;
+import org.apache.tiles.servlet.context.ServletUtil;
+import org.junit.Before;
+import org.junit.Test;
+
+import freemarker.core.Environment;
+import freemarker.ext.servlet.HttpRequestHashModel;
+import freemarker.ext.servlet.ServletContextHashModel;
+import freemarker.template.ObjectWrapper;
+import freemarker.template.Template;
+import freemarker.template.TemplateDirectiveBody;
+import freemarker.template.TemplateException;
+import freemarker.template.TemplateHashModel;
+import freemarker.template.TemplateModel;
+import freemarker.template.TemplateModelException;
+
+/**
+ * @author antonio
+ *
+ */
+public class FreeMarkerUtilTest {
+
+ /**
+ * A string writer.
+ */
+ private StringWriter writer;
+
+ /**
+ * The FreeMarker environment.
+ */
+ private Environment env;
+
+ /**
+ * The locale object.
+ */
+ private Locale locale;
+
+ /**
+ * The template.
+ */
+ private Template template;
+
+ /**
+ * The template model.
+ */
+ private TemplateHashModel model;
+
+ /**
+ * @throws java.lang.Exception If something goes wrong.
+ */
+ @Before
+ public void setUp() throws Exception {
+ template = createMock(Template.class);
+ model = createMock(TemplateHashModel.class);
+ writer = new StringWriter();
+ expect(template.getMacros()).andReturn(new HashMap<Object, Object>());
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#isForceInclude(freemarker.core.Environment)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testIsForceInclude() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel);
+ expect(request.getAttribute(ServletUtil.FORCE_INCLUDE_ATTRIBUTE_NAME)).andReturn(true);
+
+ replay(template, model, request, objectWrapper);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ assertTrue(isForceInclude(env));
+ verify(template, model, request, objectWrapper);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#setForceInclude(freemarker.core.Environment, boolean)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testSetForceInclude() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel);
+ request.setAttribute(ServletUtil.FORCE_INCLUDE_ATTRIBUTE_NAME, true);
+
+ replay(template, model, request, objectWrapper);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ setForceInclude(env, true);
+ verify(template, model, request, objectWrapper);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#getContainer(freemarker.core.Environment, java.lang.String)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testGetContainer() throws TemplateModelException {
+ GenericServlet servlet = createMock(GenericServlet.class);
+ ServletContext servletContext = createMock(ServletContext.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ TilesContainer container = createMock(TilesContainer.class);
+ expect(servlet.getServletContext()).andReturn(servletContext).times(2);
+ replay(servlet, objectWrapper);
+ ServletContextHashModel servletContextModel = new ServletContextHashModel(servlet, objectWrapper);
+
+ expect(model.get("Application")).andReturn(servletContextModel);
+ expect(servletContext.getAttribute("myKey")).andReturn(container);
+
+ replay(template, model, servletContext, container);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ assertEquals(container, getContainer(env, "myKey"));
+ verify(template, model, servlet, servletContext, objectWrapper, container);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#setCurrentContainer(freemarker.core.Environment, java.lang.String)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testSetCurrentContainerEnvironmentString() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+ GenericServlet servlet = createMock(GenericServlet.class);
+ ServletContext servletContext = createMock(ServletContext.class);
+ TilesContainer container = createMock(TilesContainer.class);
+ expect(servlet.getServletContext()).andReturn(servletContext).times(2);
+ replay(servlet, objectWrapper);
+ ServletContextHashModel servletContextModel = new ServletContextHashModel(servlet, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel);
+ request.setAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME, container);
+ expect(model.get("Application")).andReturn(servletContextModel);
+ expect(servletContext.getAttribute("myKey")).andReturn(container);
+
+ replay(template, model, servletContext, container, request);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ setCurrentContainer(env, "myKey");
+ verify(template, model, servlet, servletContext, objectWrapper, container, request);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#setCurrentContainer(freemarker.core.Environment, java.lang.String)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test(expected = NoSuchContainerException.class)
+ public void testSetCurrentContainerEnvironmentStringException() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+ GenericServlet servlet = createMock(GenericServlet.class);
+ ServletContext servletContext = createMock(ServletContext.class);
+ expect(servlet.getServletContext()).andReturn(servletContext).times(2);
+ replay(servlet, objectWrapper);
+ ServletContextHashModel servletContextModel = new ServletContextHashModel(servlet, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel);
+ expect(model.get("Application")).andReturn(servletContextModel);
+ expect(servletContext.getAttribute("myKey")).andReturn(null);
+
+ replay(template, model, servletContext, request);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ setCurrentContainer(env, "myKey");
+ verify(template, model, servlet, servletContext, objectWrapper, request);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#setCurrentContainer(freemarker.core.Environment, org.apache.tiles.TilesContainer)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testSetCurrentContainerEnvironmentTilesContainer() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+ GenericServlet servlet = createMock(GenericServlet.class);
+ ServletContext servletContext = createMock(ServletContext.class);
+ TilesContainer container = createMock(TilesContainer.class);
+ expect(servlet.getServletContext()).andReturn(servletContext).times(2);
+ replay(servlet, objectWrapper);
+ ServletContextHashModel servletContextModel = new ServletContextHashModel(servlet, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel);
+ request.setAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME, container);
+ expect(model.get("Application")).andReturn(servletContextModel);
+
+ replay(template, model, servletContext, container, request);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ setCurrentContainer(env, container);
+ verify(template, model, servlet, servletContext, objectWrapper, container, request);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#getCurrentContainer(freemarker.core.Environment)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testGetCurrentContainer() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+ GenericServlet servlet = createMock(GenericServlet.class);
+ ServletContext servletContext = createMock(ServletContext.class);
+ TilesContainer container = createMock(TilesContainer.class);
+ expect(servlet.getServletContext()).andReturn(servletContext).times(2);
+ replay(servlet, objectWrapper);
+ ServletContextHashModel servletContextModel = new ServletContextHashModel(servlet, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel);
+ expect(request.getAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME)).andReturn(container);
+ expect(model.get("Application")).andReturn(servletContextModel);
+
+ replay(template, model, servletContext, container, request);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ assertEquals(container, getCurrentContainer(env));
+ verify(template, model, servlet, servletContext, objectWrapper, container, request);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#getRequestHashModel(freemarker.core.Environment)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testGetRequestHashModel() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel);
+
+ replay(template, model, request, objectWrapper);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ assertEquals(requestModel, getRequestHashModel(env));
+ verify(template, model, request, objectWrapper);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#getServletContextHashModel(freemarker.core.Environment)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testGetServletContextHashModel() throws TemplateModelException {
+ GenericServlet servlet = createMock(GenericServlet.class);
+ ServletContext servletContext = createMock(ServletContext.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ expect(servlet.getServletContext()).andReturn(servletContext);
+ replay(servlet, objectWrapper);
+ ServletContextHashModel servletContextModel = new ServletContextHashModel(servlet, objectWrapper);
+
+ expect(model.get("Application")).andReturn(servletContextModel);
+
+ replay(template, model, servletContext);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ assertEquals(servletContextModel, getServletContextHashModel(env));
+ verify(template, model, servlet, servletContext, objectWrapper);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#setAttribute(freemarker.core.Environment, java.lang.String, java.lang.Object, java.lang.String)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testSetAttributePage() throws TemplateModelException {
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ GenericServlet servlet = createMock(GenericServlet.class);
+ TemplateModel wrappedObj = createMock(TemplateModel.class);
+ Integer myObj = new Integer(10);
+ expect(objectWrapper.wrap(myObj)).andReturn(wrappedObj);
+ replay(servlet, objectWrapper);
+
+ expect(template.getObjectWrapper()).andReturn(objectWrapper);
+
+ replay(template, model, wrappedObj);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ setAttribute(env, "myObj", myObj, null);
+ verify(template, model, servlet, objectWrapper, wrappedObj);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#setAttribute(freemarker.core.Environment, java.lang.String, java.lang.Object, java.lang.String)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testSetAttributeRequest() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+ GenericServlet servlet = createMock(GenericServlet.class);
+ TemplateModel wrappedObj = createMock(TemplateModel.class);
+ Integer myObj = new Integer(10);
+ replay(servlet, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel);
+ request.setAttribute("myObj", myObj);
+
+ replay(template, model, wrappedObj, request);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ setAttribute(env, "myObj", myObj, "request");
+ verify(template, model, servlet, objectWrapper, wrappedObj, request);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#setAttribute(freemarker.core.Environment, java.lang.String, java.lang.Object, java.lang.String)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testSetAttributeSession() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ HttpSession session = createMock(HttpSession.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+ GenericServlet servlet = createMock(GenericServlet.class);
+ TemplateModel wrappedObj = createMock(TemplateModel.class);
+ Integer myObj = new Integer(10);
+ replay(servlet, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel);
+ expect(request.getSession()).andReturn(session);
+ session.setAttribute("myObj", myObj);
+
+ replay(template, model, wrappedObj, request, session);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ setAttribute(env, "myObj", myObj, "session");
+ verify(template, model, servlet, objectWrapper, wrappedObj, request, session);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#setAttribute(freemarker.core.Environment, java.lang.String, java.lang.Object, java.lang.String)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testSetAttributeApplication() throws TemplateModelException {
+ ServletContext servletContext = createMock(ServletContext.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ GenericServlet servlet = createMock(GenericServlet.class);
+ expect(servlet.getServletContext()).andReturn(servletContext).times(2);
+ TemplateModel wrappedObj = createMock(TemplateModel.class);
+ Integer myObj = new Integer(10);
+ servletContext.setAttribute("myObj", myObj);
+ replay(servlet, objectWrapper, servletContext);
+ ServletContextHashModel servletContextModel = new ServletContextHashModel(servlet, objectWrapper);
+
+ expect(model.get("Application")).andReturn(servletContextModel);
+
+ replay(template, model, wrappedObj);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ setAttribute(env, "myObj", myObj, "application");
+ verify(template, model, servlet, servletContext, objectWrapper, wrappedObj);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#getComposeStack(freemarker.core.Environment)}.
+ * @throws TemplateModelException If something goes wrong.
+ */
+ @Test
+ public void testGetComposeStack() throws TemplateModelException {
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ ObjectWrapper objectWrapper = createMock(ObjectWrapper.class);
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+ GenericServlet servlet = createMock(GenericServlet.class);
+ TemplateModel wrappedObj = createMock(TemplateModel.class);
+ replay(servlet, objectWrapper);
+
+ expect(model.get("Request")).andReturn(requestModel).times(2);
+ expect(request.getAttribute(COMPOSE_STACK_ATTRIBUTE_NAME)).andReturn(null);
+ request.setAttribute(eq(COMPOSE_STACK_ATTRIBUTE_NAME), isA(Stack.class));
+ Stack<Object> myStack = new Stack<Object>();
+ expect(request.getAttribute(COMPOSE_STACK_ATTRIBUTE_NAME)).andReturn(myStack);
+
+ replay(template, model, wrappedObj, request);
+ env = new Environment(template, model, writer);
+ locale = Locale.ITALY;
+ env.setLocale(locale);
+ assertNotNull(getComposeStack(env));
+ assertEquals(myStack, getComposeStack(env));
+ verify(template, model, servlet, objectWrapper, wrappedObj, request);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#evaluateBody(freemarker.template.TemplateDirectiveBody)}.
+ * @throws IOException If something goes wrong.
+ * @throws TemplateException If something goes wrong.
+ */
+ @Test
+ public void testEvaluateBody() throws TemplateException, IOException {
+ TemplateDirectiveBody body = createMock(TemplateDirectiveBody.class);
+ body.render(isA(NullWriter.class));
+
+ replay(body);
+ evaluateBody(body);
+ verify(body);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.context.FreeMarkerUtil#renderAsString(freemarker.template.TemplateDirectiveBody)}.
+ * @throws IOException If something goes wrong.
+ * @throws TemplateException If something goes wrong.
+ */
+ @Test
+ public void testRenderAsString() throws TemplateException, IOException {
+ TemplateDirectiveBody body = createMock(TemplateDirectiveBody.class);
+ body.render(isA(StringWriter.class));
+
+ replay(body);
+ assertEquals("", renderAsString(body));
+ verify(body);
+ }
+
+}
Propchange: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/context/FreeMarkerUtilTest.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/context/FreeMarkerUtilTest.java
------------------------------------------------------------------------------
svn:keywords = Date Author Id Revision HeadURL
Added: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddAttributeFMModelTest.java
URL: http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddAttributeFMModelTest.java?rev=760193&view=auto
==============================================================================
--- tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddAttributeFMModelTest.java (added)
+++ tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddAttributeFMModelTest.java Mon Mar 30 21:45:34 2009
@@ -0,0 +1,124 @@
+/**
+ *
+ */
+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.http.HttpServletRequest;
+
+import org.apache.tiles.freemarker.context.FreeMarkerUtil;
+import org.apache.tiles.template.AddAttributeModel;
+import org.junit.Before;
+import org.junit.Test;
+
+import freemarker.core.Environment;
+import freemarker.ext.servlet.FreemarkerServlet;
+import freemarker.ext.servlet.HttpRequestHashModel;
+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 AddAttributeFMModelTest {
+
+ /**
+ * 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.AddAttributeFMModel#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 {
+ AddAttributeModel tModel = createMock(AddAttributeModel.class);
+ AddAttributeFMModel fmModel = new AddAttributeFMModel(tModel);
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+
+ HttpRequestHashModel requestModel = new HttpRequestHashModel(request, objectWrapper);
+ expect(model.get(FreemarkerServlet.KEY_REQUEST)).andReturn(requestModel);
+ initEnvironment();
+
+ TemplateDirectiveBody body = createMock(TemplateDirectiveBody.class);
+ Stack<Object> composeStack = new Stack<Object>();
+ Map<String, Object> params = new HashMap<String, Object>();
+ Integer value = new Integer(1);
+ params.put("value", objectWrapper.wrap(value));
+ params.put("expression", objectWrapper.wrap("myExpression"));
+ params.put("role", objectWrapper.wrap("myRole"));
+ params.put("type", objectWrapper.wrap("myType"));
+
+ expect(request.getAttribute(FreeMarkerUtil.COMPOSE_STACK_ATTRIBUTE_NAME)).andReturn(composeStack);
+ tModel.start(composeStack);
+ tModel.end(composeStack, value, "myExpression", "", "myRole", "myType");
+ body.render(isA(StringWriter.class));
+
+ replay(request, tModel, body);
+ fmModel.execute(env, params, null, body);
+ verify(template, model, request, tModel, body);
+ }
+
+ /**
+ * 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/AddAttributeFMModelTest.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddAttributeFMModelTest.java
------------------------------------------------------------------------------
svn:keywords = Date Author Id Revision HeadURL