diff options
Diffstat (limited to 'velocity-engine-core/src/test/java/org/apache/velocity/test/IncludeEventHandlingTestCase.java')
-rw-r--r-- | velocity-engine-core/src/test/java/org/apache/velocity/test/IncludeEventHandlingTestCase.java | 250 |
1 files changed, 250 insertions, 0 deletions
diff --git a/velocity-engine-core/src/test/java/org/apache/velocity/test/IncludeEventHandlingTestCase.java b/velocity-engine-core/src/test/java/org/apache/velocity/test/IncludeEventHandlingTestCase.java new file mode 100644 index 00000000..720ffc5c --- /dev/null +++ b/velocity-engine-core/src/test/java/org/apache/velocity/test/IncludeEventHandlingTestCase.java @@ -0,0 +1,250 @@ +package org.apache.velocity.test; + +/* + * 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. + */ + +import junit.framework.Test; +import junit.framework.TestSuite; +import org.apache.velocity.Template; +import org.apache.velocity.VelocityContext; +import org.apache.velocity.app.Velocity; +import org.apache.velocity.app.event.EventCartridge; +import org.apache.velocity.app.event.IncludeEventHandler; +import org.apache.velocity.context.Context; +import org.apache.velocity.runtime.RuntimeServices; +import org.apache.velocity.runtime.RuntimeSingleton; +import org.apache.velocity.test.misc.TestLogger; +import org.apache.velocity.util.RuntimeServicesAware; + +import java.io.BufferedWriter; +import java.io.FileOutputStream; +import java.io.OutputStreamWriter; +import java.io.Writer; + +/** + * Tests event handling + * + * @author <a href="mailto:geirm@optonline.net">Geir Magnusson Jr.</a> + * @version $Id$ + */ +public class IncludeEventHandlingTestCase extends BaseTestCase implements IncludeEventHandler,RuntimeServicesAware +{ + + /** + * VTL file extension. + */ + private static final String TMPL_FILE_EXT = "vm"; + + /** + * Comparison file extension. + */ + private static final String CMP_FILE_EXT = "cmp"; + + /** + * Comparison file extension. + */ + private static final String RESULT_FILE_EXT = "res"; + + /** + * Path for templates. This property will override the + * value in the default velocity properties file. + */ + private final static String FILE_RESOURCE_LOADER_PATH = TEST_COMPARE_DIR + "/includeevent"; + + /** + * Results relative to the build directory. + */ + private static final String RESULTS_DIR = TEST_RESULT_DIR + "/includeevent"; + + /** + * Results relative to the build directory. + */ + private static final String COMPARE_DIR = TEST_COMPARE_DIR + "/includeevent/compare"; + + + private static final int PASS_THROUGH=0; + private static final int RELATIVE_PATH=1; + private static final int BLOCK=2; + + private int EventHandlerBehavior = PASS_THROUGH; + + /** + * Default constructor. + */ + public IncludeEventHandlingTestCase(String name) + { + super(name); + } + + @Override + public void setUp() + throws Exception + { + assureResultsDirectoryExists(RESULTS_DIR); + + Velocity.reset(); + Velocity.addProperty( + Velocity.FILE_RESOURCE_LOADER_PATH, FILE_RESOURCE_LOADER_PATH); + + Velocity.setProperty( + Velocity.RUNTIME_LOG_INSTANCE, new TestLogger()); + + Velocity.init(); + + + } + + + public static Test suite () + { + return new TestSuite(IncludeEventHandlingTestCase.class); + } + + /** + * Runs the test. + */ + public void testIncludeEventHandling () + throws Exception + { + Template template1 = RuntimeSingleton.getTemplate( + getFileName(null, "test1", TMPL_FILE_EXT)); + + Template template2 = RuntimeSingleton.getTemplate( + getFileName(null, "subdir/test2", TMPL_FILE_EXT)); + + Template template3 = RuntimeSingleton.getTemplate( + getFileName(null, "test3", TMPL_FILE_EXT)); + + FileOutputStream fos1 = + new FileOutputStream ( + getFileName(RESULTS_DIR, "test1", RESULT_FILE_EXT)); + + FileOutputStream fos2 = + new FileOutputStream ( + getFileName(RESULTS_DIR, "test2", RESULT_FILE_EXT)); + + FileOutputStream fos3 = + new FileOutputStream ( + getFileName(RESULTS_DIR, "test3", RESULT_FILE_EXT)); + + Writer writer1 = new BufferedWriter(new OutputStreamWriter(fos1)); + Writer writer2 = new BufferedWriter(new OutputStreamWriter(fos2)); + Writer writer3 = new BufferedWriter(new OutputStreamWriter(fos3)); + + /* + * lets make a Context and add the event cartridge + */ + + Context context = new VelocityContext(); + + /* + * Now make an event cartridge, register the + * input event handler and attach it to the + * Context + */ + + EventCartridge ec = new EventCartridge(); + ec.addEventHandler(this); + ec.attachToContext( context ); + + + // BEHAVIOR A: pass through #input and #parse with no change + EventHandlerBehavior = PASS_THROUGH; + + template1.merge(context, writer1); + writer1.flush(); + writer1.close(); + + // BEHAVIOR B: pass through #input and #parse with using a relative path + EventHandlerBehavior = RELATIVE_PATH; + + template2.merge(context, writer2); + writer2.flush(); + writer2.close(); + + // BEHAVIOR C: refuse to pass through #input and #parse + EventHandlerBehavior = BLOCK; + + template3.merge(context, writer3); + writer3.flush(); + writer3.close(); + + if (!isMatch(RESULTS_DIR, COMPARE_DIR, "test1", + RESULT_FILE_EXT, CMP_FILE_EXT) || + !isMatch(RESULTS_DIR, COMPARE_DIR, "test2", + RESULT_FILE_EXT, CMP_FILE_EXT) || + !isMatch(RESULTS_DIR, COMPARE_DIR, "test3", + RESULT_FILE_EXT, CMP_FILE_EXT) + ) + { + fail("Output incorrect."); + } + } + + + @Override + public void setRuntimeServices(RuntimeServices rs ) + { + } + + /** + * Sample handler with different behaviors for the different tests. + */ + @Override + public String includeEvent(Context context, String includeResourcePath, String currentResourcePath, String directiveName) + { + if (EventHandlerBehavior == PASS_THROUGH) + return includeResourcePath; + + + // treat as relative path + else if (EventHandlerBehavior == RELATIVE_PATH) + { + // if the resource name starts with a slash, it's not a relative path + if (includeResourcePath.startsWith("/") || includeResourcePath.startsWith("\\") ) { + return includeResourcePath; + } + + int lastslashpos = Math.max( + currentResourcePath.lastIndexOf("/"), + currentResourcePath.lastIndexOf("\\") + ); + + // root of resource tree + if ( (lastslashpos == -1)) + return includeResourcePath; + + // prepend path to the input path + else + return currentResourcePath.substring(0,lastslashpos) + "/" + includeResourcePath; + + + + } else if (EventHandlerBehavior == BLOCK) + return null; + + // should never happen + else + return null; + + + } + + +} |