io.gatling.javaapi.http.SseMessageCheck Maven / Gradle / Ivy
/*
* Copyright 2011-2022 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 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;
import javax.annotation.Nonnull;
/**
* 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);
}
}
}