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

io.gatling.http.ahc.AhcChannelPoolPartitioning.scala Maven / Gradle / Ivy

/**
 * Copyright 2011-2017 GatlingCorp (http://gatling.io)
 *
 * 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 io.gatling.http.ahc

import io.gatling.core.session.Session

import org.asynchttpclient.channel.{ ChannelPoolPartitioning, ChannelPoolPartitionSelector }
import org.asynchttpclient.proxy.ProxyServer
import org.asynchttpclient.uri.Uri

case class ChannelPoolKey(userId: Long, remoteKey: RemoteKey)

sealed trait RemoteKey
case class RemoteServerKey(scheme: String, hostname: String, port: Int) extends RemoteKey
case class VirtualHostKey(virtualHost: String) extends RemoteKey
case class ProxyServerKey(hostname: String, port: Int, secure: Boolean, targetHostKey: RemoteKey) extends RemoteKey

class AhcChannelPoolPartitioning(session: Session) extends ChannelPoolPartitioning {

  override def getPartitionKey(uri: Uri, virtualHost: String, proxyServer: ProxyServer): ChannelPoolKey = {

    val targetHostKey =
      if (virtualHost == null)
        RemoteServerKey(uri.getScheme, uri.getHost, uri.getExplicitPort)
      else
        VirtualHostKey(virtualHost)

    val remoteKey =
      if (proxyServer == null) {
        targetHostKey
      } else if (uri.isSecured) {
        new ProxyServerKey(proxyServer.getHost, proxyServer.getSecuredPort, true, targetHostKey)
      } else {
        new ProxyServerKey(proxyServer.getHost, proxyServer.getPort, false, targetHostKey)
      }

    ChannelPoolKey(session.userId, remoteKey)
  }
}

class AhcChannelPoolPartitionSelector(userId: Long) extends ChannelPoolPartitionSelector {

  override def select(partitionKey: Object): Boolean = partitionKey match {
    case ChannelPoolKey(`userId`, _) => true
    case _                           => false
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy