2016-11-13 3 views
2

「MVNを検証」することはできません。キュウリテストがまとめ「MVNテスト」で実行しますが、中に

を私は春のブートアプリケーションに対して、キュウリを使っていくつかのテストを実行しています。 My Cucumberテストは "mvn test"を使用して実行するとうまく動作しますが、 "mvn verify"ライフサイクルで実行すると失敗します。

詳細:

マイキュウリランナークラス次のようになります。

@RunWith(Cucumber.class) 
@CucumberOptions(
     features = {"src/test/resources/features/creditCardSummary.feature"}, 
     glue = {"th.co.scb.fasteasy.step"}, 
     plugin = { 
       "pretty", 
       "json:target/cucumber-json-report.json" 
       } 
) 

public class CreditCardRunnerTest { 

} 

私は「MVNテスト」を実行するとき、私はキュウリのランナーがMavenの前にインスタンス化されたログで見ることができますスプリングブートプラグインは、スプリングブートインスタンスをインスタンス化します。

------------------------------------------------------- 
T E S T S 
------------------------------------------------------- 
Running CreditCardRunnerTest 
@creditcards 
Feature: POST /creditcards/summary 
    As a user, I would like to get basic information, balance and/or last 'n' transactions of a given list of credit cards, so that I can provide the information for further operations. 

........... 

2016-11-13 07:29:02.704 INFO 14716 --- [   main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8090 (http) 
2016-11-13 07:29:02.721 INFO 14716 --- [   main] t.c.s.fasteasy.step.CreditCardStepdefs : Started CreditCardStepdefs in 13.486 seconds (JVM running for 16.661) 

私のキュウリ試験は実際にはtegrationテストので、私はそれがの一部として実行されるように移動しCucumberRunnerIT.javaに名前を変更し、次のようにのpom.xmlを設定することで、代わりにライフサイクルフェーズを「MVN検証」:

<build> 
    <plugins> 
     <plugin> 
      <groupId>org.springframework.boot</groupId> 
      <artifactId>spring-boot-maven-plugin</artifactId> 
      <executions> 
       <execution> 
        <id>pre-integration-test</id> 
        <goals> 
         <goal>start</goal> 
        </goals> 
       </execution> 
       <execution> 
        <id>post-integration-test</id> 
        <goals> 
         <goal>stop</goal> 
        </goals> 
       </execution> 
      </executions> 
     </plugin> 
... 
     <plugin> 
      <groupId>org.apache.maven.plugins</groupId> 
      <artifactId>maven-surefire-plugin</artifactId> 
      <version>2.19.1</version> 
      <configuration> 
       <argLine>${surefireArgLine}</argLine> 
       <excludes> 
        <exclude>**/IT.java</exclude> 
       </excludes> 
      </configuration> 
     </plugin> 
     <plugin> 
      <groupId>org.apache.maven.plugins</groupId> 
      <artifactId>maven-failsafe-plugin</artifactId> 
      <version>2.19.1</version> 
      <executions> 
       <execution> 
        <id>integration-tests</id> 
        <goals> 
         <goal>integration-test</goal> 
         <goal>verify</goal> 
        </goals> 
        <configuration> 
         <argLine>${failsafeArgLine}</argLine> 
         <skipTests>${skip.integration.tests}</skipTests> 
        </configuration> 
       </execution> 
      </executions> 
     </plugin> 
    </plugins> 
</build> 

私は」の一環として、それを実行すると、検証」しかし、私は次のエラーを取得:

2016-11-13 07:39:42.921 INFO 12244 --- [lication.main()] o.s.c.support.DefaultLifecycleProcessor : Starting beans in phase 0 
2016-11-13 07:39:43.094 INFO 12244 --- [lication.main()] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8090 (http) 
2016-11-13 07:39:43.099 INFO 12244 --- [lication.main()] th.co.scb.fasteasy.Application   : Started Application in 10.41 seconds (JVM running for 52.053) 
[INFO] 
[INFO] --- maven-failsafe-plugin:2.19.1:integration-test (default) @ creditcards --- 

------------------------------------------------------- 
T E S T S 
------------------------------------------------------- 
Running CreditCardRunnerIT 
Tests run: 1, Failures: 0, Errors: 1, Skipped: 0, Time elapsed: 0.716 sec <<< FAILURE! - in CreditCardRunnerIT 
initializationError(CreditCardRunnerIT) Time elapsed: 0.008 sec <<< ERROR! 
cucumber.runtime.CucumberException: java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy 
Caused by: java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy 


Results : 

Tests in error: 
    CreditCardRunnerIT.initializationError ▒ Cucumber java.lang.ArrayStoreExceptio... 

Tests run: 1, Failures: 0, Errors: 1, Skipped: 0 

[INFO] 
[INFO] --- maven-failsafe-plugin:2.19.1:integration-test (integration-tests) @ creditcards --- 

をキュウリが初期化される前に、私は私が事前に統合テスト中に実行するのmaven春ブートプラグインを設定していたので、それが実行されていることに気づいたが、私はありませんこれがエラーであるかどうか確かめてください。私はspring-bootプラグインを "pre-integration-test"ではなく "integration-test"中に起動するように設定しようとしましたが、あまり効果がなかったようです。

私がここで間違っていることに関するアイデアはありますか?

+0

私はspring-boot-maven-pluginを実行せずに追加するのと同じ問題が発生しています。 Java 9(181)、Maven 3.5.0、Spring Boot 2.0.0.M5、およびCucumber 1.2.5 – Tuno

答えて

0

これはjdkバージョンに関する問題です。 JDK 1.8.0u51を使用すると、それが解決されます。

jdkのバージョンが高い場合、この問題が発生します。 JDK 1.8.0u51以下のバージョンを使用してください。

さらに、この問題を解決できます。あなたの問題と同じです:https://github.com/cucumber/cucumber-jvm/issues/912

関連する問題