All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.opentelemetry.instrumentation.test.base.HttpServerTestTrait.groovy Maven / Gradle / Ivy

There is a newer version: 2.10.0-alpha
Show newest version
/*
 * Copyright The OpenTelemetry Authors
 * SPDX-License-Identifier: Apache-2.0
 */

package io.opentelemetry.instrumentation.test.base

import ch.qos.logback.classic.Level
import io.opentelemetry.instrumentation.test.RetryOnAddressAlreadyInUseTrait
import io.opentelemetry.instrumentation.test.utils.LoggerUtils
import io.opentelemetry.instrumentation.test.utils.PortUtils
import io.opentelemetry.instrumentation.testing.junit.http.AbstractHttpServerTest
import io.opentelemetry.testing.internal.armeria.client.ClientFactory
import io.opentelemetry.testing.internal.armeria.client.WebClient
import io.opentelemetry.testing.internal.armeria.client.logging.LoggingClient
import io.opentelemetry.testing.internal.armeria.common.HttpHeaderNames
import org.slf4j.Logger
import org.slf4j.LoggerFactory

import java.time.Duration

/**
 * A trait for testing requests against http server.
 */
trait HttpServerTestTrait implements RetryOnAddressAlreadyInUseTrait {
  static final Logger SERVER_LOGGER = LoggerFactory.getLogger("http-server")
  static {
    LoggerUtils.setLevel(SERVER_LOGGER, Level.DEBUG)
  }
  static final String TEST_CLIENT_IP = AbstractHttpServerTest.TEST_CLIENT_IP
  static final String TEST_USER_AGENT = AbstractHttpServerTest.TEST_USER_AGENT

  // not using SERVER as type because it triggers a bug in groovy and java joint compilation
  static Object server
  static WebClient client = WebClient.builder()
    .responseTimeout(Duration.ofMinutes(1))
    .writeTimeout(Duration.ofMinutes(1))
    .factory(ClientFactory.builder().connectTimeout(Duration.ofMinutes(1)).build())
    .setHeader(HttpHeaderNames.USER_AGENT, TEST_USER_AGENT)
    .setHeader(HttpHeaderNames.X_FORWARDED_FOR, TEST_CLIENT_IP)
    .decorator(LoggingClient.newDecorator())
    .build()
  static int port
  static URI address

  def setupServer() {
    withRetryOnAddressAlreadyInUse({
      setupSpecUnderRetry()
    })
  }

  def setupSpecUnderRetry() {
    port = PortUtils.findOpenPort()
    address = buildAddress()
    server = startServer(port)
    println getClass().name + " http server started at: http://localhost:$port" + getContextPath()
  }

  URI buildAddress() {
    return new URI("http://localhost:$port" + getContextPath() + "/")
  }

  abstract SERVER startServer(int port)

  def cleanupServer() {
    if (server == null) {
      println getClass().name + " can't stop null server"
      return
    }
    stopServer(server)
    server = null
    println getClass().name + " http server stopped at: http://localhost:$port/"
  }

  abstract void stopServer(SERVER server)

  String getContextPath() {
    return ""
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy