Upgrade JiBX (and BCEL) towards support of 1.8 bytecode level
This commit also drops the now-unused CUSTOM_COMPILATION test group and the outdated JavaVersion class. Issue: SPR-10423
This commit is contained in:
		
							parent
							
								
									0aeb306b6d
								
							
						
					
					
						commit
						01110f678d
					
				
							
								
								
									
										13
									
								
								build.gradle
								
								
								
								
							
							
						
						
									
										13
									
								
								build.gradle
								
								
								
								
							|  | @ -514,13 +514,6 @@ project("spring-oxm") { | ||||||
| 	description = "Spring Object/XML Marshalling" | 	description = "Spring Object/XML Marshalling" | ||||||
| 	apply from: "oxm.gradle" | 	apply from: "oxm.gradle" | ||||||
| 
 | 
 | ||||||
| 	compileTestJava { |  | ||||||
| 		// necessary to avoid java.lang.VerifyError on jibx compilation |  | ||||||
| 		// see http://jira.codehaus.org/browse/JIBX-465 |  | ||||||
| 		sourceCompatibility = 1.8 |  | ||||||
| 		targetCompatibility = 1.8 |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	dependencies { | 	dependencies { | ||||||
| 		compile(project(":spring-beans")) | 		compile(project(":spring-beans")) | ||||||
| 		compile(project(":spring-core")) | 		compile(project(":spring-core")) | ||||||
|  | @ -539,10 +532,8 @@ project("spring-oxm") { | ||||||
| 		testCompile("org.codehaus.jettison:jettison:1.3.7") { | 		testCompile("org.codehaus.jettison:jettison:1.3.7") { | ||||||
| 			exclude group: 'stax', module: 'stax-api' | 			exclude group: 'stax', module: 'stax-api' | ||||||
| 		} | 		} | ||||||
| 		if (compileTestJava.enabled) { |         testCompile(files(genCastor.classesDir).builtBy(genCastor)) | ||||||
| 			testCompile(files(genCastor.classesDir).builtBy(genCastor)) |         testCompile(files(genJaxb.classesDir).builtBy(genJaxb)) | ||||||
| 			testCompile(files(genJaxb.classesDir).builtBy(genJaxb)) |  | ||||||
| 		} |  | ||||||
| 		testRuntime("xerces:xercesImpl:2.11.0")  // for Castor | 		testRuntime("xerces:xercesImpl:2.11.0")  // for Castor | ||||||
| 		testRuntime("javax.xml.bind:jaxb-api:${jaxbVersion}") | 		testRuntime("javax.xml.bind:jaxb-api:${jaxbVersion}") | ||||||
| 		testRuntime("com.sun.xml.bind:jaxb-core:${jaxbVersion}") | 		testRuntime("com.sun.xml.bind:jaxb-core:${jaxbVersion}") | ||||||
|  |  | ||||||
|  | @ -1,95 +0,0 @@ | ||||||
| /* |  | ||||||
|  * Copyright 2002-2015 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 org.springframework.tests; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * Enumeration of known JDK versions. |  | ||||||
|  * |  | ||||||
|  * @author Phillip Webb |  | ||||||
|  * @see #runningVersion() |  | ||||||
|  */ |  | ||||||
| public enum JavaVersion { |  | ||||||
| 
 |  | ||||||
| 	/** |  | ||||||
| 	 * Java 1.6 |  | ||||||
| 	 */ |  | ||||||
| 	JAVA_16("1.6", 16), |  | ||||||
| 
 |  | ||||||
| 	/** |  | ||||||
| 	 * Java 1.7 |  | ||||||
| 	 */ |  | ||||||
| 	JAVA_17("1.7", 17), |  | ||||||
| 
 |  | ||||||
| 	/** |  | ||||||
| 	 * Java 1.8 |  | ||||||
| 	 */ |  | ||||||
| 	JAVA_18("1.8", 18), |  | ||||||
| 
 |  | ||||||
| 	/** |  | ||||||
| 	 * Java 1.9 |  | ||||||
| 	 */ |  | ||||||
| 	JAVA_19("1.9", 19); |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 	private static final JavaVersion runningVersion = findRunningVersion(); |  | ||||||
| 
 |  | ||||||
| 	private static JavaVersion findRunningVersion() { |  | ||||||
| 		String version = System.getProperty("java.version"); |  | ||||||
| 		for (JavaVersion candidate : values()) { |  | ||||||
| 			if (version.startsWith(candidate.version)) { |  | ||||||
| 				return candidate; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		return JavaVersion.JAVA_16; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 	private String version; |  | ||||||
| 
 |  | ||||||
| 	private int value; |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 	private JavaVersion(String version, int value) { |  | ||||||
| 		this.version = version; |  | ||||||
| 		this.value = value; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	public String toString() { |  | ||||||
| 		return version; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	/** |  | ||||||
| 	 * Determines if the specified version is the same as or greater than this version. |  | ||||||
| 	 * @param version the version to check |  | ||||||
| 	 * @return {@code true} if the specified version is at least this version |  | ||||||
| 	 */ |  | ||||||
| 	public boolean isAtLeast(JavaVersion version) { |  | ||||||
| 		return (this.value >= version.value); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	/** |  | ||||||
| 	 * Returns the current running JDK version. If the current version cannot be |  | ||||||
| 	 * determined {@link #JAVA_16} will be returned. |  | ||||||
| 	 * @return the JDK version |  | ||||||
| 	 */ |  | ||||||
| 	public static JavaVersion runningVersion() { |  | ||||||
| 		return runningVersion; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | @ -58,14 +58,7 @@ public enum TestGroup { | ||||||
| 	/** | 	/** | ||||||
| 	 * Tests that should only be run on the continuous integration server. | 	 * Tests that should only be run on the continuous integration server. | ||||||
| 	 */ | 	 */ | ||||||
| 	CI, | 	CI; | ||||||
| 
 |  | ||||||
| 	/** |  | ||||||
| 	 * Tests that require custom compilation beyond that of the standard JDK. This helps to |  | ||||||
| 	 * allow running tests that will otherwise fail when using JDK >  1.8 b88. See |  | ||||||
| 	 * <a href="https://jira.spring.io/browse/SPR-10558">SPR-10558</a> |  | ||||||
| 	 */ |  | ||||||
| 	CUSTOM_COMPILATION; |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 	/** | 	/** | ||||||
|  |  | ||||||
|  | @ -38,6 +38,7 @@ public class TestGroupTests { | ||||||
| 	@Rule | 	@Rule | ||||||
| 	public ExpectedException thrown = ExpectedException.none(); | 	public ExpectedException thrown = ExpectedException.none(); | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| 	@Test | 	@Test | ||||||
| 	public void parseNull() throws Exception { | 	public void parseNull() throws Exception { | ||||||
| 		assertThat(TestGroup.parse(null), equalTo(Collections.<TestGroup> emptySet())); | 		assertThat(TestGroup.parse(null), equalTo(Collections.<TestGroup> emptySet())); | ||||||
|  | @ -65,7 +66,7 @@ public class TestGroupTests { | ||||||
| 		thrown.expect(IllegalArgumentException.class); | 		thrown.expect(IllegalArgumentException.class); | ||||||
| 		thrown.expectMessage("Unable to find test group 'missing' when parsing " + | 		thrown.expectMessage("Unable to find test group 'missing' when parsing " + | ||||||
| 				"testGroups value: 'performance, missing'. Available groups include: " + | 				"testGroups value: 'performance, missing'. Available groups include: " + | ||||||
| 				"[LONG_RUNNING,PERFORMANCE,JMXMP,CI,CUSTOM_COMPILATION]"); | 				"[LONG_RUNNING,PERFORMANCE,JMXMP,CI]"); | ||||||
| 		TestGroup.parse("performance, missing"); | 		TestGroup.parse("performance, missing"); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | @ -77,9 +78,8 @@ public class TestGroupTests { | ||||||
| 	@Test | 	@Test | ||||||
| 	public void parseAllExcept() throws Exception { | 	public void parseAllExcept() throws Exception { | ||||||
| 		Set<TestGroup> expected = new HashSet<>(EnumSet.allOf(TestGroup.class)); | 		Set<TestGroup> expected = new HashSet<>(EnumSet.allOf(TestGroup.class)); | ||||||
| 		expected.remove(TestGroup.CUSTOM_COMPILATION); |  | ||||||
| 		expected.remove(TestGroup.PERFORMANCE); | 		expected.remove(TestGroup.PERFORMANCE); | ||||||
| 		assertThat(TestGroup.parse("all-custom_compilation,performance"), equalTo(expected)); | 		assertThat(TestGroup.parse("all-performance"), equalTo(expected)); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -6,6 +6,7 @@ configurations { | ||||||
| dependencies { | dependencies { | ||||||
| 	castor "org.codehaus.castor:castor-anttasks:1.4.1" | 	castor "org.codehaus.castor:castor-anttasks:1.4.1" | ||||||
| 	jibx "org.jibx:jibx-bind:1.2.6" | 	jibx "org.jibx:jibx-bind:1.2.6" | ||||||
|  | 	jibx "org.apache.bcel:bcel:6.0" | ||||||
| 	xjc 'com.sun.xml.bind:jaxb-xjc:2.2.11' | 	xjc 'com.sun.xml.bind:jaxb-xjc:2.2.11' | ||||||
| 	xjc 'javax.xml.bind:jaxb-api:2.2.11' | 	xjc 'javax.xml.bind:jaxb-api:2.2.11' | ||||||
| 	xjc 'com.sun.xml.bind:jaxb-core:2.2.11' | 	xjc 'com.sun.xml.bind:jaxb-core:2.2.11' | ||||||
|  | @ -91,10 +92,8 @@ task genJaxb { | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // add jibx binding to the normal test compilation process | // JiBX compiler is currently not compatible with JDK 9 | ||||||
| // INCOMPATIBLE WITH OPENJDK 8 b89+ | if (JavaVersion.current() == JavaVersion.VERSION_1_8) { | ||||||
| def jibxEnabled = project.properties.get("testGroups")?.toLowerCase()?.split(",")?.contains("custom_compilation") |  | ||||||
| if (jibxEnabled) { |  | ||||||
| 	compileTestJava { | 	compileTestJava { | ||||||
| 		def bindingXml = "${projectDir}/src/test/resources/org/springframework/oxm/jibx/binding.xml" | 		def bindingXml = "${projectDir}/src/test/resources/org/springframework/oxm/jibx/binding.xml" | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -17,11 +17,10 @@ | ||||||
| package org.springframework.oxm.jibx; | package org.springframework.oxm.jibx; | ||||||
| 
 | 
 | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; |  | ||||||
| 
 | 
 | ||||||
| public class Flights { | public class Flights { | ||||||
| 
 | 
 | ||||||
| 	protected List<FlightType> flightList = new ArrayList<>(); | 	protected ArrayList<FlightType> flightList = new ArrayList<>(); | ||||||
| 
 | 
 | ||||||
| 	public void addFlight(FlightType flight) { | 	public void addFlight(FlightType flight) { | ||||||
| 		flightList.add(flight); | 		flightList.add(flight); | ||||||
|  |  | ||||||
|  | @ -1,5 +1,5 @@ | ||||||
| /* | /* | ||||||
|  * Copyright 2002-2015 the original author or authors. |  * Copyright 2002-2016 the original author or authors. | ||||||
|  * |  * | ||||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); |  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  * you may not use this file except in compliance with the License. |  * you may not use this file except in compliance with the License. | ||||||
|  | @ -16,19 +16,17 @@ | ||||||
| 
 | 
 | ||||||
| package org.springframework.oxm.jibx; | package org.springframework.oxm.jibx; | ||||||
| 
 | 
 | ||||||
|  | import java.io.StringWriter; | ||||||
|  | import javax.xml.transform.stream.StreamResult; | ||||||
|  | 
 | ||||||
|  | import org.junit.Assume; | ||||||
| import org.junit.BeforeClass; | import org.junit.BeforeClass; | ||||||
| import org.junit.Test; | import org.junit.Test; | ||||||
|  | 
 | ||||||
| import org.springframework.oxm.AbstractMarshallerTests; | import org.springframework.oxm.AbstractMarshallerTests; | ||||||
| import org.springframework.tests.Assume; |  | ||||||
| import org.springframework.tests.TestGroup; |  | ||||||
| 
 | 
 | ||||||
| import javax.xml.transform.stream.StreamResult; | import static org.junit.Assert.*; | ||||||
| import java.io.StringWriter; | import static org.xmlunit.matchers.CompareMatcher.*; | ||||||
| 
 |  | ||||||
| import static org.junit.Assert.assertFalse; |  | ||||||
| import static org.junit.Assert.assertThat; |  | ||||||
| import static org.junit.Assert.assertTrue; |  | ||||||
| import static org.xmlunit.matchers.CompareMatcher.isSimilarTo; |  | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * NOTE: These tests fail under Eclipse/IDEA because JiBX binding does not occur by |  * NOTE: These tests fail under Eclipse/IDEA because JiBX binding does not occur by | ||||||
|  | @ -41,7 +39,8 @@ public class JibxMarshallerTests extends AbstractMarshallerTests<JibxMarshaller> | ||||||
| 
 | 
 | ||||||
| 	@BeforeClass | 	@BeforeClass | ||||||
| 	public static void compilerAssumptions() { | 	public static void compilerAssumptions() { | ||||||
| 		Assume.group(TestGroup.CUSTOM_COMPILATION); | 		// JiBX compiler is currently not compatible with JDK 9 | ||||||
|  | 		Assume.assumeTrue(System.getProperty("java.version").startsWith("1.8.")); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	@Override | 	@Override | ||||||
|  |  | ||||||
|  | @ -1,5 +1,5 @@ | ||||||
| /* | /* | ||||||
|  * Copyright 2002-2015 the original author or authors. |  * Copyright 2002-2016 the original author or authors. | ||||||
|  * |  * | ||||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); |  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  * you may not use this file except in compliance with the License. |  * you may not use this file except in compliance with the License. | ||||||
|  | @ -19,12 +19,11 @@ package org.springframework.oxm.jibx; | ||||||
| import java.io.ByteArrayInputStream; | import java.io.ByteArrayInputStream; | ||||||
| import javax.xml.transform.stream.StreamSource; | import javax.xml.transform.stream.StreamSource; | ||||||
| 
 | 
 | ||||||
|  | import org.junit.Assume; | ||||||
| import org.junit.BeforeClass; | import org.junit.BeforeClass; | ||||||
| import org.junit.Test; | import org.junit.Test; | ||||||
| 
 | 
 | ||||||
| import org.springframework.oxm.AbstractUnmarshallerTests; | import org.springframework.oxm.AbstractUnmarshallerTests; | ||||||
| import org.springframework.tests.Assume; |  | ||||||
| import org.springframework.tests.TestGroup; |  | ||||||
| 
 | 
 | ||||||
| import static org.junit.Assert.*; | import static org.junit.Assert.*; | ||||||
| 
 | 
 | ||||||
|  | @ -41,9 +40,11 @@ public class JibxUnmarshallerTests extends AbstractUnmarshallerTests<JibxMarshal | ||||||
| 			"<tns:flights xmlns:tns=\"http://samples.springframework.org/flight\">" + | 			"<tns:flights xmlns:tns=\"http://samples.springframework.org/flight\">" + | ||||||
| 					"<tns:flight><tns:airline>Air Libert\u00e9</tns:airline><tns:number>42</tns:number></tns:flight></tns:flights>"; | 					"<tns:flight><tns:airline>Air Libert\u00e9</tns:airline><tns:number>42</tns:number></tns:flight></tns:flights>"; | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| 	@BeforeClass | 	@BeforeClass | ||||||
| 	public static void compilerAssumptions() { | 	public static void compilerAssumptions() { | ||||||
| 		Assume.group(TestGroup.CUSTOM_COMPILATION); | 		// JiBX compiler is currently not compatible with JDK 9 | ||||||
|  | 		Assume.assumeTrue(System.getProperty("java.version").startsWith("1.8.")); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue