15 changed files with 188 additions and 282 deletions
14
spring-boot-project/spring-boot-actuator-autoconfigure/src/test/java/org/springframework/boot/actuate/autoconfigure/metrics/Log4J2MetricsAutoConfigurationTests.java → spring-boot-project/spring-boot-actuator-autoconfigure/src/test/java/org/springframework/boot/actuate/autoconfigure/metrics/Log4J2MetricsWithLog4jLoggerContextAutoConfigurationTests.java
14
spring-boot-project/spring-boot-actuator-autoconfigure/src/test/java/org/springframework/boot/actuate/autoconfigure/metrics/Log4J2MetricsAutoConfigurationTests.java → spring-boot-project/spring-boot-actuator-autoconfigure/src/test/java/org/springframework/boot/actuate/autoconfigure/metrics/Log4J2MetricsWithLog4jLoggerContextAutoConfigurationTests.java
@ -1,17 +0,0 @@
@@ -1,17 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?> |
||||
<Configuration status="warn" name="test" packages=""> |
||||
<Properties> |
||||
<Property name="LOG_EXCEPTION_CONVERSION_WORD">%xwEx</Property> |
||||
<Property name="LOG_LEVEL_PATTERN">%5p</Property> |
||||
</Properties> |
||||
<Appenders> |
||||
<Console name="STDOUT" target="SYSTEM_OUT" follow="true"> |
||||
<PatternLayout pattern="%clr{%d{yyyy-MM-dd HH:mm:ss.SSS}}{faint} %clr{${LOG_LEVEL_PATTERN}} %clr{${sys:PID}}{magenta} %clr{---}{faint} %clr{[%15.15t]}{faint} %clr{%-40.40c{1.}}{cyan} %clr{:}{faint} %m%n${sys:LOG_EXCEPTION_CONVERSION_WORD}"/> |
||||
</Console> |
||||
</Appenders> |
||||
<Loggers> |
||||
<Root level="info"> |
||||
<AppenderRef ref="STDOUT"/> |
||||
</Root> |
||||
</Loggers> |
||||
</Configuration> |
||||
@ -1,112 +0,0 @@
@@ -1,112 +0,0 @@
|
||||
/* |
||||
* Copyright 2012-2018 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 |
||||
* |
||||
* http://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.autoconfigure.data.elasticsearch; |
||||
|
||||
import java.io.File; |
||||
import java.io.IOException; |
||||
import java.nio.file.Files; |
||||
import java.nio.file.Paths; |
||||
import java.util.Arrays; |
||||
import java.util.function.Consumer; |
||||
|
||||
import org.elasticsearch.common.settings.Settings; |
||||
import org.elasticsearch.node.InternalSettingsPreparer; |
||||
import org.elasticsearch.node.Node; |
||||
import org.elasticsearch.node.NodeValidationException; |
||||
import org.elasticsearch.transport.Netty4Plugin; |
||||
import org.elasticsearch.transport.Transport; |
||||
|
||||
/** |
||||
* Helper class for managing an Elasticsearch {@link Node}. |
||||
* |
||||
* @author Andy Wilkinson |
||||
*/ |
||||
public class ElasticsearchNodeTemplate { |
||||
|
||||
public void doWithNode(Consumer<ElasticsearchNode> consumer) { |
||||
System.setProperty("es.set.netty.runtime.available.processors", "false"); |
||||
Node node = null; |
||||
try { |
||||
node = startNode(); |
||||
consumer.accept(new ElasticsearchNode(node)); |
||||
} |
||||
catch (Exception ex) { |
||||
throw new RuntimeException(ex); |
||||
} |
||||
finally { |
||||
if (node != null) { |
||||
try { |
||||
node.close(); |
||||
} |
||||
catch (Exception ex) { |
||||
// Continue
|
||||
} |
||||
} |
||||
System.clearProperty("es.set.netty.runtime.available.processors"); |
||||
} |
||||
} |
||||
|
||||
private Node startNode() throws NodeValidationException { |
||||
Node node = new NettyTransportNode(); |
||||
node.start(); |
||||
return node; |
||||
} |
||||
|
||||
private static final class NettyTransportNode extends Node { |
||||
|
||||
private NettyTransportNode() { |
||||
super(InternalSettingsPreparer.prepareEnvironment(Settings.builder() |
||||
.put("path.home", "target/es/node").put("transport.type", "netty4") |
||||
.put("http.enabled", true).put("node.portsfile", true) |
||||
.put("http.port", 0).put("transport.tcp.port", 0).build(), null), |
||||
Arrays.asList(Netty4Plugin.class)); |
||||
new File("target/es/node/logs").mkdirs(); |
||||
} |
||||
|
||||
} |
||||
|
||||
public final class ElasticsearchNode { |
||||
|
||||
private final Node node; |
||||
|
||||
private ElasticsearchNode(Node node) { |
||||
this.node = node; |
||||
} |
||||
|
||||
public int getTcpPort() { |
||||
return this.node.injector().getInstance(Transport.class).boundAddress() |
||||
.publishAddress().getPort(); |
||||
} |
||||
|
||||
public int getHttpPort() { |
||||
try { |
||||
for (String line : Files |
||||
.readAllLines(Paths.get("target/es/node/logs/http.ports"))) { |
||||
if (line.startsWith("127.0.0.1")) { |
||||
return Integer.parseInt(line.substring(line.indexOf(":") + 1)); |
||||
} |
||||
} |
||||
throw new IllegalStateException("HTTP port not found"); |
||||
} |
||||
catch (IOException ex) { |
||||
throw new IllegalStateException("Failed to read HTTP port", ex); |
||||
} |
||||
} |
||||
|
||||
} |
||||
|
||||
} |
||||
@ -0,0 +1,57 @@
@@ -0,0 +1,57 @@
|
||||
/* |
||||
* Copyright 2012-2018 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 |
||||
* |
||||
* http://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.testsupport.testcontainers; |
||||
|
||||
import org.junit.runner.Description; |
||||
import org.junit.runners.model.Statement; |
||||
|
||||
/** |
||||
* A {@link Container} for Elasticsearch. |
||||
* |
||||
* @author Andy Wilkinson |
||||
*/ |
||||
public class ElasticsearchContainer extends Container { |
||||
|
||||
public ElasticsearchContainer() { |
||||
super("elasticsearch:6.4.3", 9200, (container) -> container.addExposedPort(9300)); |
||||
} |
||||
|
||||
public int getMappedTransportPort() { |
||||
return getContainer().getMappedPort(9300); |
||||
} |
||||
|
||||
@Override |
||||
public Statement apply(Statement base, Description description) { |
||||
Statement wrapped = super.apply(base, description); |
||||
return new Statement() { |
||||
|
||||
@Override |
||||
public void evaluate() throws Throwable { |
||||
System.setProperty("es.set.netty.runtime.available.processors", "false"); |
||||
try { |
||||
wrapped.evaluate(); |
||||
} |
||||
finally { |
||||
System.clearProperty("es.set.netty.runtime.available.processors"); |
||||
} |
||||
} |
||||
|
||||
}; |
||||
|
||||
} |
||||
|
||||
} |
||||
Loading…
Reference in new issue