0

ここで私が間違っていることについて、いくつかの光を教えてください。まず第一に、私はGradleとGroovyの初心者であり、学習目的でそれらとDBUnitで遊んでいます。

以下にリストされているコードを試しました。私の目標は、mysql db からデータを取得するデータセットを生成することです。

import groovy.sql.Sql
import org.dbunit.database.DatabaseConnection;
import org.dbunit.database.IDatabaseConnection;
import org.dbunit.dataset.IDataSet;
import org.dbunit.dataset.xml.FlatXmlDataSet;

repositories {
    mavenCentral()
}

configurations {
   dbunit    
}

dependencies {
   dbunit 'dbunit:dbunit:2.2', 
          'junit:junit:4.11', 
          'mysql:mysql-connector-java:5.1.25'
}

URLClassLoader loader = GroovyObject.class.classLoader
configurations.dbunit.each { File file -> loader.addURL(file.toURL()) }

task listJars << {    
    configurations.dbunit.each { File file -> println file.name }
}

task listTables << {    
    getConnection("mydb").eachRow('show tables') { row -> println row[0] }
}

task generateDataSet << {
    def IDatabaseConnection conn = new DatabaseConnection(getConnection("mydb").connection)
    def IDataSet fullDataSet = conn.createDataSet()
    FlatXmlDataSet.write(fullDataSet, new FileOutputStream("full.xml"))
}


static Sql getConnection(db) {
   def props = [user: 'dbuser', password: 'userpass', allowMultiQueries: 'true'] as Properties
   def url = (db) ? 'jdbc:mysql://host:3306/'.plus(db) : 'jdbc:mysql://host:3306/'
   def driver = 'com.mysql.jdbc.Driver'
   Sql.newInstance(url, props, driver)
}

私にとって奇妙なのは、すべての MySQL メソッドがうまく機能することです。テーブルのリストを取得できます。たとえば、接続が適切に行われたため、mysql-connector-java.jar がロードされています (と思います)。 DBUnit のもの (インポート ライブラリと generateDataSet メソッド) スクリプトで dbunit jar を使用できないようです。次のエラーが発生しました。

FAILURE: Build failed with an exception.

* Where:
Build file '/home/me/tmp/dbunit/build.gradle' line: 5

* What went wrong:
Could not compile build file '/home/me/tmp/dbunit/build.gradle'.
> startup failed:
  build file '/home/me/tmp/dbunit/build.gradle': 5: unable to resolve class      org.dbunit.dataset.xml.FlatXmlDataSet
   @ line 5, column 1.
     import org.dbunit.dataset.xml.FlatXmlDataSet;
     ^

  build file '/home/me/tmp/dbunit/build.gradle': 2: unable to resolve class     org.dbunit.database.DatabaseConnection
   @ line 2, column 1.
     import org.dbunit.database.DatabaseConnection;
     ^

  build file '/home/me/tmp/dbunit/build.gradle': 3: unable to resolve class     org.dbunit.database.IDatabaseConnection
   @ line 3, column 1.
     import org.dbunit.database.IDatabaseConnection;
     ^

   build file '/home/me/tmp/dbunit/build.gradle': 4: unable to resolve class     org.dbunit.dataset.IDataSet
   @ line 4, column 1.
     import org.dbunit.dataset.IDataSet;
     ^

  4 errors

しかし、listJars タスクを呼び出すと、次のようになります。

:listJars
junit-4.11.jar
mysql-connector-java-5.1.25.jar
hamcrest-core-1.3.jar
xercesImpl-2.6.2.jar
xmlParserAPIs-2.6.2.jar
junit-addons-1.4.jar
poi-2.5.1-final-20040804.jar
commons-collections-3.1.jar
commons-lang-2.1.jar
commons-logging-1.0.4.jar
dbunit-2.2.jar

BUILD SUCCESSFUL

私の理解では、これらすべての jar がロードされ、スクリプトで使用できることを意味しますか? または、クラスローダーに何か問題がありますか?

どうもありがとう。

4

1 に答える 1

1

ハックは、GroovyObject.class.classLoader.addURLビルド スクリプトのクラス パスに依存関係を追加する正しい方法ではありません。JDBC ドライバーを Groovy で動作させる必要がある場合があります (長い話です)。ビルド スクリプトのクラス パスに依存関係を追加する方法は次のとおりです。

buildscript {
    repositories {
        mavenCentral()
    }

    dependencies {
        classpath "some:library:1.0"
    }
}

// library can be used in the rest of the build script

詳細については、Gradle ユーザー ガイドを参照してください。

于 2013-05-31T18:22:56.420 に答える