SOLR-14283 ensure that the test only runs on JVM's where it can succeeed

This commit is contained in:
Gus Heck 2020-02-28 14:20:35 -05:00
parent a703c6e334
commit f083067328
1 changed files with 23 additions and 17 deletions

View File

@ -35,6 +35,9 @@ public class SourceHomeNullifier extends TestWatcher {
@Override @Override
protected void starting(Description description) { protected void starting(Description description) {
// see https://stackoverflow.com/a/2591122
// this test is only meant to run under java < 9.0
if (System.getProperty("java.version").startsWith("1.")) {
boolean nullify = RandomizedContext.current().getRandom().nextBoolean(); boolean nullify = RandomizedContext.current().getRandom().nextBoolean();
if (nullify) { if (nullify) {
oldSourceHome = ExternalPaths.SOURCE_HOME; oldSourceHome = ExternalPaths.SOURCE_HOME;
@ -46,7 +49,7 @@ public class SourceHomeNullifier extends TestWatcher {
fail(e.getMessage()); fail(e.getMessage());
} }
} }
super.starting(description); }
} }
@SuppressForbidden(reason = "Need to tweak the value of a static final field on a per test basis") @SuppressForbidden(reason = "Need to tweak the value of a static final field on a per test basis")
@ -62,6 +65,9 @@ public class SourceHomeNullifier extends TestWatcher {
@Override @Override
protected void finished(Description description) { protected void finished(Description description) {
// see https://stackoverflow.com/a/2591122
// this test is only meant to run under java < 9.0
if (System.getProperty("java.version").startsWith("1.")) {
if (sourceHomeField != null) { if (sourceHomeField != null) {
try { try {
sourceHomeField.set(null, oldSourceHome); sourceHomeField.set(null, oldSourceHome);
@ -70,6 +76,6 @@ public class SourceHomeNullifier extends TestWatcher {
fail(e.getMessage()); fail(e.getMessage());
} }
} }
super.finished(description); }
} }
} }