Align TldPatterns with Tomcat default

Update `TldPatterns` to align with the latest default shipped by Tomcat.
This commit also introduces a test to ensure that we will remain aligned
going forwards.

Closes gh-25764
This commit is contained in:
Phillip Webb 2021-03-23 12:17:38 -07:00
parent 62023104de
commit 0ec8d281ef
5 changed files with 151 additions and 30 deletions

View File

@ -4,4 +4,5 @@ org.gradle.caching=true
org.gradle.parallel=true
org.gradle.jvmargs=-Xmx2g -Dfile.encoding=UTF-8
kotlinVersion=1.3.72
kotlinVersion=1.3.72
tomcatVersion=9.0.43

View File

@ -1807,7 +1807,7 @@ bom {
]
}
}
library("Tomcat", "9.0.43") {
library("Tomcat", "${tomcatVersion}") {
group("org.apache.tomcat") {
modules = [
"tomcat-annotations-api",

View File

@ -9,6 +9,12 @@ plugins {
description = "Spring Boot"
def tomcatConfigProperties = "$buildDir/tomcat-config-properties"
configurations {
tomcatDistribution
}
dependencies {
annotationProcessor("org.apache.logging.log4j:log4j-core")
@ -106,6 +112,22 @@ dependencies {
exclude group: "javax.annotation", module: "javax.annotation-api"
exclude group: "javax.xml.bind", module: "jaxb-api"
}
tomcatDistribution("org.apache.tomcat:tomcat:${tomcatVersion}@zip")
}
task extractTomcatConfigProperties(type: Sync) {
dependsOn configurations.tomcatDistribution
destinationDir = file(tomcatConfigProperties)
from(zipTree(configurations.tomcatDistribution.incoming.files.singleFile).matching {
include '**/conf/catalina.properties'
}.singleFile)
}
sourceSets {
test {
output.dir(tomcatConfigProperties, builtBy: "extractTomcatConfigProperties")
}
}
compileKotlin {

View File

@ -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.
@ -28,16 +28,30 @@ import java.util.Set;
*/
final class TldPatterns {
private static final Set<String> TOMCAT_SKIP;
static final Set<String> TOMCAT_SKIP;
static {
// Same as Tomcat
Set<String> skipPatterns = new LinkedHashSet<>();
skipPatterns.add("ant-*.jar");
skipPatterns.add("annotations-api.jar");
skipPatterns.add("ant-junit*.jar");
skipPatterns.add("ant-launcher.jar");
skipPatterns.add("ant.jar");
skipPatterns.add("asm-*.jar");
skipPatterns.add("aspectj*.jar");
skipPatterns.add("bootstrap.jar");
skipPatterns.add("catalina-ant.jar");
skipPatterns.add("catalina-ha.jar");
skipPatterns.add("catalina-ssi.jar");
skipPatterns.add("catalina-storeconfig.jar");
skipPatterns.add("catalina-tribes.jar");
skipPatterns.add("catalina.jar");
skipPatterns.add("cglib-*.jar");
skipPatterns.add("cobertura-*.jar");
skipPatterns.add("commons-beanutils*.jar");
skipPatterns.add("commons-codec*.jar");
skipPatterns.add("commons-collections*.jar");
skipPatterns.add("commons-daemon.jar");
skipPatterns.add("commons-dbcp*.jar");
skipPatterns.add("commons-digester*.jar");
skipPatterns.add("commons-fileupload*.jar");
@ -47,29 +61,59 @@ final class TldPatterns {
skipPatterns.add("commons-logging*.jar");
skipPatterns.add("commons-math*.jar");
skipPatterns.add("commons-pool*.jar");
skipPatterns.add("dom4j-*.jar");
skipPatterns.add("easymock-*.jar");
skipPatterns.add("ecj-*.jar");
skipPatterns.add("el-api.jar");
skipPatterns.add("geronimo-spec-jaxrpc*.jar");
skipPatterns.add("h2*.jar");
skipPatterns.add("hamcrest*.jar");
skipPatterns.add("hamcrest-*.jar");
skipPatterns.add("hibernate*.jar");
skipPatterns.add("jaxb-runtime-*.jar");
skipPatterns.add("jmx*.jar");
skipPatterns.add("jmx-tools-*.jar");
skipPatterns.add("httpclient*.jar");
skipPatterns.add("icu4j-*.jar");
skipPatterns.add("jasper-el.jar");
skipPatterns.add("jasper.jar");
skipPatterns.add("jaspic-api.jar");
skipPatterns.add("jaxb-*.jar");
skipPatterns.add("jaxen-*.jar");
skipPatterns.add("jdom-*.jar");
skipPatterns.add("jetty-*.jar");
skipPatterns.add("jmx-tools.jar");
skipPatterns.add("jmx.jar");
skipPatterns.add("jsp-api.jar");
skipPatterns.add("jstl.jar");
skipPatterns.add("jta*.jar");
skipPatterns.add("junit-*.jar");
skipPatterns.add("httpclient*.jar");
skipPatterns.add("log4j-*.jar");
skipPatterns.add("junit.jar");
skipPatterns.add("log4j*.jar");
skipPatterns.add("mail*.jar");
skipPatterns.add("org.hamcrest*.jar");
skipPatterns.add("objenesis-*.jar");
skipPatterns.add("oraclepki.jar");
skipPatterns.add("oro-*.jar");
skipPatterns.add("servlet-api-*.jar");
skipPatterns.add("servlet-api.jar");
skipPatterns.add("slf4j*.jar");
skipPatterns.add("tomcat-embed-core-*.jar");
skipPatterns.add("tomcat-embed-logging-*.jar");
skipPatterns.add("tomcat-jdbc-*.jar");
skipPatterns.add("tomcat-juli-*.jar");
skipPatterns.add("taglibs-standard-spec-*.jar");
skipPatterns.add("tagsoup-*.jar");
skipPatterns.add("tomcat-api.jar");
skipPatterns.add("tomcat-coyote.jar");
skipPatterns.add("tomcat-dbcp.jar");
skipPatterns.add("tomcat-i18n-*.jar");
skipPatterns.add("tomcat-jdbc.jar");
skipPatterns.add("tomcat-jni.jar");
skipPatterns.add("tomcat-juli-adapters.jar");
skipPatterns.add("tomcat-juli.jar");
skipPatterns.add("tomcat-util-scan.jar");
skipPatterns.add("tomcat-util.jar");
skipPatterns.add("tomcat-websocket.jar");
skipPatterns.add("tools.jar");
skipPatterns.add("websocket-api.jar");
skipPatterns.add("wsdl4j*.jar");
skipPatterns.add("xercesImpl-*.jar");
skipPatterns.add("xercesImpl.jar");
skipPatterns.add("xml-apis.jar");
skipPatterns.add("xmlParserAPIs-*.jar");
skipPatterns.add("xml-apis-*.jar");
skipPatterns.add("xmlParserAPIs.jar");
skipPatterns.add("xom-*.jar");
TOMCAT_SKIP = Collections.unmodifiableSet(skipPatterns);
}
@ -80,17 +124,9 @@ final class TldPatterns {
Set<String> skipPatterns = new LinkedHashSet<>();
skipPatterns.add("antlr-*.jar");
skipPatterns.add("aopalliance-*.jar");
skipPatterns.add("aspectjrt-*.jar");
skipPatterns.add("aspectjweaver-*.jar");
skipPatterns.add("classmate-*.jar");
skipPatterns.add("dom4j-*.jar");
skipPatterns.add("ecj-*.jar");
skipPatterns.add("ehcache-core-*.jar");
skipPatterns.add("hibernate-core-*.jar");
skipPatterns.add("hibernate-commons-annotations-*.jar");
skipPatterns.add("hibernate-entitymanager-*.jar");
skipPatterns.add("hibernate-jpa-2.1-api-*.jar");
skipPatterns.add("hibernate-validator-*.jar");
skipPatterns.add("hsqldb-*.jar");
skipPatterns.add("jackson-annotations-*.jar");
skipPatterns.add("jackson-core-*.jar");
@ -102,11 +138,9 @@ final class TldPatterns {
skipPatterns.add("jcl-over-slf4j-*.jar");
skipPatterns.add("jdom-*.jar");
skipPatterns.add("jul-to-slf4j-*.jar");
skipPatterns.add("log4j-over-slf4j-*.jar");
skipPatterns.add("logback-classic-*.jar");
skipPatterns.add("logback-core-*.jar");
skipPatterns.add("rome-*.jar");
skipPatterns.add("slf4j-api-*.jar");
skipPatterns.add("spring-aop-*.jar");
skipPatterns.add("spring-aspects-*.jar");
skipPatterns.add("spring-beans-*.jar");
@ -122,7 +156,6 @@ final class TldPatterns {
skipPatterns.add("snakeyaml-*.jar");
skipPatterns.add("tomcat-embed-el-*.jar");
skipPatterns.add("validation-api-*.jar");
skipPatterns.add("xml-apis-*.jar");
ADDITIONAL_SKIP = Collections.unmodifiableSet(skipPatterns);
}
@ -135,7 +168,7 @@ final class TldPatterns {
DEFAULT_SKIP = Collections.unmodifiableSet(skipPatterns);
}
private static final Set<String> TOMCAT_SCAN;
static final Set<String> TOMCAT_SCAN;
static {
Set<String> scanPatterns = new LinkedHashSet<>();

View File

@ -0,0 +1,65 @@
/*
* 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.
* You may obtain a copy of the License at
*
* https://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.boot.web.embedded.tomcat;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
import java.util.Set;
import org.junit.jupiter.api.Test;
import org.springframework.util.StringUtils;
import static org.assertj.core.api.Assertions.assertThat;
/**
* Tests for {@link TldPatterns}.
*
* @author Phillip Webb
*/
class TldPatternsTests {
@Test
void tomcatSkipAlignsWithTomcatDefaults() throws IOException {
assertThat(TldPatterns.TOMCAT_SKIP).containsExactlyInAnyOrderElementsOf(getTomcatDefaultJarsToSkip());
}
@Test
void tomcatScanAlignsWithTomcatDefaults() throws IOException {
assertThat(TldPatterns.TOMCAT_SCAN).containsExactlyInAnyOrderElementsOf(getTomcatDefaultJarsToScan());
}
private Set<String> getTomcatDefaultJarsToSkip() throws IOException {
return getTomcatDefault("tomcat.util.scan.StandardJarScanFilter.jarsToSkip");
}
private Set<String> getTomcatDefaultJarsToScan() throws IOException {
return getTomcatDefault("tomcat.util.scan.StandardJarScanFilter.jarsToScan");
}
private Set<String> getTomcatDefault(String key) throws IOException {
ClassLoader classLoader = getClass().getClassLoader();
try (InputStream inputStream = classLoader.getResource("catalina.properties").openStream()) {
Properties properties = new Properties();
properties.load(inputStream);
String jarsToSkip = properties.getProperty(key);
return StringUtils.commaDelimitedListToSet(jarsToSkip);
}
}
}