Accept only ClassPathResource in ResourceHints#registerResource()
This commit throws an exception in registerResource() if the supplied resource is not a ClassPathResource. See gh-29083
This commit is contained in:
parent
7605ed7862
commit
649c2f56fd
|
|
@ -27,7 +27,6 @@ import java.util.stream.Stream;
|
||||||
import org.springframework.core.io.ClassPathResource;
|
import org.springframework.core.io.ClassPathResource;
|
||||||
import org.springframework.core.io.Resource;
|
import org.springframework.core.io.Resource;
|
||||||
import org.springframework.lang.Nullable;
|
import org.springframework.lang.Nullable;
|
||||||
import org.springframework.util.Assert;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gather the need for resources available at runtime.
|
* Gather the need for resources available at runtime.
|
||||||
|
|
@ -115,19 +114,19 @@ public class ResourceHints {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Register that the supplied resource should be made available at runtime.
|
* Register that the supplied resource should be made available at runtime.
|
||||||
* <p>If the supplied resource is not a {@link ClassPathResource}, it will
|
|
||||||
* not be registered.
|
|
||||||
* @param resource the resource to register
|
* @param resource the resource to register
|
||||||
* @throws IllegalArgumentException if the supplied class path resource does
|
* @throws IllegalArgumentException if the supplied resource is not a
|
||||||
* not {@linkplain Resource#exists() exist}
|
* {@link ClassPathResource} or does not {@linkplain Resource#exists() exist}
|
||||||
* @see #registerPattern(String)
|
* @see #registerPattern(String)
|
||||||
* @see ClassPathResource#getAbsolutePath()
|
* @see ClassPathResource#getAbsolutePath()
|
||||||
*/
|
*/
|
||||||
public void registerResource(Resource resource) {
|
public void registerResource(Resource resource) {
|
||||||
if (resource instanceof ClassPathResource classPathResource) {
|
if (resource instanceof ClassPathResource classPathResource && classPathResource.exists()) {
|
||||||
Assert.isTrue(classPathResource.exists(), () -> "Resource does not exist: " + classPathResource);
|
|
||||||
registerPattern(classPathResource.getAbsolutePath());
|
registerPattern(classPathResource.getAbsolutePath());
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
throw new IllegalArgumentException("Resource must be a ClassPathResource that exists: " + resource);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -117,8 +117,9 @@ class ResourceHintsTests {
|
||||||
@Test
|
@Test
|
||||||
void registerResourceWithUnsupportedResourceType() {
|
void registerResourceWithUnsupportedResourceType() {
|
||||||
DescriptiveResource resource = new DescriptiveResource("bogus");
|
DescriptiveResource resource = new DescriptiveResource("bogus");
|
||||||
this.resourceHints.registerResource(resource);
|
assertThatIllegalArgumentException()
|
||||||
assertThat(this.resourceHints.resourcePatterns()).isEmpty();
|
.isThrownBy(() -> this.resourceHints.registerResource(resource))
|
||||||
|
.withMessage("Resource must be a ClassPathResource that exists: %s", resource);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
@ -126,7 +127,7 @@ class ResourceHintsTests {
|
||||||
ClassPathResource resource = new ClassPathResource("bogus", getClass());
|
ClassPathResource resource = new ClassPathResource("bogus", getClass());
|
||||||
assertThatIllegalArgumentException()
|
assertThatIllegalArgumentException()
|
||||||
.isThrownBy(() -> this.resourceHints.registerResource(resource))
|
.isThrownBy(() -> this.resourceHints.registerResource(resource))
|
||||||
.withMessage("Resource does not exist: %s", resource);
|
.withMessage("Resource must be a ClassPathResource that exists: %s", resource);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue