PropertiesTest.java :  » Scripting » scriptella » scriptella » Java Open Source

Java Open Source » Scripting » scriptella 
scriptella » scriptella » PropertiesTest.java
/*
 * Copyright 2006-2007 The Scriptella Project Team.
 *
 * Licensed 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 scriptella;

import scriptella.configuration.ConfigurationFactory;
import scriptella.core.ConnectionManager;
import scriptella.core.SqlTestHelper;
import scriptella.execution.EtlContext;
import scriptella.execution.EtlExecutor;
import scriptella.execution.EtlExecutorException;
import scriptella.interactive.ProgressIndicator;
import scriptella.spi.ConnectionParameters;

import java.util.HashMap;
import java.util.Map;


/**
 * TODO: Add documentation
 *
 * @author Fyodor Kupolov
 * @version 1.0
 */
public class PropertiesTest extends AbstractTestCase {
    private EtlContext ctx; //execution context
    private ConnectionParameters params;

    public void test() throws EtlExecutorException {
        EtlExecutor se = prepareExecutor(null);
        se.execute();

        assertEquals("jdbc:hsqldb:mem:propertiestest", params.getUrl());
        assertEquals("sa", params.getUser());
        assertEquals("", params.getPassword());

        //check substituted properties in a context
        assertEquals("1", ctx.getParameter("a"));
        assertEquals("bar", ctx.getParameter("foo"));
        assertEquals("1", ctx.getParameter("var"));
        assertEquals("1|1|1|1|1|1", ctx.getParameter("b"));
        assertEquals("jdbc:hsqldb:mem", ctx.getParameter("url.prefix"));
        assertEquals("propertiestest", ctx.getParameter("dbname"));
        assertEquals("org.hsqldb.jdbcDriver", ctx.getParameter("driver"));
        assertEquals("org.hsqldb.jdbcDriver", ctx.getParameter("driver"));
        assertEquals("jdbc:hsqldb:mem:propertiestest", ctx.getParameter("url"));
        assertEquals("sa", ctx.getParameter("user"));
        assertEquals("", ctx.getParameter("password"));
        Map<String,String> extra = new HashMap<String, String>();
        extra.put("var", "2");
        se = prepareExecutor(extra);
        se.execute();
        assertEquals("2", ctx.getParameter("var"));
        assertEquals("2|2|2|2|2|2", ctx.getParameter("b"));
    }

    private EtlExecutor prepareExecutor(Map<String,String> props) {
        ConfigurationFactory cf = new ConfigurationFactory();
        cf.setResourceURL(getClass().getResource(getClass().getSimpleName()+".xml"));
        cf.setExternalParameters(props);
        return new EtlExecutor(cf.createConfiguration()) {
            //overrides prepare method to get ctx and params for connection
            @Override
            protected EtlContext prepare(final ProgressIndicator indicator) {
                ctx = super.prepare(indicator);
                Map<String, ConnectionManager> connections = SqlTestHelper.getConnections(ctx.getSession());
                ConnectionManager con = connections.entrySet().iterator().next().getValue();
                params = SqlTestHelper.getConnectionParameters(con);
                return ctx;
            }
        };

    }

}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.