| 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 org.apache.velocity.VelocityContext; |
| import org.apache.velocity.app.VelocityEngine; |
| import org.apache.velocity.runtime.RuntimeConstants; |
| import org.apache.velocity.runtime.resource.loader.StringResourceLoader; |
| import org.apache.velocity.test.misc.TestLogger; |
| |
| import java.io.File; |
| import java.io.FileWriter; |
| import java.nio.file.FileSystems; |
| import java.nio.file.Files; |
| import java.nio.file.StandardCopyOption; |
| |
| /** |
| * This class tests the velocimacro.library.autoreload functionality, and issue VELOCITY- |
| */ |
| public class MacroAutoReloadTestCase extends BaseTestCase |
| { |
| private final String RELOAD_TEMPLATE_PATH = TEST_COMPARE_DIR + "/reload"; |
| |
| public MacroAutoReloadTestCase(String name) |
| { |
| super(name); |
| } |
| |
| protected void setUp() throws Exception |
| { |
| // always copy macros library before modifying it, to ensure successive tests will pass |
| Files.copy(FileSystems.getDefault().getPath(RELOAD_TEMPLATE_PATH + "/macros.vtl"), FileSystems.getDefault().getPath(RELOAD_TEMPLATE_PATH + "/macros2.vtl"), StandardCopyOption.REPLACE_EXISTING); |
| |
| engine = new VelocityEngine(); |
| |
| //by default, make the engine's log output go to the test-report |
| log = new TestLogger(false, false); |
| engine.setProperty(RuntimeConstants.RUNTIME_LOG_INSTANCE, log); |
| |
| // use file resource loader |
| engine.setProperty(RuntimeConstants.RESOURCE_LOADERS, "file,string"); |
| engine.addProperty("file.resource.loader.path", RELOAD_TEMPLATE_PATH); |
| engine.addProperty("velocimacro.library", "macros2.vtl"); |
| engine.addProperty("velocimacro.library.autoreload", "true"); |
| engine.addProperty("file.resource.loader.cache", "false"); |
| engine.addProperty("string.resource.loader.class", StringResourceLoader.class.getName()); |
| engine.addProperty("string.resource.loader.repository.name", "stringRepo"); |
| engine.addProperty("string.resource.loader.repository.static", "false"); |
| context = new VelocityContext(); |
| } |
| |
| |
| public void testChangedMacro() throws Exception |
| { |
| String template = "#foo('hip')"; |
| assertEvalEquals("hop_hip", template); |
| |
| FileWriter writer = new FileWriter(RELOAD_TEMPLATE_PATH + "/macros2.vtl"); |
| writer.write("#macro(foo $txt)hip_$txt#{end}"); |
| writer.close(); |
| // last modified timestamps resolution is one second before Java 8, |
| // so force reloading by setting a file date in the future |
| File macros2 = new File(TEST_COMPARE_DIR + "/reload/macros2.vtl"); |
| macros2.setLastModified(macros2.lastModified() + 1000); |
| |
| assertEvalEquals("hip_hip", template); |
| } |
| |
| public void testNewMacro() throws Exception |
| { |
| String template = "#foo('hip')"; |
| assertEvalEquals("hop_hip", template); |
| |
| FileWriter writer = new FileWriter(TEST_COMPARE_DIR + "/reload/macros2.vtl", true); |
| writer.write("\n#macro(bar $txt)hep_$txt#{end}"); |
| writer.close(); |
| // last modified timestamps resolution is one second before Java 8, |
| // so force reloading by setting a file date in the future |
| File macros2 = new File(TEST_COMPARE_DIR + "/reload/macros2.vtl"); |
| macros2.setLastModified(macros2.lastModified() + 1000); |
| |
| template = "#foo('hip') #bar('hip')"; |
| assertEvalEquals("hop_hip hep_hip", template); |
| } |
| } |