Spring Boot 2.2.x の Web アプリを 2.3.x へバージョンアップする ( その3 )( Spring Boot を 2.2.9 → 2.3.2 へバージョンアップする )
概要
記事一覧はこちらです。
- 今回の手順で確認できるのは以下の内容です。
- Spring Boot を 2.2.9 → 2.3.2 へバージョンアップします。
参照したサイト・書籍
目次
手順
Spring Initializr で 2.3.2 のプロジェクトを作成する
Spring Initializr で 2.3.2 のプロジェクトを作成して、生成された build.gradle を見て反映した方が良い点があるか確認します。
※リストの一番下の「PostgreSQL Driver」もチェックします。
以下の build.gradle が作成されました。
plugins { id 'org.springframework.boot' version '2.3.2.RELEASE' id 'io.spring.dependency-management' version '1.0.9.RELEASE' id 'java' } group = 'com.example' version = '0.0.1-SNAPSHOT' sourceCompatibility = '11' configurations { compileOnly { extendsFrom annotationProcessor } } repositories { mavenCentral() } dependencies { implementation 'org.springframework.boot:spring-boot-starter-actuator' implementation 'org.springframework.boot:spring-boot-starter-data-jpa' implementation 'org.springframework.boot:spring-boot-starter-data-redis' implementation 'org.springframework.boot:spring-boot-starter-freemarker' implementation 'org.springframework.boot:spring-boot-starter-mail' implementation 'org.springframework.boot:spring-boot-starter-security' implementation 'org.springframework.boot:spring-boot-starter-thymeleaf' implementation 'org.springframework.boot:spring-boot-starter-web' implementation 'org.springframework.session:spring-session-data-redis' compileOnly 'org.projectlombok:lombok' developmentOnly 'org.springframework.boot:spring-boot-devtools' runtimeOnly 'org.postgresql:postgresql' annotationProcessor 'org.projectlombok:lombok' testImplementation('org.springframework.boot:spring-boot-starter-test') { exclude group: 'org.junit.vintage', module: 'junit-vintage-engine' } testImplementation 'org.springframework.security:spring-security-test' } test { useJUnitPlatform() }
以下の点を build.gradle に反映します。
- configurations block から以下の2行を削除します。
developmentOnly
runtimeClasspath.extendsFrom developmentOnly
build.gradle を変更する
buildscript { ext { group "ksbysample" version "2.3.2-RELEASE" } repositories { mavenCentral() maven { url "https://repo.spring.io/release/" } gradlePluginPortal() } } plugins { id "java" id "eclipse" id "idea" id "org.springframework.boot" version "2.3.2.RELEASE" id "io.spring.dependency-management" version "1.0.9.RELEASE" id "groovy" id "checkstyle" // id "com.github.spotbugs" version "3.0.0" id "pmd" id "net.ltgt.errorprone" version "1.1.1" id "com.gorylenko.gradle-git-properties" version "2.2.3" } .......... configurations { compileOnly.extendsFrom annotationProcessor // annotationProcessor と testAnnotationProcessor、compileOnly と testCompileOnly を併記不要にする testAnnotationProcessor.extendsFrom annotationProcessor testImplementation.extendsFrom compileOnly // for Doma 2 domaGenRuntime // for SpotBugs spotbugsStylesheets { transitive = false } } .......... dependencyManagement { imports { // mavenBom は以下の URL のものを使用する // https://repo.spring.io/release/org/springframework/boot/spring-boot-starter-parent/2.2.9.RELEASE/ // bomProperty に指定可能な property は以下の URL の BOM に記述がある // https://repo.spring.io/release/org/springframework/boot/spring-boot-dependencies/2.2.9.RELEASE/spring-boot-dependencies-2.2.9.RELEASE.pom mavenBom(org.springframework.boot.gradle.plugin.SpringBootPlugin.BOM_COORDINATES) { // Spring Boot の BOM に定義されているバージョンから変更する場合には、ここに以下のように記述する // bomProperty "thymeleaf.version", "3.0.9.RELEASE" bomProperty "groovy.version", "2.5.12" } mavenBom("org.junit:junit-bom:5.6.2") } } dependencies { def jdbcDriver = "org.postgresql:postgresql:42.2.14" def spockVersion = "1.3-groovy-2.5" def domaVersion = "2.26.0" def lombokVersion = "1.18.12" def errorproneVersion = "2.3.4" def powermockVersion = "2.0.7" def spotbugsVersion = "4.0.0-beta4" // dependency-management-plugin によりバージョン番号が自動で設定されるもの // Appendix F. Dependency versions ( https://docs.spring.io/spring-boot/docs/current/reference/html/appendix-dependency-versions.html ) 参照 implementation("org.springframework.boot:spring-boot-starter-web") implementation("org.springframework.boot:spring-boot-starter-thymeleaf") implementation("org.thymeleaf.extras:thymeleaf-extras-springsecurity5") implementation("org.springframework.boot:spring-boot-starter-data-jpa") implementation("org.springframework.boot:spring-boot-starter-freemarker") implementation("org.springframework.boot:spring-boot-starter-mail") implementation("org.springframework.boot:spring-boot-starter-security") implementation("org.springframework.boot:spring-boot-starter-data-redis") implementation("org.springframework.boot:spring-boot-starter-amqp") implementation("org.springframework.boot:spring-boot-starter-actuator") developmentOnly("org.springframework.boot:spring-boot-devtools") compileOnly("org.springframework.boot:spring-boot-configuration-processor") implementation("org.springframework.session:spring-session-data-redis") implementation("org.springframework.retry:spring-retry") implementation("com.fasterxml.jackson.dataformat:jackson-dataformat-xml") implementation("org.apache.commons:commons-lang3") implementation("org.codehaus.janino:janino") implementation("io.micrometer:micrometer-registry-prometheus") testImplementation("org.springframework.boot:spring-boot-starter-test") { exclude group: "org.junit.vintage", module: "junit-vintage-engine" } testImplementation("org.springframework.security:spring-security-test") testImplementation("org.yaml:snakeyaml") // dependency-management-plugin によりバージョン番号が自動で設定されないもの、あるいは最新バージョンを指定したいもの runtimeOnly("${jdbcDriver}") implementation("com.integralblue:log4jdbc-spring-boot-starter:2.0.0") implementation("org.simpleframework:simple-xml:2.7.1") implementation("com.univocity:univocity-parsers:2.8.4") implementation("com.google.guava:guava:29.0-jre") implementation("org.flywaydb:flyway-core:6.5.3") testImplementation("org.dbunit:dbunit:2.7.0") { exclude group: "postgresql", module: "postgresql" } testImplementation("com.icegreen:greenmail:1.5.14") testImplementation("org.assertj:assertj-core:3.16.1") testImplementation("com.jayway.jsonpath:json-path:2.4.0") testImplementation("org.jsoup:jsoup:1.13.1") testImplementation("cglib:cglib-nodep:3.3.0") testImplementation("org.spockframework:spock-core:${spockVersion}") testImplementation("org.spockframework:spock-spring:${spockVersion}") // for lombok // testAnnotationProcessor、testCompileOnly を併記しなくてよいよう configurations で設定している annotationProcessor("org.projectlombok:lombok:${lombokVersion}") compileOnly("org.projectlombok:lombok:${lombokVersion}") // for Doma annotationProcessor("org.seasar.doma:doma:${domaVersion}") implementation("org.seasar.doma:doma:${domaVersion}") domaGenRuntime("org.seasar.doma:doma-gen:${domaVersion}") domaGenRuntime("${jdbcDriver}") // for JUnit 5 // junit-jupiter で junit-jupiter-api, junit-jupiter-params, junit-jupiter-engine の3つが依存関係に追加される testImplementation("org.junit.jupiter:junit-jupiter") testRuntimeOnly("org.junit.platform:junit-platform-launcher") // for Error Prone ( http://errorprone.info/ ) errorprone("com.google.errorprone:error_prone_core:${errorproneVersion}") compileOnly("com.google.errorprone:error_prone_annotations:${errorproneVersion}") // PowerMock testImplementation("org.powermock:powermock-module-junit4:${powermockVersion}") testImplementation("org.powermock:powermock-api-mockito2:${powermockVersion}") // for SpotBugs // compileOnly("com.github.spotbugs:spotbugs:${spotbugsVersion}") { // exclude group: "pull-parser", module: "pull-parser" // } // compileOnly("net.jcip:jcip-annotations:1.0") compileOnly("com.github.spotbugs:spotbugs-annotations:${spotbugsVersion}") // testImplementation("com.google.code.findbugs:jsr305:3.0.2") // spotbugsStylesheets("com.github.spotbugs:spotbugs:${spotbugsVersion}") // spotbugsPlugins("com.h3xstream.findsecbugs:findsecbugs-plugin:1.10.1") } ..........
Spring Boot 2.3.2 へのバージョンアップとして以下の点を変更します。
- buildscript block の以下の点を変更します。
version "2.2.9-RELEASE"
→version "2.3.2-RELEASE"
- plugins block の以下の点を変更します。
id "org.springframework.boot" version "2.2.9.RELEASE"
→id "org.springframework.boot" version "2.3.2.RELEASE"
- configurations block から以下の2行を削除します。
developmentOnly
runtimeClasspath.extendsFrom developmentOnly
各種ライブラリのバージョンアップとして以下の点を変更します。
- plugins block の以下の点を変更します。
id "com.gorylenko.gradle-git-properties" version "2.2.0"
→id "com.gorylenko.gradle-git-properties" version "2.2.3"
- dependencyManagement block の以下の点を変更します。
mavenBom("org.junit:junit-bom:5.5.2")
→mavenBom("org.junit:junit-bom:5.6.2")
- dependencies block の以下の点を変更します。
def jdbcDriver = "org.postgresql:postgresql:42.2.9"
→def jdbcDriver = "org.postgresql:postgresql:42.2.14"
def lombokVersion = "1.18.10"
→def lombokVersion = "1.18.12"
def powermockVersion = "2.0.4"
→def powermockVersion = "2.0.7"
implementation("com.google.guava:guava:28.1-jre")
→implementation("com.google.guava:guava:29.0-jre")
implementation("org.flywaydb:flyway-core:6.1.3")
→implementation("org.flywaydb:flyway-core:6.5.3")
testImplementation("org.dbunit:dbunit:2.6.0")
→testImplementation("org.dbunit:dbunit:2.7.0")
testImplementation("com.icegreen:greenmail:1.5.11")
→testImplementation("com.icegreen:greenmail:1.5.14")
testImplementation("org.assertj:assertj-core:3.14.0")
→testImplementation("org.assertj:assertj-core:3.16.1")
testImplementation("org.jsoup:jsoup:1.12.1")
→testImplementation("org.jsoup:jsoup:1.13.1")
- Doma は domaGen タスクを変更する必要があるので後でバージョンアップします。
build タスク実行時に出るエラーを修正する
clean タスク実行 → Rebuild Project 実行。。。でエラーが出ました。パッケージjavax.validationは存在しません
のエラーメッセージが出力されています。
Spring Boot 2.3 Release Notes の Validation Starter no longer included in web starters の記述に従い implementation("org.springframework.boot:spring-boot-starter-validation")
を追加します。
dependencies { .......... implementation("org.springframework.boot:spring-boot-starter-web") implementation("org.springframework.boot:spring-boot-starter-validation")
再度 Rebuild Project 実行を実行すると、今度は以下の警告が出ます。
1つ目は org.springframework.boot.web.servlet.error.ErrorControllerのgetErrorPath()は推奨されません
で、ksbysample.webapp.lending.web.WebappErrorController クラスで getErrorPath メソッドを override していたのですが、
org.springframework.boot.web.servlet.error.ErrorController#getErrorPath メソッドを見ると Deprecated になっていました。エラーページの path は設定ファイルの server.error.path で設定することになったようです。
Spring Boot の Common Application properties のページを見ると server.error.path のデフォルト値は /error
で ksbysample.webapp.lending.web.WebappErrorController#getErrorPath メソッドが返す値と同じですので、override している ksbysample.webapp.lending.web.WebappErrorController#getErrorPath メソッドに @SuppressWarnings("deprecation")
を付与して警告が出ないようにします。
@SuppressWarnings("deprecation") @Override public String getErrorPath() { return "/error"; }
2つ目は org.junit.Assertの<T>assertThat(java.lang.String,T,org.hamcrest.Matcher<? super T>)は推奨されません
で、これは JUnit 4 の assertThat メソッドを呼び出していたことが原因でした。AssertJ の assertThat に変更します。
再度 clean タスク実行 → Rebuild Project 実行 → build タスクを実行すると無事 "BUILD SUCCESSFUL" のメッセージが出力されました。
履歴
2020/08/09
初版発行。