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/04/03 00:02:26 UTC
svn commit: r761441 -
/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/
Author: apetrelli
Date: Thu Apr 2 22:02:23 2009
New Revision: 761441
URL: http://svn.apache.org/viewvc?rev=761441&view=rev
Log:
TILES-382
Second bunch of new FreeMarker support tests.
Added:
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddListAttributeFMModelTest.java (with props)
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/DefinitionFMModelTest.java (with props)
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/GetAsStringFMModelTest.java (with props)
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/ImportAttributeFMModelTest.java (with props)
tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertAttributeFMModelTest.java (with props)
Added: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddListAttributeFMModelTest.java
URL: http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddListAttributeFMModelTest.java?rev=761441&view=auto
==============================================================================
--- tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddListAttributeFMModelTest.java (added)
+++ tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddListAttributeFMModelTest.java Thu Apr 2 22:02:23 2009
@@ -0,0 +1,120 @@
+/**
+ *
+ */
+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.http.HttpServletRequest;
+
+import org.apache.tiles.freemarker.context.FreeMarkerUtil;
+import org.apache.tiles.freemarker.io.NullWriter;
+import org.apache.tiles.template.AddListAttributeModel;
+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 AddListAttributeFMModelTest {
+
+ /**
+ * 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.AddListAttributeFMModel#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 {
+ AddListAttributeModel tModel = createMock(AddListAttributeModel.class);
+ AddListAttributeFMModel fmModel = new AddListAttributeFMModel(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>();
+ params.put("role", objectWrapper.wrap("myRole"));
+
+ expect(request.getAttribute(FreeMarkerUtil.COMPOSE_STACK_ATTRIBUTE_NAME)).andReturn(composeStack);
+ tModel.start(composeStack, "myRole");
+ tModel.end(composeStack);
+ body.render(isA(NullWriter.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/AddListAttributeFMModelTest.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/AddListAttributeFMModelTest.java
------------------------------------------------------------------------------
svn:keywords = Date Author Id Revision HeadURL
Added: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/DefinitionFMModelTest.java
URL: http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/DefinitionFMModelTest.java?rev=761441&view=auto
==============================================================================
--- tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/DefinitionFMModelTest.java (added)
+++ tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/DefinitionFMModelTest.java Thu Apr 2 22:02:23 2009
@@ -0,0 +1,142 @@
+/**
+ *
+ */
+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.access.TilesAccess;
+import org.apache.tiles.freemarker.context.FreeMarkerUtil;
+import org.apache.tiles.freemarker.io.NullWriter;
+import org.apache.tiles.mgmt.MutableTilesContainer;
+import org.apache.tiles.servlet.context.ServletUtil;
+import org.apache.tiles.template.DefinitionModel;
+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 DefinitionFMModelTest {
+
+ /**
+ * 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.DefinitionFMModel#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 {
+ DefinitionModel tModel = createMock(DefinitionModel.class);
+ DefinitionFMModel fmModel = new DefinitionFMModel(tModel);
+ MutableTilesContainer container = createMock(MutableTilesContainer.class);
+
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ Stack<Object> composeStack = new Stack<Object>();
+ expect(request.getAttribute(FreeMarkerUtil.COMPOSE_STACK_ATTRIBUTE_NAME)).andReturn(composeStack).times(2);
+ 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(3);
+ 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("template", objectWrapper.wrap("myTemplate"));
+ params.put("role", objectWrapper.wrap("myRole"));
+ params.put("extends", objectWrapper.wrap("myExtends"));
+ params.put("preparer", objectWrapper.wrap("myPreparer"));
+
+ tModel.start(composeStack, "myName", "myTemplate", "myRole", "myExtends", "myPreparer");
+ tModel.end(container, composeStack, env);
+ body.render(isA(NullWriter.class));
+
+ replay(tModel, body, container);
+ fmModel.execute(env, params, null, body);
+ verify(template, model, request, tModel, body, container, servlet, servletContext);
+ }
+
+ /**
+ * 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/DefinitionFMModelTest.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/DefinitionFMModelTest.java
------------------------------------------------------------------------------
svn:keywords = Date Author Id Revision HeadURL
Added: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/GetAsStringFMModelTest.java
URL: http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/GetAsStringFMModelTest.java?rev=761441&view=auto
==============================================================================
--- tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/GetAsStringFMModelTest.java (added)
+++ tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/GetAsStringFMModelTest.java Thu Apr 2 22:02:23 2009
@@ -0,0 +1,147 @@
+/**
+ *
+ */
+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.Attribute;
+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.GetAsStringModel;
+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 GetAsStringFMModelTest {
+
+ /**
+ * 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.GetAsStringFMModel#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 {
+ GetAsStringModel tModel = createMock(GetAsStringModel.class);
+ GetAsStringFMModel fmModel = new GetAsStringFMModel(tModel);
+ TilesContainer container = createMock(TilesContainer.class);
+
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ Stack<Object> composeStack = new Stack<Object>();
+ expect(request.getAttribute(FreeMarkerUtil.COMPOSE_STACK_ATTRIBUTE_NAME)).andReturn(composeStack).times(2);
+ 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(3);
+ 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("preparer", objectWrapper.wrap("myPreparer"));
+ params.put("role", objectWrapper.wrap("myRole"));
+ params.put("defaultValue", objectWrapper.wrap("myDefaultValue"));
+ params.put("defaultValueRole", objectWrapper.wrap("myDefaultValueRole"));
+ params.put("defaultValueType", objectWrapper.wrap("myDefaultValueType"));
+ params.put("name", objectWrapper.wrap("myName"));
+ params.put("value", objectWrapper.wrap(attribute));
+
+ tModel.start(composeStack, container, false, "myPreparer", "myRole", "myDefaultValue", "myDefaultValueRole",
+ "myDefaultValueType", "myName", attribute, env);
+ tModel.end(composeStack, container, writer, false, 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/GetAsStringFMModelTest.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/GetAsStringFMModelTest.java
------------------------------------------------------------------------------
svn:keywords = Date Author Id Revision HeadURL
Added: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/ImportAttributeFMModelTest.java
URL: http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/ImportAttributeFMModelTest.java?rev=761441&view=auto
==============================================================================
--- tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/ImportAttributeFMModelTest.java (added)
+++ tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/ImportAttributeFMModelTest.java Thu Apr 2 22:02:23 2009
@@ -0,0 +1,291 @@
+/**
+ *
+ */
+package org.apache.tiles.freemarker.template;
+
+import static org.easymock.classextension.EasyMock.*;
+import static org.junit.Assert.*;
+
+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 javax.servlet.http.HttpSession;
+
+import org.apache.tiles.Attribute;
+import org.apache.tiles.TilesContainer;
+import org.apache.tiles.access.TilesAccess;
+import org.apache.tiles.servlet.context.ServletUtil;
+import org.apache.tiles.template.ImportAttributeModel;
+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;
+import freemarker.template.utility.DeepUnwrap;
+
+/**
+ * @author antonio
+ *
+ */
+public class ImportAttributeFMModelTest {
+
+ /**
+ * 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.ImportAttributeFMModel#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 {
+ ImportAttributeModel tModel = createMock(ImportAttributeModel.class);
+ ImportAttributeFMModel fmModel = new ImportAttributeFMModel(tModel);
+ TilesContainer container = createMock(TilesContainer.class);
+
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ 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);
+ expect(model.get(FreemarkerServlet.KEY_APPLICATION)).andReturn(servletContextModel);
+ expect(template.getObjectWrapper()).andReturn(objectWrapper).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("toName", objectWrapper.wrap("myToName"));
+ params.put("ignore", objectWrapper.wrap(false));
+
+ Map<String, Object> attributes = new HashMap<String, Object>();
+ attributes.put("one", "value1");
+ attributes.put("two", "value2");
+ expect(tModel.getImportedAttributes(container, "myName", "myToName",
+ false, env)).andReturn(attributes);
+
+ replay(tModel, body, container, attribute);
+ fmModel.execute(env, params, null, body);
+ assertEquals("value1", DeepUnwrap.unwrap(env.getCurrentNamespace().get("one")));
+ assertEquals("value2", DeepUnwrap.unwrap(env.getCurrentNamespace().get("two")));
+ verify(template, model, request, tModel, body, container, servlet, servletContext, attribute);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.template.ImportAttributeFMModel#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 testExecuteRequest() throws TemplateException, IOException {
+ ImportAttributeModel tModel = createMock(ImportAttributeModel.class);
+ ImportAttributeFMModel fmModel = new ImportAttributeFMModel(tModel);
+ TilesContainer container = createMock(TilesContainer.class);
+
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ expect(request.getAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME)).andReturn(null);
+ request.setAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME, container);
+ request.setAttribute("one", "value1");
+ request.setAttribute("two", "value2");
+ 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(3);
+ 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("name", objectWrapper.wrap("myName"));
+ params.put("toName", objectWrapper.wrap("myToName"));
+ params.put("ignore", objectWrapper.wrap(false));
+ params.put("scope", objectWrapper.wrap("request"));
+
+ Map<String, Object> attributes = new HashMap<String, Object>();
+ attributes.put("one", "value1");
+ attributes.put("two", "value2");
+ expect(tModel.getImportedAttributes(container, "myName", "myToName",
+ false, env)).andReturn(attributes);
+
+ replay(tModel, body, container, attribute);
+ fmModel.execute(env, params, null, body);
+ verify(template, model, request, tModel, body, container, servlet, servletContext, attribute);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.template.ImportAttributeFMModel#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 testExecuteSession() throws TemplateException, IOException {
+ ImportAttributeModel tModel = createMock(ImportAttributeModel.class);
+ ImportAttributeFMModel fmModel = new ImportAttributeFMModel(tModel);
+ TilesContainer container = createMock(TilesContainer.class);
+
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ HttpSession session = createMock(HttpSession.class);
+ expect(request.getSession()).andReturn(session).times(2);
+ expect(request.getAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME)).andReturn(null);
+ request.setAttribute(ServletUtil.CURRENT_CONTAINER_ATTRIBUTE_NAME, container);
+ session.setAttribute("one", "value1");
+ session.setAttribute("two", "value2");
+ replay(request, session);
+ 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(3);
+ 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("name", objectWrapper.wrap("myName"));
+ params.put("toName", objectWrapper.wrap("myToName"));
+ params.put("ignore", objectWrapper.wrap(false));
+ params.put("scope", objectWrapper.wrap("session"));
+
+ Map<String, Object> attributes = new HashMap<String, Object>();
+ attributes.put("one", "value1");
+ attributes.put("two", "value2");
+ expect(tModel.getImportedAttributes(container, "myName", "myToName",
+ false, env)).andReturn(attributes);
+
+ replay(tModel, body, container, attribute);
+ fmModel.execute(env, params, null, body);
+ verify(template, model, request, session, tModel, body, container, servlet, servletContext, attribute);
+ }
+
+ /**
+ * Test method for {@link org.apache.tiles.freemarker.template.ImportAttributeFMModel#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 testExecuteApplication() throws TemplateException, IOException {
+ ImportAttributeModel tModel = createMock(ImportAttributeModel.class);
+ ImportAttributeFMModel fmModel = new ImportAttributeFMModel(tModel);
+ TilesContainer container = createMock(TilesContainer.class);
+
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ 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(4);
+ expect(servletContext.getAttribute(TilesAccess.CONTAINER_ATTRIBUTE)).andReturn(container);
+ servletContext.setAttribute("one", "value1");
+ servletContext.setAttribute("two", "value2");
+ 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).times(3);
+ 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("toName", objectWrapper.wrap("myToName"));
+ params.put("ignore", objectWrapper.wrap(false));
+ params.put("scope", objectWrapper.wrap("application"));
+
+ Map<String, Object> attributes = new HashMap<String, Object>();
+ attributes.put("one", "value1");
+ attributes.put("two", "value2");
+ expect(tModel.getImportedAttributes(container, "myName", "myToName",
+ false, env)).andReturn(attributes);
+
+ 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/ImportAttributeFMModelTest.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/ImportAttributeFMModelTest.java
------------------------------------------------------------------------------
svn:keywords = Date Author Id Revision HeadURL
Added: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertAttributeFMModelTest.java
URL: http://svn.apache.org/viewvc/tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertAttributeFMModelTest.java?rev=761441&view=auto
==============================================================================
--- tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertAttributeFMModelTest.java (added)
+++ tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertAttributeFMModelTest.java Thu Apr 2 22:02:23 2009
@@ -0,0 +1,147 @@
+/**
+ *
+ */
+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.Attribute;
+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.InsertAttributeModel;
+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 InsertAttributeFMModelTest {
+
+ /**
+ * 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.InsertAttributeFMModel#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 {
+ InsertAttributeModel tModel = createMock(InsertAttributeModel.class);
+ InsertAttributeFMModel fmModel = new InsertAttributeFMModel(tModel);
+ TilesContainer container = createMock(TilesContainer.class);
+
+ HttpServletRequest request = createMock(HttpServletRequest.class);
+ Stack<Object> composeStack = new Stack<Object>();
+ expect(request.getAttribute(FreeMarkerUtil.COMPOSE_STACK_ATTRIBUTE_NAME)).andReturn(composeStack).times(2);
+ 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(3);
+ 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("preparer", objectWrapper.wrap("myPreparer"));
+ params.put("role", objectWrapper.wrap("myRole"));
+ params.put("defaultValue", objectWrapper.wrap("myDefaultValue"));
+ params.put("defaultValueRole", objectWrapper.wrap("myDefaultValueRole"));
+ params.put("defaultValueType", objectWrapper.wrap("myDefaultValueType"));
+ params.put("name", objectWrapper.wrap("myName"));
+ params.put("value", objectWrapper.wrap(attribute));
+
+ tModel.start(composeStack, container, false, "myPreparer", "myRole", "myDefaultValue", "myDefaultValueRole",
+ "myDefaultValueType", "myName", attribute, env);
+ tModel.end(composeStack, container, false, 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/InsertAttributeFMModelTest.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tiles/framework/trunk/tiles-freemarker/src/test/java/org/apache/tiles/freemarker/template/InsertAttributeFMModelTest.java
------------------------------------------------------------------------------
svn:keywords = Date Author Id Revision HeadURL