亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dbunittask.java

?? 采用 Java 編寫的數據庫系統單元測試程序。
?? JAVA
字號:
/*
 *
 * The DbUnit Database Testing Framework
 * Copyright (C)2002-2004, DbUnit.org
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 */

package org.dbunit.ant;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import org.apache.tools.ant.AntClassLoader;
import org.apache.tools.ant.BuildException;
import org.apache.tools.ant.Project;
import org.apache.tools.ant.Task;
import org.apache.tools.ant.types.Path;
import org.apache.tools.ant.types.Reference;
import org.dbunit.DatabaseUnitException;
import org.dbunit.database.DatabaseConfig;
import org.dbunit.database.DatabaseConnection;
import org.dbunit.database.ForwardOnlyResultSetTableFactory;
import org.dbunit.database.IDatabaseConnection;
import org.dbunit.dataset.datatype.IDataTypeFactory;

import java.sql.Connection;
import java.sql.Driver;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Properties;

/**
 * <code>DbUnitTask</code> is the task definition for an Ant
 * interface to <code>DbUnit</code>.   DbUnit is a JUnit extension
 * which sets your database to a known state before executing your
 * tasks.
 *
 * @author Timothy Ruppert
 * @author Ben Cox
 * @version $Revision: 629 $
 * @since Jun 10, 2002
 * @see org.apache.tools.ant.Task
 */
public class DbUnitTask extends Task
{

    /**
     * Logger for this class
     */
    private static final Logger logger = LoggerFactory.getLogger(DbUnitTask.class);

    /**
     * Database connection
     */
    private Connection conn = null;

    /**
     * DB driver.
     */
    private String driver = null;

    /**
     * DB url.
     */
    private String url = null;

    /**
     * User name.
     */
    private String userId = null;

    /**
     * Password
     */
    private String password = null;

    /**
     * DB schema.
     */
    private String schema = null;

    /**
     * Steps
     */
    private List steps = new ArrayList();

    private Path classpath;

    private AntClassLoader loader;

    /**
     * Flag for using the qualified table names.
     */
    private boolean useQualifiedTableNames = false;

    /**
     * Flag for using batched statements.
     */
    private boolean supportBatchStatement = false;

    /**
     * Flag for datatype warning.
     */
    private boolean datatypeWarning = true;

    private String escapePattern = null;

    private String dataTypeFactory = "org.dbunit.dataset.datatype.DefaultDataTypeFactory";

    /**
     * Set the JDBC driver to be used.
     */
    public void setDriver(String driver)
    {
        logger.debug("setDriver(driver=" + driver + ") - start");

        this.driver = driver;
    }

    /**
     * Set the DB connection url.
     */
    public void setUrl(String url)
    {
        logger.debug("setUrl(url=" + url + ") - start");

        this.url = url;
    }

    /**
     * Set the user name for the DB connection.
     */
    public void setUserid(String userId)
    {
        logger.debug("setUserid(userId=" + userId + ") - start");

        this.userId = userId;
    }

    /**
     * Set the password for the DB connection.
     */
    public void setPassword(String password)
    {
        logger.debug("setPassword(password=" + password + ") - start");

        this.password = password;
    }

    /**
     * Set the schema for the DB connection.
     */
    public void setSchema(String schema)
    {
        logger.debug("setSchema(schema=" + schema + ") - start");

        this.schema = schema;
    }

    /**
     * Set the flag for using the qualified table names.
     */
    public void setUseQualifiedTableNames(boolean useQualifiedTableNames)
    {
        logger.debug("setUseQualifiedTableNames(useQualifiedTableNames=" + useQualifiedTableNames + ") - start");

        this.useQualifiedTableNames = useQualifiedTableNames;
    }

    /**
     * Set the flag for supporting batch statements.
     * NOTE: This property cannot be used to force the usage of batch
     *       statement if your database does not support it.
     */
    public void setSupportBatchStatement(boolean supportBatchStatement)
    {
        logger.debug("setSupportBatchStatement(supportBatchStatement=" + supportBatchStatement + ") - start");

        this.supportBatchStatement = supportBatchStatement;
    }

    public void setDatatypeWarning(boolean datatypeWarning)
    {
        logger.debug("setDatatypeWarning(datatypeWarning=" + datatypeWarning + ") - start");

        this.datatypeWarning = datatypeWarning;
    }

    public void setDatatypeFactory(String datatypeFactory)
    {
        logger.debug("setDatatypeFactory(datatypeFactory=" + datatypeFactory + ") - start");

        this.dataTypeFactory = datatypeFactory;
    }

    public void setEscapePattern(String escapePattern)
    {
        logger.debug("setEscapePattern(escapePattern=" + escapePattern + ") - start");

        this.escapePattern = escapePattern;
    }

    /**
     * Set the classpath for loading the driver.
     */
    public void setClasspath(Path classpath)
    {
        logger.debug("setClasspath(classpath=" + classpath + ") - start");

        if (this.classpath == null)
        {
            this.classpath = classpath;
        }
        else
        {
            this.classpath.append(classpath);
        }
    }

    /**
     * Create the classpath for loading the driver.
     */
    public Path createClasspath()
    {
        logger.debug("createClasspath() - start");

        if (this.classpath == null)
        {
            this.classpath = new Path(project);
        }
        return this.classpath.createPath();
    }

    /**
     * Set the classpath for loading the driver using the classpath reference.
     */
    public void setClasspathRef(Reference r)
    {
        logger.debug("setClasspathRef(r=" + r + ") - start");

        createClasspath().setRefid(r);
    }

    /**
     * Gets the Steps.
     */
    public List getSteps()
    {
        logger.debug("getSteps() - start");

        return steps;
    }

    /**
     * Adds an Operation.
     */
    public void addOperation(Operation operation)
    {
        logger.debug("addOperation(operation) - start");

        steps.add(operation);
    }

    /**
     * Adds a Compare to the steps List.
     */
    public void addCompare(Compare compare)
    {
        logger.debug("addCompare(compare) - start");

        steps.add(compare);
    }

    /**
     * Adds an Export to the steps List.
     */
    public void addExport(Export export)
    {
        logger.debug("addExport(export) - start");

    	export.setParentTask(this);
        steps.add(export);
    }

    /**
     * Load the step and then execute it
     */
    public void execute() throws BuildException
    {
        logger.debug("execute() - start");

        try
        {
            IDatabaseConnection connection = createConnection();

            Iterator stepIter = steps.listIterator();
            while (stepIter.hasNext())
            {
                DbUnitTaskStep step = (DbUnitTaskStep)stepIter.next();
                log(step.getLogMessage(), Project.MSG_INFO);
                step.execute(connection);
            }
        }
        catch (DatabaseUnitException e)
        {
            throw new BuildException(e, location);
        }
        catch (SQLException e)
        {
            throw new BuildException(e, location);
        }
        finally
        {
            try
            {
                if (conn != null)
                {
                    conn.close();
                }
            }
            catch (SQLException e)
            {
                logger.error("execute()", e);
            }
        }
    }

