001    /**
002     * Copyright 2005-2013 The Kuali Foundation
003     *
004     * Licensed under the Educational Community License, Version 2.0 (the "License");
005     * you may not use this file except in compliance with the License.
006     * You may obtain a copy of the License at
007     *
008     * http://www.opensource.org/licenses/ecl2.php
009     *
010     * Unless required by applicable law or agreed to in writing, software
011     * distributed under the License is distributed on an "AS IS" BASIS,
012     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013     * See the License for the specific language governing permissions and
014     * limitations under the License.
015     */
016    package edu.samplu.common;
017    
018    import freemarker.cache.ClassTemplateLoader;
019    import freemarker.template.Configuration;
020    import freemarker.template.Template;
021    import freemarker.template.TemplateException;
022    import org.apache.log4j.Logger;
023    import org.junit.Before;
024    import org.testng.annotations.BeforeMethod;
025    
026    import java.io.File;
027    import java.io.FileInputStream;
028    import java.io.IOException;
029    import java.io.InputStream;
030    import java.util.Properties;
031    
032    /**
033     * @see FreemarkerUtil
034     * @author Kuali Rice Team (rice.collab@kuali.org)
035     */
036    public abstract class FreemarkerSTBase extends WebDriverLegacyITBase {
037    
038        protected final Logger LOG = Logger.getLogger(getClass());
039    
040        protected Configuration cfg;
041    
042        protected abstract String getTemplateDir();
043    
044        @Override
045        @Before
046        @BeforeMethod
047        public void setUp() throws Exception {
048            super.setUp();
049            // generated load users and group resources
050            cfg = new Configuration();
051            cfg.setTemplateLoader(new ClassTemplateLoader(getClass().getClassLoader().getClass(), getTemplateDir()));
052        }
053    
054        /**
055         * Calls ftlWrite that also accepts a key, using the output getName as the key.
056         * {@link FreemarkerUtil#ftlWrite(java.io.File, freemarker.template.Template, java.io.InputStream)}
057         * @param output
058         * @param template
059         * @return
060         * @throws IOException
061         * @throws TemplateException
062         */
063        public File ftlWrite(File output, Template template, InputStream inputStream) throws IOException, TemplateException {
064    
065            return FreemarkerUtil.ftlWrite(output.getName(), output, template, inputStream);
066        }
067    
068        /**
069         * TODO can we cut this down to one param?
070         * {@link FreemarkerUtil#loadProperties(java.io.InputStream)}
071         * @param fileLocation null means use resourceLocation
072         * @param resourceLocation
073         * @return
074         * @throws IOException
075         */
076        protected Properties loadProperties(String fileLocation, String resourceLocation) throws IOException {
077            Properties props = null;
078            InputStream in = null;
079            if(fileLocation != null) {
080                in = new FileInputStream(fileLocation);
081            } else {
082                in = getClass().getClassLoader().getResourceAsStream(resourceLocation);
083            }
084            if(in != null) {
085                props = FreemarkerUtil.loadProperties(in);
086                in.close();
087            }
088    
089            return props;
090        }
091    
092        /**
093         * {@link FreemarkerUtil#systemPropertiesOverride(java.util.Properties, String)}
094         * @param props
095         * @param key
096         */
097        protected void systemPropertiesOverride(Properties props, String key) {
098            FreemarkerUtil.systemPropertiesOverride(props, key);
099        }
100    
101        /**
102        * {@link FreemarkerUtil#writeTemplateToFile(java.io.File, freemarker.template.Template, java.util.Properties)}
103        * @param file
104        * @param template
105        * @param props
106        * @return
107        * @throws IOException
108        * @throws TemplateException
109        */
110        protected static File writeTemplateToFile(File file, Template template, Properties props) throws IOException, TemplateException {
111            return FreemarkerUtil.writeTemplateToFile(file, template, props);
112        }
113    }