/*
* $Id: UntypedAttributeRendererTest.java 637434 2008-03-15 15:48:38Z apetrelli $
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.tiles.renderer.impl;
import java.io.IOException;
import java.io.StringWriter;
import org.apache.tiles.Attribute;
import org.apache.tiles.TilesApplicationContext;
import org.apache.tiles.TilesContainer;
import org.apache.tiles.context.TilesContextFactory;
import org.apache.tiles.context.TilesRequestContext;
import org.apache.tiles.evaluator.impl.DirectAttributeEvaluator;
import org.easymock.EasyMock;
import junit.framework.TestCase;
/**
* Tests {@link UntypedAttributeRenderer}.
*
* @version $Rev: 637434 $ $Date: 2008-03-15 16:48:38 +0100 (Sat, 15 Mar 2008) $
*/
public class UntypedAttributeRendererTest extends TestCase {
/**
* The renderer.
*/
private UntypedAttributeRenderer renderer;
/** {@inheritDoc} */
@Override
protected void setUp() throws Exception {
renderer = new UntypedAttributeRenderer();
renderer.setEvaluator(new DirectAttributeEvaluator());
}
/**
* Tests
* {@link StringAttributeRenderer#write(Object, Attribute, java.io.Writer, TilesRequestContext, Object...)}
* writing a Definition.
*
* @throws IOException If something goes wrong during rendition.
*/
public void testWriteDefinition() throws IOException {
StringWriter writer = new StringWriter();
Attribute attribute = new Attribute("my.definition", null, "definition");
TilesApplicationContext applicationContext = EasyMock
.createMock(TilesApplicationContext.class);
TilesContextFactory contextFactory = EasyMock
.createMock(TilesContextFactory.class);
TilesContainer container = EasyMock.createMock(TilesContainer.class);
TilesRequestContext requestContext = EasyMock
.createMock(TilesRequestContext.class);
EasyMock.expect(contextFactory.createRequestContext(applicationContext))
.andReturn(requestContext);
EasyMock.expect(container.isValidDefinition("my.definition"))
.andReturn(Boolean.TRUE);
container.render("my.definition");
EasyMock.replay(applicationContext, contextFactory, requestContext,
container);
renderer.setApplicationContext(applicationContext);
renderer.setContextFactory(contextFactory);
renderer.setContainer(container);
renderer.render(attribute, writer);
writer.close();
}
/**
* Tests
* {@link StringAttributeRenderer#write(Object, Attribute, java.io.Writer, TilesRequestContext, Object...)}
* writing a string.
*
* @throws IOException If something goes wrong during rendition.
*/
public void testWriteString() throws IOException {
StringWriter writer = new StringWriter();
Attribute attribute = new Attribute("Result", null, "string");
TilesApplicationContext applicationContext = EasyMock
.createMock(TilesApplicationContext.class);
TilesContextFactory contextFactory = EasyMock
.createMock(TilesContextFactory.class);
TilesContainer container = EasyMock.createMock(TilesContainer.class);
TilesRequestContext requestContext = EasyMock
.createMock(TilesRequestContext.class);
EasyMock.expect(contextFactory.createRequestContext(applicationContext))
.andReturn(requestContext);
EasyMock.expect(container.isValidDefinition("my.definition"))
.andReturn(Boolean.TRUE);
EasyMock.replay(applicationContext, contextFactory, requestContext);
renderer.setApplicationContext(applicationContext);
renderer.setContextFactory(contextFactory);
renderer.setContainer(container);
renderer.render(attribute, writer);
writer.close();
assertEquals("Not written 'Result'", "Result", writer.toString());
}
/**
* Tests
* {@link StringAttributeRenderer#write(Object, Attribute, java.io.Writer, TilesRequestContext, Object...)}
* writing a template.
*
* @throws IOException If something goes wrong during rendition.
*/
public void testWriteTemplate() throws IOException {
StringWriter writer = new StringWriter();
Attribute attribute = new Attribute("/myTemplate.jsp", null, "template");
TilesApplicationContext applicationContext = EasyMock
.createMock(TilesApplicationContext.class);
TilesContextFactory contextFactory = EasyMock
.createMock(TilesContextFactory.class);
TilesContainer container = EasyMock.createMock(TilesContainer.class);
TilesRequestContext requestContext = EasyMock
.createMock(TilesRequestContext.class);
EasyMock.expect(contextFactory.createRequestContext(applicationContext))
.andReturn(requestContext);
requestContext.dispatch("/myTemplate.jsp");
EasyMock.expect(container.isValidDefinition("my.definition"))
.andReturn(Boolean.TRUE);
EasyMock.replay(applicationContext, contextFactory, requestContext);
renderer.setApplicationContext(applicationContext);
renderer.setContextFactory(contextFactory);
renderer.setContainer(container);
renderer.render(attribute, writer);
writer.close();
}
}