    IDatabaseConnection createConnection() throws SQLException
    {
        logger.debug("createConnection() - start");

        if (driver == null)
        {
            throw new BuildException("Driver attribute must be set!", location);
        }
        if (userId == null)
        {
            throw new BuildException("User Id attribute must be set!", location);
        }
        if (password == null)
        {
            throw new BuildException("Password attribute must be set!", location);
        }
        if (url == null)
        {
            throw new BuildException("Url attribute must be set!", location);
        }
        if (steps.size() == 0)
        {
            throw new BuildException("Must declare at least one step in a <dbunit> task!");
        }

        // Instanciate JDBC driver
        Driver driverInstance = null;
        try
        {
            Class dc;
            if (classpath != null)
            {
                log("Loading " + driver + " using AntClassLoader with classpath " + classpath,
                        Project.MSG_VERBOSE);

                loader = new AntClassLoader(project, classpath);
                dc = loader.loadClass(driver);
            }
            else
            {
                log("Loading " + driver + " using system loader.", Project.MSG_VERBOSE);
                dc = Class.forName(driver);
            }
            driverInstance = (Driver)dc.newInstance();
        }
        catch (ClassNotFoundException e)
        {
            throw new BuildException("Class Not Found: JDBC driver "
                    + driver + " could not be loaded", e, location);
        }
        catch (IllegalAccessException e)
        {
            throw new BuildException("Illegal Access: JDBC driver "
                    + driver + " could not be loaded", e, location);
        }
        catch (InstantiationException e)
        {
            throw new BuildException("Instantiation Exception: JDBC driver "
                    + driver + " could not be loaded", e, location);
        }

        log("connecting to " + url, Project.MSG_VERBOSE);
        Properties info = new Properties();
        info.put("user", userId);
        info.put("password", password);
        conn = driverInstance.connect(url, info);

        if (conn == null)
        {
            // Driver doesn't understand the URL
            throw new SQLException("No suitable Driver for " + url);
        }
        conn.setAutoCommit(true);

        IDatabaseConnection connection = new DatabaseConnection(conn, schema);
        DatabaseConfig config = connection.getConfig();
        config.setFeature(DatabaseConfig.FEATURE_BATCHED_STATEMENTS, supportBatchStatement);
        config.setFeature(DatabaseConfig.FEATURE_QUALIFIED_TABLE_NAMES, useQualifiedTableNames);
        config.setFeature(DatabaseConfig.FEATURE_DATATYPE_WARNING, datatypeWarning);
        config.setProperty(DatabaseConfig.PROPERTY_ESCAPE_PATTERN, escapePattern);
        config.setProperty(DatabaseConfig.PROPERTY_RESULTSET_TABLE_FACTORY,
                new ForwardOnlyResultSetTableFactory());

        // Setup data type factory
        try
        {
            IDataTypeFactory dataTypeFactory = (IDataTypeFactory)Class.forName(
                    this.dataTypeFactory).newInstance();
            config.setProperty(DatabaseConfig.PROPERTY_DATATYPE_FACTORY, dataTypeFactory);
        }
        catch (ClassNotFoundException e)
        {
            throw new BuildException("Class Not Found: DataType factory "
                    + driver + " could not be loaded", e, location);
        }
        catch (IllegalAccessException e)
        {
            throw new BuildException("Illegal Access: DataType factory "
                    + driver + " could not be loaded", e, location);
        }
        catch (InstantiationException e)
        {
            throw new BuildException("Instantiation Exception: DataType factory "
                    + driver + " could not be loaded", e, location);
        }

        return connection;
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产98色在线|日韩| 亚洲综合色成人| 一区二区欧美国产| 成人激情免费网站| 欧美丰满高潮xxxx喷水动漫| 国产片一区二区| 91视频精品在这里| 国产亚洲综合av| 97aⅴ精品视频一二三区| 一区二区视频在线看| 美女精品一区二区| 亚洲成av人片| 亚洲欧洲www| 国产精品国产三级国产专播品爱网 | 成人国产精品免费观看动漫| 午夜av一区二区| 日韩电影免费在线看| 视频一区欧美精品| 天天综合日日夜夜精品| 国产精品国产馆在线真实露脸 | 成人免费在线视频| 国产精品女上位| 国产日韩综合av| 国产精品美女久久久久久久| 日韩一级黄色大片| 欧美mv日韩mv亚洲| 日韩欧美你懂的| 精品国内二区三区| 久久久综合视频| 国产农村妇女毛片精品久久麻豆 | 蜜芽一区二区三区| 亚洲伊人伊色伊影伊综合网| 一区二区三区日韩精品| 亚洲一区在线视频| 一区二区三区自拍| 亚洲国产日韩精品| 日韩中文欧美在线| 久久99精品久久久久婷婷| 国产成人精品免费| 狠狠色综合日日| 久88久久88久久久| 国产精品一区二区91| 粉嫩嫩av羞羞动漫久久久| 成人激情av网| 91亚洲精品一区二区乱码| 色一情一乱一乱一91av| 欧美日韩五月天| 91福利在线播放| 91香蕉国产在线观看软件| 国产乱码一区二区三区| 国产成人在线视频网址| 国产福利一区二区| 成a人片国产精品| 91免费国产视频网站| 日本大香伊一区二区三区| 色婷婷亚洲一区二区三区| av亚洲精华国产精华精| 国产精品123| 成人深夜视频在线观看| 成人激情免费网站| 欧美久久一二三四区| 国产午夜精品理论片a级大结局| 日本一区二区三区在线不卡| 久久91精品久久久久久秒播| 国产成人免费视频一区| 日本韩国欧美在线| 欧美亚洲一区二区三区四区| 色八戒一区二区三区| 91在线观看免费视频| 欧美综合色免费| 亚洲男人的天堂在线观看| 欧美午夜一区二区| 国产精品福利一区二区三区| 国产精品嫩草影院com| 久久久综合网站| 91精品国产综合久久久久| 日本一区二区三区在线不卡| 久久精品噜噜噜成人88aⅴ | 石原莉奈在线亚洲三区| 成人一区二区三区中文字幕| 欧美精品日日鲁夜夜添| 日韩一区二区三区免费看 | 色琪琪一区二区三区亚洲区| 亚洲男人的天堂在线观看| 欧美日韩久久久| 精品一区二区三区视频在线观看| 91色婷婷久久久久合中文| 日日夜夜一区二区| 国产精品久久毛片| 一本色道久久综合亚洲精品按摩| 国产伦精品一区二区三区免费迷 | 国产精品家庭影院| 欧美一级免费大片| 欧美高清视频一二三区 | 日本不卡一区二区三区 | 国产欧美精品一区aⅴ影院| 欧美tickling网站挠脚心| 91精品在线观看入口| 4438成人网| 26uuu色噜噜精品一区| 国产女人18毛片水真多成人如厕 | 亚洲精品老司机| 天天操天天色综合| 国产在线国偷精品产拍免费yy| 国产精品99久久久久久久女警| 成人精品gif动图一区| 色婷婷av一区| 91精品国产综合久久久久久漫画| 久久久久久久久久美女| 欧美精彩视频一区二区三区| 亚洲欧美日韩人成在线播放| 香蕉成人啪国产精品视频综合网| 美国十次了思思久久精品导航| 国内精品久久久久影院一蜜桃| 99视频精品全部免费在线| 欧美肥大bbwbbw高潮| 国产女主播视频一区二区| 亚洲黄网站在线观看| 视频一区二区国产| 成人永久免费视频| 91精品中文字幕一区二区三区| 国产午夜亚洲精品不卡| 亚洲一区在线观看网站| 国产一区视频导航| 欧美日韩情趣电影| 亚洲国产精品综合小说图片区| 日本伊人午夜精品| 国产99久久久国产精品潘金| 色婷婷香蕉在线一区二区| 日韩一区二区三区av| 国产精品情趣视频| 视频一区二区国产| 国产99久久久久久免费看农村| 91久久一区二区| 国产精品久久久久久久久搜平片| 亚洲亚洲精品在线观看| 国产精品综合在线视频| 欧美高清激情brazzers| 中文字幕一区免费在线观看| 美女免费视频一区二区| 欧美色电影在线| 一区二区三区电影在线播| 青青草国产精品亚洲专区无| 91社区在线播放| 午夜私人影院久久久久| 一本一本大道香蕉久在线精品| 午夜激情综合网| 国产成人激情av| 国产乱码一区二区三区| 欧美美女视频在线观看| 亚洲精品免费在线播放| 国产99久久久精品| 石原莉奈一区二区三区在线观看 | 成人免费观看视频| 国产日韩亚洲欧美综合| 亚洲第一久久影院| 一道本成人在线| 亚洲日本免费电影| 成人ar影院免费观看视频| 久久亚洲春色中文字幕久久久| 久久精品国产久精国产| 制服丝袜激情欧洲亚洲| 亚洲成人综合网站| 欧美中文字幕一区二区三区亚洲| 日韩一区在线看| aaa亚洲精品| 亚洲欧美日韩国产综合在线 | 亚洲乱码精品一二三四区日韩在线| 国产精品99久久久| 久久人人爽爽爽人久久久| 久久av中文字幕片| 久久综合九色综合97婷婷| 麻豆传媒一区二区三区| 欧美videofree性高清杂交| 久久99精品久久久久婷婷| 欧美电影免费提供在线观看| 另类的小说在线视频另类成人小视频在线| 欧美日韩国产高清一区二区 | 亚洲人成亚洲人成在线观看图片| 国产+成+人+亚洲欧洲自线| 久久精品一区二区三区av | 91无套直看片红桃| 亚洲另类一区二区| 欧美美女一区二区三区| 久久精品二区亚洲w码| 精品av综合导航| 粉嫩av亚洲一区二区图片| 国产精品第五页| 欧美三级电影一区| 免费高清在线一区| 久久一区二区视频| www.性欧美| 五月婷婷久久丁香| 久久尤物电影视频在线观看| av激情综合网| 天堂一区二区在线| 久久亚洲影视婷婷| 色呦呦国产精品| 久久不见久久见中文字幕免费| 国产精品久久久久影院|