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

io.gatling.http.action.sse.SseOpenAction.scala Maven / Gradle / Ivy

/**
 * Copyright 2011-2014 eBusiness Information, Groupe Excilys (www.ebusinessinformation.fr)
 *
 * 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.action.sse

import akka.actor.ActorDSL.actor
import akka.actor.ActorRef
import com.ning.http.client.Request
import io.gatling.core.action.Interruptable
import io.gatling.core.session.{ Expression, Session }
import io.gatling.core.util.TimeHelper.nowMillis
import io.gatling.core.validation.{ Failure, Success }
import io.gatling.http.ahc.{ HttpEngine, SseTx }
import io.gatling.http.check.ws._
import io.gatling.http.config.HttpProtocol

class SseOpenAction(
    requestName: Expression[String],
    sseName: String,
    request: Expression[Request],
    checkBuilder: Option[WsCheckBuilder],
    val next: ActorRef,
    protocol: HttpProtocol) extends Interruptable with SseAction {

  override def execute(session: Session): Unit = {

      def open(tx: SseTx): Unit = {
        logger.info(s"Opening and getting sse '$sseName': Scenario '${session.scenarioName}', UserId #${session.userId}")
        val sseActor = actor(context)(new SseActor(sseName))
        HttpEngine.instance.startSseTransaction(tx, sseActor)
      }

    fetchSse(sseName, session) match {
      case _: Success[_] =>
        Failure(s"Unable to create a new SSE with name $sseName: Already exists")
      case _ =>
        for {
          requestName <- requestName(session)
          request <- request(session)
          check = checkBuilder.map(_.build)
        } yield open(SseTx(session, request, requestName, protocol, next, nowMillis, check = check))
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy