Test: Fix forbidden uses in test framework (#32824)
This commit fixes existing uses of forbidden apis in the test framework and re-enables the forbidden apis check. It was previously completely disabled and had missed a rename of the forbidden apis signatures files. closes #32772
This commit is contained in:
parent
ab7e7508f5
commit
0158b59a5a
|
@ -28,19 +28,10 @@ subprojects {
|
||||||
apply plugin: 'nebula.maven-base-publish'
|
apply plugin: 'nebula.maven-base-publish'
|
||||||
apply plugin: 'nebula.maven-scm'
|
apply plugin: 'nebula.maven-scm'
|
||||||
|
|
||||||
|
|
||||||
// the main files are actually test files, so use the appropriate forbidden api sigs
|
|
||||||
forbiddenApisMain {
|
|
||||||
signaturesURLs = [PrecommitTasks.getResource('/forbidden/jdk-signatures.txt'),
|
|
||||||
PrecommitTasks.getResource('/forbidden/es-signatures.txt'),
|
|
||||||
PrecommitTasks.getResource('/forbidden/es-test-signatures.txt')]
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: should we have licenses for our test deps?
|
// TODO: should we have licenses for our test deps?
|
||||||
dependencyLicenses.enabled = false
|
dependencyLicenses.enabled = false
|
||||||
dependenciesInfo.enabled = false
|
dependenciesInfo.enabled = false
|
||||||
|
|
||||||
// TODO: why is the test framework pulled in...
|
// TODO: why is the test framework pulled in...
|
||||||
forbiddenApisMain.enabled = false
|
|
||||||
jarHell.enabled = false
|
jarHell.enabled = false
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
|
||||||
|
subprojects {
|
||||||
|
// fixtures are mostly external and by default we don't want to check forbidden apis
|
||||||
|
forbiddenApisMain.enabled = false
|
||||||
|
}
|
|
@ -41,8 +41,9 @@ compileTestJava.options.compilerArgs << '-Xlint:-rawtypes'
|
||||||
|
|
||||||
// the main files are actually test files, so use the appropriate forbidden api sigs
|
// the main files are actually test files, so use the appropriate forbidden api sigs
|
||||||
forbiddenApisMain {
|
forbiddenApisMain {
|
||||||
signaturesURLs = [PrecommitTasks.getResource('/forbidden/all-signatures.txt'),
|
signaturesURLs = [PrecommitTasks.getResource('/forbidden/jdk-signatures.txt'),
|
||||||
PrecommitTasks.getResource('/forbidden/test-signatures.txt')]
|
PrecommitTasks.getResource('/forbidden/es-all-signatures.txt'),
|
||||||
|
PrecommitTasks.getResource('/forbidden/es-test-signatures.txt')]
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: should we have licenses for our test deps?
|
// TODO: should we have licenses for our test deps?
|
||||||
|
|
|
@ -67,7 +67,7 @@ public abstract class AnalysisFactoryTestCase extends ESTestCase {
|
||||||
Matcher m = UNDERSCORE_THEN_ANYTHING.matcher(s);
|
Matcher m = UNDERSCORE_THEN_ANYTHING.matcher(s);
|
||||||
StringBuffer sb = new StringBuffer();
|
StringBuffer sb = new StringBuffer();
|
||||||
while (m.find()) {
|
while (m.find()) {
|
||||||
m.appendReplacement(sb, m.group(1).toUpperCase());
|
m.appendReplacement(sb, m.group(1).toUpperCase(Locale.ROOT));
|
||||||
}
|
}
|
||||||
m.appendTail(sb);
|
m.appendTail(sb);
|
||||||
sb.setCharAt(0, Character.toUpperCase(sb.charAt(0)));
|
sb.setCharAt(0, Character.toUpperCase(sb.charAt(0)));
|
||||||
|
|
|
@ -21,7 +21,6 @@ package org.elasticsearch.test;
|
||||||
|
|
||||||
import com.carrotsearch.randomizedtesting.RandomizedTest;
|
import com.carrotsearch.randomizedtesting.RandomizedTest;
|
||||||
import com.carrotsearch.randomizedtesting.SeedUtils;
|
import com.carrotsearch.randomizedtesting.SeedUtils;
|
||||||
|
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.util.Accountable;
|
import org.apache.lucene.util.Accountable;
|
||||||
import org.elasticsearch.Version;
|
import org.elasticsearch.Version;
|
||||||
|
@ -42,6 +41,7 @@ import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.settings.SettingsModule;
|
import org.elasticsearch.common.settings.SettingsModule;
|
||||||
import org.elasticsearch.common.xcontent.NamedXContentRegistry;
|
import org.elasticsearch.common.xcontent.NamedXContentRegistry;
|
||||||
|
import org.elasticsearch.core.internal.io.IOUtils;
|
||||||
import org.elasticsearch.env.Environment;
|
import org.elasticsearch.env.Environment;
|
||||||
import org.elasticsearch.env.TestEnvironment;
|
import org.elasticsearch.env.TestEnvironment;
|
||||||
import org.elasticsearch.index.Index;
|
import org.elasticsearch.index.Index;
|
||||||
|
@ -194,8 +194,8 @@ public abstract class AbstractBuilderTestCase extends ESTestCase {
|
||||||
|
|
||||||
@AfterClass
|
@AfterClass
|
||||||
public static void afterClass() throws Exception {
|
public static void afterClass() throws Exception {
|
||||||
org.apache.lucene.util.IOUtils.close(serviceHolder);
|
IOUtils.close(serviceHolder);
|
||||||
org.apache.lucene.util.IOUtils.close(serviceHolderWithNoType);
|
IOUtils.close(serviceHolderWithNoType);
|
||||||
serviceHolder = null;
|
serviceHolder = null;
|
||||||
serviceHolderWithNoType = null;
|
serviceHolderWithNoType = null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -54,6 +54,7 @@ import org.elasticsearch.cluster.ClusterModule;
|
||||||
import org.elasticsearch.cluster.metadata.IndexMetaData;
|
import org.elasticsearch.cluster.metadata.IndexMetaData;
|
||||||
import org.elasticsearch.common.CheckedBiFunction;
|
import org.elasticsearch.common.CheckedBiFunction;
|
||||||
import org.elasticsearch.common.CheckedRunnable;
|
import org.elasticsearch.common.CheckedRunnable;
|
||||||
|
import org.elasticsearch.common.SuppressForbidden;
|
||||||
import org.elasticsearch.common.bytes.BytesReference;
|
import org.elasticsearch.common.bytes.BytesReference;
|
||||||
import org.elasticsearch.common.io.PathUtils;
|
import org.elasticsearch.common.io.PathUtils;
|
||||||
import org.elasticsearch.common.io.PathUtilsForTesting;
|
import org.elasticsearch.common.io.PathUtilsForTesting;
|
||||||
|
@ -198,13 +199,9 @@ public abstract class ESTestCase extends LuceneTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
static {
|
static {
|
||||||
System.setProperty("log4j.shutdownHookEnabled", "false");
|
setTestSysProps();
|
||||||
System.setProperty("log4j2.disable.jmx", "true");
|
|
||||||
|
|
||||||
LogConfigurator.loadLog4jPlugins();
|
LogConfigurator.loadLog4jPlugins();
|
||||||
|
|
||||||
// Enable Netty leak detection and monitor logger for logged leak errors
|
|
||||||
System.setProperty("io.netty.leakDetection.level", "paranoid");
|
|
||||||
String leakLoggerName = "io.netty.util.ResourceLeakDetector";
|
String leakLoggerName = "io.netty.util.ResourceLeakDetector";
|
||||||
Logger leakLogger = LogManager.getLogger(leakLoggerName);
|
Logger leakLogger = LogManager.getLogger(leakLoggerName);
|
||||||
Appender leakAppender = new AbstractAppender(leakLoggerName, null,
|
Appender leakAppender = new AbstractAppender(leakLoggerName, null,
|
||||||
|
@ -243,6 +240,14 @@ public abstract class ESTestCase extends LuceneTestCase {
|
||||||
Collections.sort(javaZoneIds);
|
Collections.sort(javaZoneIds);
|
||||||
JAVA_ZONE_IDS = Collections.unmodifiableList(javaZoneIds);
|
JAVA_ZONE_IDS = Collections.unmodifiableList(javaZoneIds);
|
||||||
}
|
}
|
||||||
|
@SuppressForbidden(reason = "force log4j and netty sysprops")
|
||||||
|
private static void setTestSysProps() {
|
||||||
|
System.setProperty("log4j.shutdownHookEnabled", "false");
|
||||||
|
System.setProperty("log4j2.disable.jmx", "true");
|
||||||
|
|
||||||
|
// Enable Netty leak detection and monitor logger for logged leak errors
|
||||||
|
System.setProperty("io.netty.leakDetection.level", "paranoid");
|
||||||
|
}
|
||||||
|
|
||||||
protected final Logger logger = Loggers.getLogger(getClass());
|
protected final Logger logger = Loggers.getLogger(getClass());
|
||||||
protected final DeprecationLogger deprecationLogger = new DeprecationLogger(logger);
|
protected final DeprecationLogger deprecationLogger = new DeprecationLogger(logger);
|
||||||
|
|
|
@ -20,6 +20,8 @@
|
||||||
package org.elasticsearch.test.fixture;
|
package org.elasticsearch.test.fixture;
|
||||||
|
|
||||||
import com.sun.net.httpserver.HttpServer;
|
import com.sun.net.httpserver.HttpServer;
|
||||||
|
import org.elasticsearch.common.SuppressForbidden;
|
||||||
|
import org.elasticsearch.common.io.PathUtils;
|
||||||
|
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -32,7 +34,6 @@ import java.net.SocketAddress;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.nio.file.Paths;
|
|
||||||
import java.nio.file.StandardCopyOption;
|
import java.nio.file.StandardCopyOption;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -48,6 +49,7 @@ import static java.util.Collections.singletonMap;
|
||||||
/**
|
/**
|
||||||
* Base class for test fixtures that requires a {@link HttpServer} to work.
|
* Base class for test fixtures that requires a {@link HttpServer} to work.
|
||||||
*/
|
*/
|
||||||
|
@SuppressForbidden(reason = "uses httpserver by design")
|
||||||
public abstract class AbstractHttpFixture {
|
public abstract class AbstractHttpFixture {
|
||||||
|
|
||||||
protected static final Map<String, String> TEXT_PLAIN_CONTENT_TYPE = contentType("text/plain; charset=utf-8");
|
protected static final Map<String, String> TEXT_PLAIN_CONTENT_TYPE = contentType("text/plain; charset=utf-8");
|
||||||
|
@ -62,7 +64,7 @@ public abstract class AbstractHttpFixture {
|
||||||
private final Path workingDirectory;
|
private final Path workingDirectory;
|
||||||
|
|
||||||
protected AbstractHttpFixture(final String workingDir) {
|
protected AbstractHttpFixture(final String workingDir) {
|
||||||
this.workingDirectory = Paths.get(Objects.requireNonNull(workingDir));
|
this.workingDirectory = PathUtils.get(Objects.requireNonNull(workingDir));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -22,6 +22,7 @@ import com.carrotsearch.randomizedtesting.ReproduceErrorMessageBuilder;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.apache.lucene.util.Constants;
|
import org.apache.lucene.util.Constants;
|
||||||
import org.elasticsearch.common.Strings;
|
import org.elasticsearch.common.Strings;
|
||||||
|
import org.elasticsearch.common.SuppressForbidden;
|
||||||
import org.elasticsearch.common.logging.Loggers;
|
import org.elasticsearch.common.logging.Loggers;
|
||||||
import org.elasticsearch.test.ESIntegTestCase;
|
import org.elasticsearch.test.ESIntegTestCase;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
|
@ -86,7 +87,12 @@ public class ReproduceInfoPrinter extends RunListener {
|
||||||
gradleMessageBuilder.appendClientYamlSuiteProperties();
|
gradleMessageBuilder.appendClientYamlSuiteProperties();
|
||||||
}
|
}
|
||||||
|
|
||||||
System.err.println(b.toString());
|
printToErr(b.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressForbidden(reason = "printing repro info")
|
||||||
|
private static void printToErr(String s) {
|
||||||
|
System.err.println(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static class GradleMessageBuilder extends ReproduceErrorMessageBuilder {
|
protected static class GradleMessageBuilder extends ReproduceErrorMessageBuilder {
|
||||||
|
|
|
@ -29,6 +29,7 @@ import org.elasticsearch.Version;
|
||||||
import org.elasticsearch.action.ActionListenerResponseHandler;
|
import org.elasticsearch.action.ActionListenerResponseHandler;
|
||||||
import org.elasticsearch.action.support.PlainActionFuture;
|
import org.elasticsearch.action.support.PlainActionFuture;
|
||||||
import org.elasticsearch.cluster.node.DiscoveryNode;
|
import org.elasticsearch.cluster.node.DiscoveryNode;
|
||||||
|
import org.elasticsearch.common.SuppressForbidden;
|
||||||
import org.elasticsearch.common.io.stream.BytesStreamOutput;
|
import org.elasticsearch.common.io.stream.BytesStreamOutput;
|
||||||
import org.elasticsearch.common.io.stream.NamedWriteableRegistry;
|
import org.elasticsearch.common.io.stream.NamedWriteableRegistry;
|
||||||
import org.elasticsearch.common.io.stream.StreamInput;
|
import org.elasticsearch.common.io.stream.StreamInput;
|
||||||
|
@ -64,6 +65,7 @@ import java.net.InetAddress;
|
||||||
import java.net.InetSocketAddress;
|
import java.net.InetSocketAddress;
|
||||||
import java.net.ServerSocket;
|
import java.net.ServerSocket;
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
|
import java.net.UnknownHostException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
@ -1894,7 +1896,7 @@ public abstract class AbstractSimpleTransportTestCase extends ESTestCase {
|
||||||
// means that once we received an ACK from the client we just drop the packet on the floor (which is what we want) and we run
|
// means that once we received an ACK from the client we just drop the packet on the floor (which is what we want) and we run
|
||||||
// into a connection timeout quickly. Yet other implementations can for instance can terminate the connection within the 3 way
|
// into a connection timeout quickly. Yet other implementations can for instance can terminate the connection within the 3 way
|
||||||
// handshake which I haven't tested yet.
|
// handshake which I haven't tested yet.
|
||||||
socket.bind(new InetSocketAddress(InetAddress.getLocalHost(), 0), 1);
|
socket.bind(getLocalEphemeral(), 1);
|
||||||
socket.setReuseAddress(true);
|
socket.setReuseAddress(true);
|
||||||
DiscoveryNode first = new DiscoveryNode("TEST", new TransportAddress(socket.getInetAddress(),
|
DiscoveryNode first = new DiscoveryNode("TEST", new TransportAddress(socket.getInetAddress(),
|
||||||
socket.getLocalPort()), emptyMap(),
|
socket.getLocalPort()), emptyMap(),
|
||||||
|
@ -2008,7 +2010,7 @@ public abstract class AbstractSimpleTransportTestCase extends ESTestCase {
|
||||||
|
|
||||||
public void testTcpHandshakeTimeout() throws IOException {
|
public void testTcpHandshakeTimeout() throws IOException {
|
||||||
try (ServerSocket socket = new MockServerSocket()) {
|
try (ServerSocket socket = new MockServerSocket()) {
|
||||||
socket.bind(new InetSocketAddress(InetAddress.getLocalHost(), 0), 1);
|
socket.bind(getLocalEphemeral(), 1);
|
||||||
socket.setReuseAddress(true);
|
socket.setReuseAddress(true);
|
||||||
DiscoveryNode dummy = new DiscoveryNode("TEST", new TransportAddress(socket.getInetAddress(),
|
DiscoveryNode dummy = new DiscoveryNode("TEST", new TransportAddress(socket.getInetAddress(),
|
||||||
socket.getLocalPort()), emptyMap(),
|
socket.getLocalPort()), emptyMap(),
|
||||||
|
@ -2029,7 +2031,7 @@ public abstract class AbstractSimpleTransportTestCase extends ESTestCase {
|
||||||
|
|
||||||
public void testTcpHandshakeConnectionReset() throws IOException, InterruptedException {
|
public void testTcpHandshakeConnectionReset() throws IOException, InterruptedException {
|
||||||
try (ServerSocket socket = new MockServerSocket()) {
|
try (ServerSocket socket = new MockServerSocket()) {
|
||||||
socket.bind(new InetSocketAddress(InetAddress.getLocalHost(), 0), 1);
|
socket.bind(getLocalEphemeral(), 1);
|
||||||
socket.setReuseAddress(true);
|
socket.setReuseAddress(true);
|
||||||
DiscoveryNode dummy = new DiscoveryNode("TEST", new TransportAddress(socket.getInetAddress(),
|
DiscoveryNode dummy = new DiscoveryNode("TEST", new TransportAddress(socket.getInetAddress(),
|
||||||
socket.getLocalPort()), emptyMap(),
|
socket.getLocalPort()), emptyMap(),
|
||||||
|
@ -2665,4 +2667,8 @@ public abstract class AbstractSimpleTransportTestCase extends ESTestCase {
|
||||||
|
|
||||||
protected abstract void closeConnectionChannel(Transport transport, Transport.Connection connection) throws IOException;
|
protected abstract void closeConnectionChannel(Transport transport, Transport.Connection connection) throws IOException;
|
||||||
|
|
||||||
|
@SuppressForbidden(reason = "need local ephemeral port")
|
||||||
|
private InetSocketAddress getLocalEphemeral() throws UnknownHostException {
|
||||||
|
return new InetSocketAddress(InetAddress.getLocalHost(), 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.transport;
|
package org.elasticsearch.transport;
|
||||||
|
|
||||||
|
import org.elasticsearch.cli.SuppressForbidden;
|
||||||
import org.elasticsearch.core.internal.io.IOUtils;
|
import org.elasticsearch.core.internal.io.IOUtils;
|
||||||
import org.elasticsearch.Version;
|
import org.elasticsearch.Version;
|
||||||
import org.elasticsearch.action.ActionListener;
|
import org.elasticsearch.action.ActionListener;
|
||||||
|
@ -160,6 +161,7 @@ public class MockTcpTransport extends TcpTransport {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@SuppressForbidden(reason = "real socket for mocking remote connections")
|
||||||
protected MockChannel initiateChannel(InetSocketAddress address, ActionListener<Void> connectListener) throws IOException {
|
protected MockChannel initiateChannel(InetSocketAddress address, ActionListener<Void> connectListener) throws IOException {
|
||||||
final MockSocket socket = new MockSocket();
|
final MockSocket socket = new MockSocket();
|
||||||
final MockChannel channel = new MockChannel(socket, address, "none");
|
final MockChannel channel = new MockChannel(socket, address, "none");
|
||||||
|
|
Loading…
Reference in New Issue