質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.92%

SpringBootアプリのビルド・テスト時に、テスト用application.propertiesが読み込まれない

受付中

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 129

daphnia99

score 17

問題と実現したいこと

ビルドサーバーを立て、Jenkinsで./gradlew buildでビルドした際、全てのテストが失敗します。

こちらの記事によれば、test時にはtest/resorces/配下のpropertiesファイルが優先されるとのことです。しかし、下記エラーメッセージにあるように、どうもtest用のtest.propertiesが読み込まれていないようです。

Caused by: java.io.FileNotFoundException: class path resource [test.properties] cannot be opened because it does not exist

ビルド時、どのようにしてテスト用のtest.propertiesを読み込ませ、JUnitによるテストを実施すれば良いでしょうか??

エラーメッセージ

各テストには下記のようなエラーメッセージがでます。

Java.lang.IllegalStateException: Failed to load ApplicationContext
Caused by: java.io.FileNotFoundException: class path resource [test.properties] cannot be opened because it does not exist
    at org.springframework.core.io.ClassPathResource.getInputStream(ClassPathResource.java:180)
    at org.springframework.core.io.support.EncodedResource.getInputStream(EncodedResource.java:159)
    at org.springframework.core.io.support.PropertiesLoaderUtils.fillProperties(PropertiesLoaderUtils.java:99)
    at org.springframework.core.io.support.PropertiesLoaderUtils.fillProperties(PropertiesLoaderUtils.java:73)
    at org.springframework.core.io.support.PropertiesLoaderUtils.loadProperties(PropertiesLoaderUtils.java:59)
    at org.springframework.core.io.support.ResourcePropertySource.<init>(ResourcePropertySource.java:86)
    at org.springframework.test.context.support.TestPropertySourceUtils.addPropertiesFilesToEnvironment(TestPropertySourceUtils.java:192)
    ... 71 more

試したこと、確認したこと

  • こちらの記事を参考に、各テストクラスに@SpringBootTestおよび@TestPropertySource(locations = "/test.properties")を記載しました。
  • sMySQLがビルドサーバーにもインストール済みか/該当のデータベースが存在するかを確認しました。

設定ファイル(test.properties)

###  データベース関連
spring.datasource.url=jdbc:mysql://localhost:3306/DBname?serverTimezone=JST
spring.datasource.username=root
spring.datasource.password=TestTest100!
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.jpa.open-in-view=true
# (1)初期化を行うかの指定。
spring.datasource.initialization-mode=always
# (2)初期化を行う際のモード。この場合は検証のみ。
spring.jpa.hibernate.ddl-auto=validate

###  メッセージ
spring.messages.basename=messages
spring.messages.encoding=UTF-8

環境

  • AmazonLinux2
  • Jenkins
  • SpringBoot 2.2.4
  • gradle6.0
  • MySQL 8.0

ディレクトリ構成はだいたい↓の感じです(上記サイトを引用させてもらいました)。

/my/good/project
 ├── README.md
 ├── pon.xml
 └── src
     ├── main
     │   ├── com
     │   │    └── ...
     │   └── resources
     │       └── application.properties
     └── test
         ├── com
         │    └── ...
         └── resources
             └── test.properties
             └── schema.sql(テスト用データ)
             └── testdata.sql(テスト用データ)


また、build.gradleも記載いたします。

plugins {
    id 'org.springframework.boot' version '2.2.4.RELEASE'
    id 'io.spring.dependency-management' version '1.0.9.RELEASE'
    id 'java'
    id 'war'
}
war {
    enabled = true
    archiveName = 'sample.war'
}

group = 'com.example'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '1.8'

configurations {
    developmentOnly
    runtimeClasspath {
        extendsFrom developmentOnly
    }
    compileOnly {
        extendsFrom annotationProcessor
    }
}

~中略~

dependencies {
~中略~
    runtimeOnly 'mysql:mysql-connector-java'
    testImplementation 'org.springframework.boot:spring-boot-starter-test'
}

//画面テストは除外
test {
    useJUnitPlatform()
    exclude 'com/example/demo/ViewTest.class'
}

作成したテストクラスの例

以下のようなテストクラスを作成しています。

@RunWith(SpringRunner.class)
@SpringBootTest
@TestPropertySource(locations = "/test.properties")
@AutoConfigureMockMvc
public class BusinessDateServiceImplTest {

    //依存しているDaoをモック化
    @MockBean
    BusinessDateDao mockDao;

    @Autowired
    BusinessDateService businessDateService;


    @Test
    public void 一件登録が機能する()throws Exception{
        //テスト用の空のEntityクラス用意
        BusinessDate businessDate = new BusinessDate();

        //Daoのvoidメソッドが実行されることを設定(void)
        doNothing().when(mockDao).insertDate(businessDate);

//~以下略~
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

0

SpringBootスタータープロジェクトから作成した直後は、src/test/resources がビルドパスに含まれていませんので追加します。

Javaのビルドパスから src/test/resourcesを追加し、その後に以下の2つの操作をします。

  • 出力フォルダーを targer/test-classes に変更
  • テスト・ソースを含む を はい に変更

イメージ説明

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/09/17 08:14

    僭越ながらリポジトリの方へプルリクエストを出しましたのでご確認ください。

    https://github.com/fftcysstkm/datemanager/pull/6

    キャンセル

  • 2020/09/17 20:26

    ご確認ありがとうございます。
    テストもビルドサーバーにインストールしたMySQLに接続するようにしておりました。ですので、dependenciesのh2は余計でした。
    しかし、接続するDBはtest.propertiesで決まると認識していましたので、残したままにしておりました。

    キャンセル

  • 2020/09/17 21:32

    DBの接続情報はあってますかね。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.92%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る