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
|
|
@ -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