io.gatling.http.action.polling.Poller.scala Maven / Gradle / Ivy
/*
* Copyright 2011-2020 GatlingCorp (https://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.action.polling
import java.util.concurrent.{ ScheduledFuture, TimeUnit }
import scala.concurrent.duration.FiniteDuration
import io.gatling.commons.util.Clock
import io.gatling.commons.validation.{ Success, Validation }
import io.gatling.core.action.Action
import io.gatling.core.session.Session
import io.gatling.core.stats.StatsEngine
import io.gatling.http.cache.HttpCaches
import io.gatling.http.engine.response.{ ResponseProcessor, RootSessionProcessor }
import io.gatling.http.engine.tx.{ HttpTx, HttpTxExecutor }
import io.gatling.http.protocol.HttpProtocol
import io.gatling.http.request.HttpRequestDef
import io.gatling.http.response.HttpResult
import com.typesafe.scalalogging.StrictLogging
private[polling] class Poller(
pollerName: String,
period: FiniteDuration,
requestDef: HttpRequestDef,
httpTxExecutor: HttpTxExecutor,
httpCaches: HttpCaches,
httpProtocol: HttpProtocol,
statsEngine: StatsEngine,
clock: Clock
) extends StrictLogging {
private var session: Session = _
private var timer: ScheduledFuture[_] = _
def start(session: Session): Unit =
timer = session.eventLoop.scheduleAtFixedRate(() => poll(), 0, period.toMillis, TimeUnit.MILLISECONDS)
// FIXME is currently static
private def buildHttpTx(): Validation[HttpTx] =
for {
requestName <- requestDef.requestName(session).mapError { errorMessage =>
logger.error(s"'$pollerName' failed to execute: $errorMessage")
errorMessage
}
httpRequest <- requestDef.build(requestName, session).mapError { errorMessage =>
statsEngine.reportUnbuildableRequest(session.scenario, session.groups, pollerName, errorMessage)
errorMessage
}
} yield HttpTx(session, httpRequest, next = null, resourceTx = None, redirectCount = 0)
private def poll(): Unit =
buildHttpTx() match {
case Success(tx) =>
httpTxExecutor.execute(
tx,
tx =>
new ResponseProcessor() {
override def onComplete(result: HttpResult): Unit =
// FIXME not great, should we cancel timer on request failure?
session = resourceFetched(tx, result)
}
)
case _ =>
timer.cancel(false)
session = session.markAsFailed
}
private def resourceFetched(tx: HttpTx, result: HttpResult): Session =
new PollerResponseProcessor(
tx.copy(session = session),
sessionProcessor = new RootSessionProcessor(
tx.silent,
tx.request.clientRequest,
tx.request.requestConfig.checks,
httpCaches,
httpProtocol,
clock
),
statsProcessor = httpTxExecutor.statsProcessor(tx),
tx.request.requestConfig.defaultCharset
).onComplete(result)
def stop(next: Action, session: Session): Unit = {
timer.cancel(false)
// FIXME all state change is lost
next ! session.remove(pollerName)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy