mirror of
https://gitee.com/dcren/initializr.git
synced 2025-12-03 03:44:05 +08:00
Add support for Java 9
This commit also removes explicit support for Java 6. The generator still supports it but Java 6 is no longer offered as an option in the UI. Closes gh-538
This commit is contained in:
@@ -0,0 +1,57 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-2017 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package io.spring.initializr.service.extension;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import io.spring.initializr.generator.ProjectRequest;
|
||||||
|
import io.spring.initializr.generator.ProjectRequestPostProcessor;
|
||||||
|
import io.spring.initializr.metadata.InitializrMetadata;
|
||||||
|
import io.spring.initializr.util.Version;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle corner cases when Java9 is required.
|
||||||
|
*
|
||||||
|
* @author Stephane Nicoll
|
||||||
|
*/
|
||||||
|
@Component
|
||||||
|
class Java9RequestPostProcessor implements ProjectRequestPostProcessor {
|
||||||
|
|
||||||
|
private static final Version VERSION_2_0_0_M1 = Version.parse("2.0.0.M1");
|
||||||
|
|
||||||
|
private static final List<String> UNSUPPORTED_LANGUAGES = Arrays.asList("groovy", "kotlin");
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void postProcessAfterResolution(ProjectRequest request, InitializrMetadata metadata) {
|
||||||
|
Version requestVersion = Version.safeParse(request.getBootVersion());
|
||||||
|
if (!"9".equals(request.getJavaVersion())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// Not supported for Spring Boot 1.x
|
||||||
|
if (VERSION_2_0_0_M1.compareTo(requestVersion) > 0) {
|
||||||
|
request.setJavaVersion("1.8");
|
||||||
|
}
|
||||||
|
// Not supported for Kotlin & Groovy
|
||||||
|
if (UNSUPPORTED_LANGUAGES.contains(request.getLanguage())) {
|
||||||
|
request.setJavaVersion("1.8");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -16,6 +16,9 @@
|
|||||||
|
|
||||||
package io.spring.initializr.service.extension;
|
package io.spring.initializr.service.extension;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import io.spring.initializr.generator.ProjectRequest;
|
import io.spring.initializr.generator.ProjectRequest;
|
||||||
import io.spring.initializr.generator.ProjectRequestPostProcessor;
|
import io.spring.initializr.generator.ProjectRequestPostProcessor;
|
||||||
import io.spring.initializr.metadata.InitializrMetadata;
|
import io.spring.initializr.metadata.InitializrMetadata;
|
||||||
@@ -34,12 +37,16 @@ class SpringBoot2RequestPostProcessor implements ProjectRequestPostProcessor {
|
|||||||
|
|
||||||
private static final Version VERSION_2_0_0_M1 = Version.parse("2.0.0.M1");
|
private static final Version VERSION_2_0_0_M1 = Version.parse("2.0.0.M1");
|
||||||
|
|
||||||
|
private static final List<String> VALID_VERSIONS = Arrays.asList("1.8", "9");
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void postProcessAfterResolution(ProjectRequest request, InitializrMetadata metadata) {
|
public void postProcessAfterResolution(ProjectRequest request, InitializrMetadata metadata) {
|
||||||
|
if (!VALID_VERSIONS.contains(request.getJavaVersion())) {
|
||||||
Version requestVersion = Version.safeParse(request.getBootVersion());
|
Version requestVersion = Version.safeParse(request.getBootVersion());
|
||||||
if (VERSION_2_0_0_M1.compareTo(requestVersion) <= 0) {
|
if (VERSION_2_0_0_M1.compareTo(requestVersion) <= 0) {
|
||||||
request.setJavaVersion("1.8");
|
request.setJavaVersion("1.8");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1251,11 +1251,13 @@ initializr:
|
|||||||
id: war
|
id: war
|
||||||
default: false
|
default: false
|
||||||
javaVersions:
|
javaVersions:
|
||||||
|
- id: 9
|
||||||
|
default: false
|
||||||
- id: 1.8
|
- id: 1.8
|
||||||
|
name: 8
|
||||||
default: true
|
default: true
|
||||||
- id: 1.7
|
- id: 1.7
|
||||||
default: false
|
name: 7
|
||||||
- id: 1.6
|
|
||||||
default: false
|
default: false
|
||||||
languages:
|
languages:
|
||||||
- name: Java
|
- name: Java
|
||||||
|
|||||||
@@ -0,0 +1,98 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-2017 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package io.spring.initializr.service.extension;
|
||||||
|
|
||||||
|
import io.spring.initializr.generator.ProjectRequest;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for {@link Java9RequestPostProcessor}.
|
||||||
|
*
|
||||||
|
* @author Stephane Nicoll
|
||||||
|
*/
|
||||||
|
public class Java9RequestPostProcessorTests
|
||||||
|
extends AbstractRequestPostProcessorTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CannotBeUsedWithSpringBoot1Maven() {
|
||||||
|
ProjectRequest request = createProjectRequest("web");
|
||||||
|
request.setBootVersion("1.5.8.RELEASE");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateMavenPom(request).hasJavaVersion("1.8");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CannotBeUsedWithSpringBoot1Gradle() {
|
||||||
|
ProjectRequest request = createProjectRequest("data-jpa");
|
||||||
|
request.setBootVersion("1.99.99.BUILD-SNAPSHOT");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateGradleBuild(request).hasJavaVersion("1.8");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CannotBeUsedWithGroovyMaven() {
|
||||||
|
ProjectRequest request = createProjectRequest("web");
|
||||||
|
request.setBootVersion("2.0.1.RELEASE");
|
||||||
|
request.setLanguage("groovy");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateMavenPom(request).hasJavaVersion("1.8");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CannotBeUsedWithKotlinMaven() {
|
||||||
|
ProjectRequest request = createProjectRequest("web");
|
||||||
|
request.setBootVersion("2.0.1.RELEASE");
|
||||||
|
request.setLanguage("kotlin");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateMavenPom(request).hasJavaVersion("1.8");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CannotBeUsedWithGroovyGradle() {
|
||||||
|
ProjectRequest request = createProjectRequest("data-jpa");
|
||||||
|
request.setBootVersion("2.0.1.RELEASE");
|
||||||
|
request.setLanguage("groovy");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateGradleBuild(request).hasJavaVersion("1.8");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CannotBeUsedWithKotlinGradle() {
|
||||||
|
ProjectRequest request = createProjectRequest("data-jpa");
|
||||||
|
request.setBootVersion("2.0.1.RELEASE");
|
||||||
|
request.setLanguage("kotlin");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateGradleBuild(request).hasJavaVersion("1.8");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CanBeUsedWithSpringBoot2Maven() {
|
||||||
|
ProjectRequest request = createProjectRequest("web");
|
||||||
|
request.setBootVersion("2.0.1.RELEASE");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateMavenPom(request).hasJavaVersion("9");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CanBeUsedWithSpringBoot2Gradle() {
|
||||||
|
ProjectRequest request = createProjectRequest("data-jpa");
|
||||||
|
request.setBootVersion("2.0.0.M3");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateGradleBuild(request).hasJavaVersion("9");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -43,4 +43,20 @@ public class SpringBoot2RequestPostProcessorTests
|
|||||||
generateGradleBuild(request).hasJavaVersion("1.8");
|
generateGradleBuild(request).hasJavaVersion("1.8");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CanBeUsedMaven() {
|
||||||
|
ProjectRequest request = createProjectRequest("web");
|
||||||
|
request.setBootVersion("2.0.0.BUILD-SNAPSHOT");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateMavenPom(request).hasJavaVersion("9");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void java9CanBeUsedGradle() {
|
||||||
|
ProjectRequest request = createProjectRequest("data-jpa");
|
||||||
|
request.setBootVersion("2.0.0.M3");
|
||||||
|
request.setJavaVersion("9");
|
||||||
|
generateGradleBuild(request).hasJavaVersion("9");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user