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

io.gatling.http.check.header.HttpHeaderRegexCheckBuilder.scala Maven / Gradle / Ivy

/*
 * Copyright 2011-2024 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.check.header

import io.gatling.core.check._
import io.gatling.core.check.regex.{ GroupExtractor, Patterns }
import io.gatling.core.session.Expression
import io.gatling.http.check.{ HttpCheck, HttpCheckMaterializer }
import io.gatling.http.check.HttpCheckScope.Header
import io.gatling.http.response.Response

trait HttpHeaderRegexCheckType

trait HttpHeaderRegexOfType {
  self: HttpHeaderRegexCheckBuilder[String] =>

  def ofType[X: GroupExtractor]: CheckBuilder.MultipleFind[HttpHeaderRegexCheckType, Response, X] =
    new HttpHeaderRegexCheckBuilder[X](headerName, pattern, patterns)
}

object HttpHeaderRegexCheckBuilder {
  def headerRegex(
      headerName: Expression[CharSequence],
      pattern: Expression[String],
      patterns: Patterns
  ): HttpHeaderRegexCheckBuilder[String] with HttpHeaderRegexOfType =
    new HttpHeaderRegexCheckBuilder[String](headerName, pattern, patterns) with HttpHeaderRegexOfType
}

class HttpHeaderRegexCheckBuilder[X: GroupExtractor] private[header] (
    private[header] val headerName: Expression[CharSequence],
    private[header] val pattern: Expression[String],
    private[header] val patterns: Patterns
) extends CheckBuilder.MultipleFind.Default[HttpHeaderRegexCheckType, Response, X](displayActualValue = true) {
  private def withHeaderAndPattern[T](f: (CharSequence, String) => T): Expression[T] =
    session =>
      for {
        headerName <- headerName(session)
        pattern <- pattern(session)
      } yield f(headerName, pattern)

  override protected def findExtractor(occurrence: Int): Expression[Extractor[Response, X]] =
    withHeaderAndPattern(HttpHeaderRegexExtractors.find(_, _, occurrence, patterns))

  override protected def findAllExtractor: Expression[Extractor[Response, Seq[X]]] = withHeaderAndPattern(HttpHeaderRegexExtractors.findAll(_, _, patterns))

  override protected def countExtractor: Expression[Extractor[Response, Int]] = withHeaderAndPattern(HttpHeaderRegexExtractors.count(_, _, patterns))
}

object HttpHeaderRegexCheckMaterializer {
  val Instance: CheckMaterializer[HttpHeaderRegexCheckType, HttpCheck, Response, Response] =
    new HttpCheckMaterializer[HttpHeaderRegexCheckType, Response](Header, identityPreparer)
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy