Skip to content

Commit

Permalink
Avoid illegal reflective access in CLI tests
Browse files Browse the repository at this point in the history
  • Loading branch information
dreis2211 committed Jun 16, 2021
1 parent 76ac18f commit 0ac2cd8
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 20 deletions.
1 change: 1 addition & 0 deletions spring-boot-project/spring-boot-cli/build.gradle
Expand Up @@ -56,6 +56,7 @@ dependencies {

loader(project(":spring-boot-project:spring-boot-tools:spring-boot-loader"))

testCompileOnly("org.apache.tomcat.embed:tomcat-embed-core")
testImplementation(project(":spring-boot-project:spring-boot"))
testImplementation(project(":spring-boot-project:spring-boot-tools:spring-boot-test-support"))
testImplementation(project(":spring-boot-project:spring-boot-test"))
Expand Down
@@ -1,5 +1,5 @@
/*
* Copyright 2012-2020 the original author or authors.
* Copyright 2012-2021 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.
Expand All @@ -22,9 +22,7 @@
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.lang.reflect.Field;
import java.net.URI;
import java.net.URL;
import java.nio.file.Files;
import java.util.ArrayList;
import java.util.List;
Expand Down Expand Up @@ -127,7 +125,6 @@ public File getTemp() {
}

private <T extends OptionParsingCommand> Future<T> submitCommand(T command, String... args) {
clearUrlHandler();
final String[] sources = getSources(args);
return Executors.newSingleThreadExecutor().submit(() -> {
ClassLoader loader = Thread.currentThread().getContextClassLoader();
Expand All @@ -152,21 +149,6 @@ private <T extends OptionParsingCommand> Future<T> submitCommand(T command, Stri
});
}

/**
* The TomcatURLStreamHandlerFactory fails if the factory is already set, use
* reflection to reset it.
*/
private void clearUrlHandler() {
try {
Field field = URL.class.getDeclaredField("factory");
field.setAccessible(true);
field.set(null, null);
}
catch (Exception ex) {
throw new IllegalStateException(ex);
}
}

protected String[] getSources(String... args) {
final String[] sources = new String[args.length];
for (int i = 0; i < args.length; i++) {
Expand Down
@@ -1,5 +1,5 @@
/*
* Copyright 2012-2019 the original author or authors.
* Copyright 2012-2021 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.
Expand All @@ -16,9 +16,12 @@

package org.springframework.boot.cli;

import org.apache.catalina.webresources.TomcatURLStreamHandlerFactory;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.web.context.WebServerPortFileWriter;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.util.ClassUtils;

/**
* Custom {@link SpringApplication} used by {@link CliTester}.
Expand All @@ -27,6 +30,13 @@
*/
public class CliTesterSpringApplication extends SpringApplication {

static {
if (ClassUtils.isPresent("org.apache.catalina.webresources.TomcatURLStreamHandlerFactory",
CliTesterSpringApplication.class.getClassLoader())) {
TomcatURLStreamHandlerFactory.disable();
}
}

public CliTesterSpringApplication(Class<?>... sources) {
super(sources);
}
Expand Down

0 comments on commit 0ac2cd8

Please sign in to comment.