org.testcontainers.containers.wait.strategy.WaitStrategyTarget.getContainerInfo()方法的使用及代码示例

x33g5p2x  于2022-02-03 转载在 其他  
字(5.7k)|赞(0)|评价(0)|浏览(120)

本文整理了Java中org.testcontainers.containers.wait.strategy.WaitStrategyTarget.getContainerInfo()方法的一些代码示例,展示了WaitStrategyTarget.getContainerInfo()的具体用法。这些代码示例主要来源于Github/Stackoverflow/Maven等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。WaitStrategyTarget.getContainerInfo()方法的具体详情如下:
包路径:org.testcontainers.containers.wait.strategy.WaitStrategyTarget
类名称:WaitStrategyTarget
方法名:getContainerInfo

WaitStrategyTarget.getContainerInfo介绍

暂无

代码示例

代码示例来源:origin: testcontainers/testcontainers-java

  1. private void tryPort(Integer internalPort) {
  2. String[][] commands = {
  3. {"/bin/sh", "-c", format("cat /proc/net/tcp{,6} | awk '{print $2}' | grep -i :%x && echo %s", internalPort, SUCCESS_MARKER)},
  4. {"/bin/sh", "-c", format("nc -vz -w 1 localhost %d && echo %s", internalPort, SUCCESS_MARKER)},
  5. {"/bin/bash", "-c", format("</dev/tcp/localhost/%d && echo %s", internalPort, SUCCESS_MARKER)}
  6. };
  7. for (String[] command : commands) {
  8. try {
  9. if (ExecInContainerPattern.execInContainer(waitStrategyTarget.getContainerInfo(), command).getStdout().contains(SUCCESS_MARKER)) {
  10. return;
  11. }
  12. } catch (Exception e) {
  13. throw new IllegalStateException(e);
  14. }
  15. }
  16. throw new IllegalStateException("Socket not listening yet: " + internalPort);
  17. }
  18. }

代码示例来源:origin: testcontainers/testcontainers-java

  1. @Override
  2. protected void waitUntilReady() {
  3. final String containerName = waitStrategyTarget.getContainerInfo().getName();

代码示例来源:origin: testcontainers/testcontainers-java

  1. @Override
  2. protected void waitUntilReady() {
  3. final Set<Integer> externalLivenessCheckPorts = getLivenessCheckPorts();
  4. if (externalLivenessCheckPorts.isEmpty()) {
  5. log.debug("Liveness check ports of {} is empty. Not waiting.", waitStrategyTarget.getContainerInfo().getName());
  6. return;
  7. }
  8. @SuppressWarnings("unchecked")
  9. List<Integer> exposedPorts = waitStrategyTarget.getExposedPorts();
  10. final Set<Integer> internalPorts = getInternalPorts(externalLivenessCheckPorts, exposedPorts);
  11. Callable<Boolean> internalCheck = new InternalCommandPortListeningCheck(waitStrategyTarget, internalPorts);
  12. Callable<Boolean> externalCheck = new ExternalPortListeningCheck(waitStrategyTarget, externalLivenessCheckPorts);
  13. try {
  14. Unreliables.retryUntilTrue((int) startupTimeout.getSeconds(), TimeUnit.SECONDS,
  15. () -> getRateLimiter().getWhenReady(() -> internalCheck.call() && externalCheck.call()));
  16. } catch (TimeoutException e) {
  17. throw new ContainerLaunchException("Timed out waiting for container port to open (" +
  18. waitStrategyTarget.getContainerIpAddress() +
  19. " ports: " +
  20. externalLivenessCheckPorts +
  21. " should be listening)");
  22. }
  23. }

代码示例来源:origin: org.testcontainers/testcontainers

  1. private void tryPort(Integer internalPort) {
  2. String[][] commands = {{"/bin/sh", "-c", format("cat /proc/net/tcp{,6} | awk \'{print $2}\' | grep -i :%x && echo %s", internalPort, SUCCESS_MARKER)}, {"/bin/sh", "-c", format("nc -vz -w 1 localhost %d && echo %s", internalPort, SUCCESS_MARKER)}, {"/bin/bash", "-c", format("</dev/tcp/localhost/%d && echo %s", internalPort, SUCCESS_MARKER)}};
  3. for (String[] command : commands) {
  4. try {
  5. if (ExecInContainerPattern.execInContainer(waitStrategyTarget.getContainerInfo(), command).getStdout().contains(SUCCESS_MARKER)) {
  6. return;
  7. }
  8. } catch (Exception e) {
  9. throw new IllegalStateException(e);
  10. }
  11. }
  12. throw new IllegalStateException("Socket not listening yet: " + internalPort);
  13. }

代码示例来源:origin: org.testcontainers/testcontainers

  1. @Override
  2. protected void waitUntilReady() {
  3. final String containerName = waitStrategyTarget.getContainerInfo().getName();
  4. final Integer livenessCheckPort = livenessPort.map(waitStrategyTarget::getMappedPort).orElseGet(() -> {
  5. final Set<Integer> livenessCheckPorts = getLivenessCheckPorts();

代码示例来源:origin: org.testcontainers/testcontainers

  1. @Override
  2. protected void waitUntilReady() {
  3. final Set<Integer> externalLivenessCheckPorts = getLivenessCheckPorts();
  4. if (externalLivenessCheckPorts.isEmpty()) {
  5. log.debug("Liveness check ports of {} is empty. Not waiting.", waitStrategyTarget.getContainerInfo().getName());
  6. return;
  7. }
  8. @SuppressWarnings("unchecked")
  9. List<Integer> exposedPorts = waitStrategyTarget.getExposedPorts();
  10. final Set<Integer> internalPorts = getInternalPorts(externalLivenessCheckPorts, exposedPorts);
  11. Callable<Boolean> internalCheck = new InternalCommandPortListeningCheck(waitStrategyTarget, internalPorts);
  12. Callable<Boolean> externalCheck = new ExternalPortListeningCheck(waitStrategyTarget, externalLivenessCheckPorts);
  13. try {
  14. Unreliables.retryUntilTrue((int) startupTimeout.getSeconds(), TimeUnit.SECONDS, () -> getRateLimiter().getWhenReady(() -> internalCheck.call() && externalCheck.call()));
  15. } catch (TimeoutException e) {
  16. throw new ContainerLaunchException("Timed out waiting for container port to open (" + waitStrategyTarget.getContainerIpAddress() + " ports: " + externalLivenessCheckPorts + " should be listening)");
  17. }
  18. }

代码示例来源:origin: Playtika/testcontainers-spring-boot

  1. @Override
  2. protected boolean isReady() {
  3. String containerId = waitStrategyTarget.getContainerId();
  4. log.debug("Check Aerospike container {} status", containerId);
  5. InspectContainerResponse containerInfo = waitStrategyTarget.getContainerInfo();
  6. if (containerInfo == null) {
  7. log.debug("Aerospike container[{}] doesn't contain info. Abnormal situation, should not happen.", containerId);
  8. return false;
  9. }
  10. int port = getMappedPort(containerInfo.getNetworkSettings(), properties.port);
  11. String host = DockerClientFactory.instance().dockerHostIpAddress();
  12. //TODO: Remove dependency to client https://www.aerospike.com/docs/tools/asmonitor/common_tasks.html
  13. try (AerospikeClient client = new AerospikeClient(host, port)) {
  14. return client.isConnected();
  15. } catch (AerospikeException.Connection e) {
  16. log.debug("Aerospike container: {} not yet started. {}", containerId, e.getMessage());
  17. }
  18. return false;
  19. }

相关文章