1

grails で単体テストを実行できません。以下のようにテストしたいメソッドを備えたTransactionControllergithubでも入手可能)があります。transactionAnalytics

TransactionController.groovy

package eccount


import org.codehaus.groovy.grails.web.json.JSONObject
import org.springframework.dao.DataIntegrityViolationException
import grails.converters.JSON

class TransactionController {
   def transactionService

   def transactionAnalytics = {
       searchRequest = searchRequest ?: new SearchRequest(requestParams: new HashMap<String, String>())
       configureRequestParams()
       def responseBytes = transactionService.getSearchResponse(searchRequest)
       def jsonResponse
       if (responseBytes)
            jsonResponse = JSON.parse(responseBytes)
       else
           jsonResponse = new JSONObject()
       render jsonResponse as JSON
   }
 }

対応するテストTransactionController#transactionAnalytics( github でも入手可能) は以下のとおりです。

TransactionControllerTests.groovy

package eccount



import org.junit.*
import grails.test.mixin.*

@TestFor(TransactionController)
class TransactionControllerTests {
    def INDEX_NAME = "gccount"

    void testTransactionAnalytics(){
        Map<String, String> params = new HashMap<String, String>()
        params.put("indexName",INDEX_NAME)
        //println params.get("indexName")
        //controller.params  = params
        controller.params.indexName  = "gccount"
        controller.transactionAnalytics()
        def jsonResponse = controller.response.json
        println jsonResponse
    }
}

コントローラーのメソッドを実行すると、次の例外が発生します

prayag@prayag:/backup/gccount$ grails test-app TransactionController.transactionAnalytics
| Environment set to test.....

| Running 1 unit test...
| Failure:  Test mechanism
|  java.lang.NullPointerException: Cannot invoke method finish() on null object
    at org.junit.runner.notification.RunNotifier$2.notifyListener(RunNotifier.java:71)
    at org.junit.runner.notification.RunNotifier$SafeNotifier.run(RunNotifier.java:41)
    at org.junit.runner.notification.RunNotifier.fireTestRunFinished(RunNotifier.java:68)
    at _GrailsTest_groovy$_run_closure4.doCall(_GrailsTest_groovy:290)
    at _GrailsTest_groovy$_run_closure2.doCall(_GrailsTest_groovy:248)
    at _GrailsTest_groovy$_run_closure1_closure21.doCall(_GrailsTest_groovy:195)
    at _GrailsTest_groovy$_run_closure1.doCall(_GrailsTest_groovy:184)
    at TestApp$_run_closure1.doCall(TestApp.groovy:82)
| Completed 0 unit test, 1 failed in 2723ms

| Packaging Grails application.....
[scalaPlugin] Compiling Scala sources from plugins to /home/prayag/.grails/2.1.1/projects/cashless/plugin-classes
[scalaPlugin] Compiling Scala sources to /backup/gccount/target/classes
| Compiling 2 source files

Configuring Spring Security Core ...
... finished configuring Spring Security Core
sandbox user created
role created
stall created with a user
| Tests FAILED  - view reports in /backup/gccount/target/test-reports

繰り返しますが、 にはレポートが残っていませんfile:///backup/gccount/target/test-reportsとにかく、ここで実際に null になっているのは誰ですか?

単体テスト

資力

9 テスト - 参照ドキュメント

http://mrhaki.blogspot.com/2010/04/grails-goodness-invoking-single-test.html

https://stackoverflow.com/a/3736549/432903

4

2 に答える 2

1

試す:

grails test-app TransactionController.testTransactionAnalytics

メソッド名の前の「テスト」を忘れた...そしてはい...クラス名に書く必要はないようですが、メソッド名には書く必要があります...

于 2013-11-08T09:07:10.540 に答える
0

Grails の良さ: 単一のテスト メソッドを呼び出すと、次のコードが機能しないため、間違った情報が投稿されているようです。

$ grails test-app TransactionController.transactionAnalytics

正しいものは初期化されたものですtransactionService

$ grails test-app TransactionControllerTests.testTransactionAnalytics

また

$ grails test-app TransactionController.testTransactionAnalytics
于 2013-11-09T08:20:03.143 に答える