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

io.gatling.javaapi.http.SseMessageCheck Maven / Gradle / Ivy

There is a newer version: 3.13.1
Show newest version
/*
 * 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.javaapi.http;

import edu.umd.cs.findbugs.annotations.NonNull;
import io.gatling.javaapi.core.CheckBuilder;
import io.gatling.javaapi.core.Session;
import io.gatling.javaapi.http.internal.ScalaSseCheckConditions;
import io.gatling.javaapi.http.internal.SseChecks;
import java.util.Arrays;
import java.util.List;
import java.util.function.BiFunction;
import java.util.function.Function;

/**
 * DSL for building SSE
 * checks
 *
 * 

Immutable, so all methods return a new occurrence and leave the original unmodified. */ public final class SseMessageCheck { private final io.gatling.http.check.sse.SseMessageCheck wrapped; public SseMessageCheck(io.gatling.http.check.sse.SseMessageCheck wrapped) { this.wrapped = wrapped; } public io.gatling.http.check.sse.SseMessageCheck asScala() { return wrapped; } /** * Define conditions that have to hold true to match inbound messages and apply the checks on them * * @param newMatchConditions the conditions to match * @return a new SseMessageCheck instance */ @NonNull public SseMessageCheck matching(@NonNull CheckBuilder... newMatchConditions) { return matching(Arrays.asList(newMatchConditions)); } /** * Define conditions that have to hold true to match inbound messages and apply the checks on them * * @param newMatchConditions the conditions to match * @return a new SseMessageCheck instance */ @NonNull public SseMessageCheck matching(@NonNull List newMatchConditions) { return new SseMessageCheck(wrapped.matching(SseChecks.toScalaChecks(newMatchConditions))); } /** * Define the checks to apply on inbound messages * * @param checks the checks * @return a new SseMessageCheck instance */ @NonNull public SseMessageCheck check(@NonNull CheckBuilder... checks) { return check(Arrays.asList(checks)); } /** * Define the checks to apply on inbound messages * * @param checks the checks * @return a new SseMessageCheck instance */ @NonNull public SseMessageCheck check(@NonNull List checks) { return new SseMessageCheck(wrapped.check(SseChecks.toScalaChecks(checks))); } /** * Define the checks to apply on inbound messages when a condition holds true. * * @param condition a condition, expressed as a function * @return the next DSL step */ public UntypedCondition checkIf(Function condition) { return new UntypedCondition(ScalaSseCheckConditions.untyped(wrapped, condition)); } /** * Define the checks to apply on inbound messages when a condition holds true. * * @param condition a condition, expressed as a Gatling Expression Language String * @return the next DSL step */ public UntypedCondition checkIf(String condition) { return new UntypedCondition(ScalaSseCheckConditions.untyped(wrapped, condition)); } public static final class UntypedCondition { private final ScalaSseCheckConditions.Untyped wrapped; public UntypedCondition(ScalaSseCheckConditions.Untyped wrapped) { this.wrapped = wrapped; } /** * Define the checks to apply on inbound messages when a condition holds true. * * @param thenChecks the checks * @return a new Text instance */ public SseMessageCheck then(CheckBuilder... thenChecks) { return then(Arrays.asList(thenChecks)); } /** * Define the checks to apply when the condition holds true. * * @param thenChecks the checks * @return a new Text instance */ public SseMessageCheck then(List thenChecks) { return wrapped.then_(thenChecks); } } /** * Define the checks to apply on inbound messages when a condition holds true. * * @param condition a condition, expressed as a function that's aware of the HTTP response and the * Session * @return the next DSL step */ public TypedCondition checkIf(BiFunction condition) { return new TypedCondition(ScalaSseCheckConditions.typed(wrapped, condition)); } public static final class TypedCondition { private final ScalaSseCheckConditions.Typed wrapped; public TypedCondition(ScalaSseCheckConditions.Typed wrapped) { this.wrapped = wrapped; } /** * Define the checks to apply when the condition holds true. * * @param thenChecks the checks * @return a new Text instance */ public SseMessageCheck then(CheckBuilder... thenChecks) { return then(Arrays.asList(thenChecks)); } /** * Define the checks to apply when the condition holds true. * * @param thenChecks the checks * @return a new Text instance */ public SseMessageCheck then(List thenChecks) { return wrapped.then_(thenChecks); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy