![JAR search and dependency download from the Maven repository](/logo.png)
fr.landel.utils.assertor.AssertorStepIterable Maven / Gradle / Ivy
/*-
* #%L
* utils-assertor
* %%
* Copyright (C) 2016 - 2018 Gilles Landel
* %%
* 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.
* #L%
*/
package fr.landel.utils.assertor;
import java.util.Locale;
import java.util.function.Predicate;
import fr.landel.utils.assertor.commons.MessageAssertor;
import fr.landel.utils.assertor.helper.HelperStep;
import fr.landel.utils.assertor.utils.AssertorIterable;
/**
* This class define methods that can be applied on the checked {@link Iterable}
* object. To provide a result, it's also provide a chain builder by returning a
* {@link StepIterable}. The chain looks like:
*
*
* {@link AssertorStepIterable} > {@link StepIterable} > {@link AssertorStepIterable} > {@link StepIterable}...
*
*
* This chain always starts with a {@link AssertorStepIterable} and ends with
* {@link StepIterable}.
*
* @since Aug 3, 2016
* @author Gilles
*
* @param
* the {@link Iterable} type
* @param
* the {@link Iterable} elements type
*/
@FunctionalInterface
public interface AssertorStepIterable, T> extends AssertorStep, I> {
/**
* {@inheritDoc}
*/
@Override
default StepIterable get(final StepAssertor result) {
return () -> result;
}
/**
* {@inheritDoc}
*/
@Override
default AssertorStepIterable not() {
return () -> HelperStep.not(getStep());
}
/**
* Asserts that the given {@link Iterable} has the specified {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSize(size).orElseThrow();
*
*
* @param size
* The wanted size
* @return The operator
* @category no_message
*/
default StepIterable hasSize(final int size) {
return this.hasSize(size, null);
}
/**
* Asserts that the given {@link Iterable} has the specified {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSize(size, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable hasSize(final int size, final CharSequence message, final Object... arguments) {
return this.hasSize(size, null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} has the specified {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSize(size, Locale.US, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable hasSize(final int size, final Locale locale, final CharSequence message, final Object... arguments) {
return () -> AssertorIterable.hasSize(this.getStep(), size, MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} has a size greater than
* {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeGT(size).orElseThrow();
*
*
* @param size
* The wanted size
* @return The operator
* @category no_message
*/
default StepIterable hasSizeGT(final int size) {
return this.hasSizeGT(size, null);
}
/**
* Asserts that the given {@link Iterable} has a size greater than
* {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeGT(size, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable hasSizeGT(final int size, final CharSequence message, final Object... arguments) {
return this.hasSizeGT(size, null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} has a size greater than
* {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeGT(size, Locale.US, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable hasSizeGT(final int size, final Locale locale, final CharSequence message, final Object... arguments) {
return () -> AssertorIterable.hasSizeGT(this.getStep(), size, MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} has a size greater than or equal
* to {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeGTE(size).orElseThrow();
*
*
* @param size
* The wanted size
* @return The operator
* @category no_message
*/
default StepIterable hasSizeGTE(final int size) {
return this.hasSizeGTE(size, null);
}
/**
* Asserts that the given {@link Iterable} has a size greater than or equal
* to {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeGTE(size, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable hasSizeGTE(final int size, final CharSequence message, final Object... arguments) {
return this.hasSizeGTE(size, null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} has a size greater than or equal
* to {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeGTE(size, Locale.US, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable hasSizeGTE(final int size, final Locale locale, final CharSequence message, final Object... arguments) {
return () -> AssertorIterable.hasSizeGTE(this.getStep(), size, MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} has a size lower than
* {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeLT(size).orElseThrow();
*
*
* @param size
* The wanted size
* @return The operator
* @category no_message
*/
default StepIterable hasSizeLT(final int size) {
return this.hasSizeLT(size, null);
}
/**
* Asserts that the given {@link Iterable} has a size lower than
* {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeLT(size, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable hasSizeLT(final int size, final CharSequence message, final Object... arguments) {
return this.hasSizeLT(size, null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} has a size lower than
* {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeLT(size, Locale.US, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable hasSizeLT(final int size, final Locale locale, final CharSequence message, final Object... arguments) {
return () -> AssertorIterable.hasSizeLT(this.getStep(), size, MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} has a size lower than or equal to
* {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeLTE(size).orElseThrow();
*
*
* @param size
* The wanted size
* @return The operator
* @category no_message
*/
default StepIterable hasSizeLTE(final int size) {
return this.hasSizeLTE(size, null);
}
/**
* Asserts that the given {@link Iterable} has a size lower than or equal to
* {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeLTE(size, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable hasSizeLTE(final int size, final CharSequence message, final Object... arguments) {
return this.hasSizeLTE(size, null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} has a size lower than or equal to
* {@code size}.
*
*
* precondition: {@link Iterable} cannot be {@code null} and size cannot be
* lower than zero
*
*
*
* Assertor.that(iterable).hasSizeLTE(size, Locale.US, "bad size").orElseThrow();
*
*
* @param size
* The wanted size
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable hasSizeLTE(final int size, final Locale locale, final CharSequence message, final Object... arguments) {
return () -> AssertorIterable.hasSizeLTE(this.getStep(), size, MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} is {@code null} or empty.
*
*
* precondition: none
*
*
*
* Assertor.that(iterable).isEmpty().orElseThrow();
*
*
* @return The operator
* @category no_message
*/
default StepIterable isEmpty() {
return this.isEmpty(null);
}
/**
* Asserts that the given {@link Iterable} is {@code null} or empty.
*
*
* precondition: none
*
*
*
* Assertor.that(iterable).isEmpty("the iterable must be null or empty").orElseThrow();
*
*
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable isEmpty(final CharSequence message, final Object... arguments) {
return this.isEmpty(null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} is {@code null} or empty.
*
*
* precondition: none
*
*
*
* Assertor.that(iterable).isEmpty(Locale.US, "the iterable must be null or empty").orElseThrow();
*
*
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable isEmpty(final Locale locale, final CharSequence message, final Object... arguments) {
return () -> AssertorIterable.isEmpty(this.getStep(), MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} is not {@code null} and not
* empty.
*
*
* precondition: none
*
*
*
* Assertor.that(iterable).isNotEmpty().orElseThrow();
*
*
* @return The operator
* @category no_message
*/
default StepIterable isNotEmpty() {
return this.isNotEmpty(null);
}
/**
* Asserts that the given {@link Iterable} is not {@code null} and not
* empty.
*
*
* precondition: none
*
*
*
* Assertor.that(iterable).isNotEmpty("the iterable cannot be null or empty").orElseThrow();
*
*
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable isNotEmpty(final CharSequence message, final Object... arguments) {
return this.isNotEmpty(null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} is not {@code null} and not
* empty.
*
*
* precondition: none
*
*
*
* Assertor.that(iterable).isNotEmpty(Locale.US, "the iterable cannot be null or empty").orElseThrow();
*
*
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable isNotEmpty(final Locale locale, final CharSequence message, final Object... arguments) {
return () -> AssertorIterable.isNotEmpty(this.getStep(), MessageAssertor.of(locale, message, arguments));
}
/**
* Check if any iterable's element matches the predicate.
*
*
* precondition: {@code iterable} cannot be {@code null} or empty and
* predicate cannot be {@code null}
*
*
*
* Assertor.that(iterable).anyMatch(Objects::nonNull).orElseThrow();
*
*
* @param predicate
* the predicate function that validates each element
* @return the assertor step
* @category no_message
*/
default StepIterable anyMatch(final Predicate predicate) {
return this.anyMatch(predicate, null);
}
/**
* Check if any iterable's element matches the predicate.
*
*
* precondition: {@code iterable} cannot be {@code null} or empty and
* predicate cannot be {@code null}
*
*
*
* Assertor.that(iterable).anyMatch(Objects::nonNull, "the iterable must contain at least on non null element").orElseThrow();
*
*
* @param predicate
* the predicate function that validates each element
* @param message
* the message on mismatch
* @param arguments
* the message arguments
* @return the assertor step
* @category message
*/
default StepIterable anyMatch(final Predicate predicate, final CharSequence message, final Object... arguments) {
return this.anyMatch(predicate, null, message, arguments);
}
/**
* Check if any iterable's element matches the predicate.
*
*
* precondition: {@code iterable} cannot be {@code null} or empty and
* predicate cannot be {@code null}
*
*
*
* Assertor.that(iterable).anyMatch(Objects::nonNull, Locale.US, "the iterable must contain at least on non null element").orElseThrow();
*
*
* @param predicate
* the predicate function that validates each element
* @param locale
* the message locale (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* the message on mismatch
* @param arguments
* the message arguments
* @return the assertor step
* @category localized_message
*/
default StepIterable anyMatch(final Predicate predicate, final Locale locale, final CharSequence message,
final Object... arguments) {
return () -> AssertorIterable.anyMatch(this.getStep(), predicate, MessageAssertor.of(locale, message, arguments));
}
/**
* Check if all iterable's elements match the predicate.
*
*
* precondition: {@code iterable} cannot be {@code null} or empty and
* predicate cannot be {@code null}
*
*
*
* Assertor.that(iterable).allMatch(Objects::nonNull).orElseThrow();
*
*
* @param predicate
* the predicate function that validates each element
* @return the assertor step
* @category no_message
*/
default StepIterable allMatch(final Predicate predicate) {
return this.allMatch(predicate, null);
}
/**
* Check if all iterable's elements match the predicate.
*
*
* precondition: {@code iterable} cannot be {@code null} or empty and
* predicate cannot be {@code null}
*
*
*
* Assertor.that(iterable).allMatch(Objects::nonNull, "the iterable cannot contain null element").orElseThrow();
*
*
* @param predicate
* the predicate function that validates each element
* @param message
* the message on mismatch
* @param arguments
* the message arguments
* @return the assertor step
* @category message
*/
default StepIterable allMatch(final Predicate predicate, final CharSequence message, final Object... arguments) {
return this.allMatch(predicate, null, message, arguments);
}
/**
* Check if all iterable's elements match the predicate.
*
*
* precondition: {@code iterable} cannot be {@code null} or empty and
* predicate cannot be {@code null}
*
*
*
* Assertor.that(iterable).allMatch(Objects::nonNull, Locale.US, "the iterable cannot contain null element").orElseThrow();
*
*
* @param predicate
* the predicate function that validates each element
* @param locale
* the message locale (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* the message on mismatch
* @param arguments
* the message arguments
* @return the assertor step
* @category localized_message
*/
default StepIterable allMatch(final Predicate predicate, final Locale locale, final CharSequence message,
final Object... arguments) {
return () -> AssertorIterable.allMatch(this.getStep(), predicate, MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} contains the specified
* {@code value}.
*
*
* precondition: the {@link Iterable} cannot be {@code null} or empty
*
*
*
* Assertor.that(iterable).contains(value).orElseThrow();
*
*
* @param value
* The value
* @return The operator
* @category no_message
*/
default StepIterable contains(final T value) {
return this.contains(value, null);
}
/**
* Asserts that the given {@link Iterable} contains the specified
* {@code value}.
*
*
* precondition: the {@link Iterable} cannot be {@code null} or empty
*
*
*
* Assertor.that(iterable).contains(value, "the element was not found in the iterable").orElseThrow();
*
*
* @param value
* The value
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable contains(final T value, final CharSequence message, final Object... arguments) {
return this.contains(value, (Locale) null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} contains the specified
* {@code value}.
*
*
* precondition: the {@link Iterable} cannot be {@code null} or empty
*
*
*
* Assertor.that(iterable).contains(value, Locale.US, "the element was not found in the iterable").orElseThrow();
*
*
* @param value
* The value
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable contains(final T value, final Locale locale, final CharSequence message, final Object... arguments) {
return () -> AssertorIterable.contains(this.getStep(), value, MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} contains ALL the specified
* {@code values}.
*
*
* precondition: neither {@link Iterable} can be {@code null} or empty
*
*
*
* Assertor.that(iterable).containsAll(values).orElseThrow();
*
*
* @param values
* The {@link Iterable} values
* @return The operator
* @category no_message
*/
default StepIterable containsAll(final Iterable values) {
return this.containsAll(values, null);
}
/**
* Asserts that the given {@link Iterable} contains ALL the specified
* {@code values}.
*
*
* precondition: neither {@link Iterable} can be {@code null} or empty
*
*
*
* Assertor.that(iterable).containsAll(values, "not all elements can be found in the iterable").orElseThrow();
*
*
* @param values
* The {@link Iterable} values
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable containsAll(final Iterable values, final CharSequence message, final Object... arguments) {
return this.containsAll(values, null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} contains ALL the specified
* {@code values}.
*
*
* precondition: neither {@link Iterable} can be {@code null} or empty
*
*
*
* Assertor.that(iterable).containsAll(values, Locale.US, "not all elements can be found in the iterable").orElseThrow();
*
*
* @param values
* The {@link Iterable} values
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable containsAll(final Iterable values, final Locale locale, final CharSequence message,
final Object... arguments) {
return () -> AssertorIterable.containsAll(this.getStep(), values, MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} contains ANY element of
* {@code values}.
*
*
* precondition: neither {@link Iterable} can be {@code null} or empty
*
*
*
* Assertor.that(iterable).containsAny(values).orElseThrow();
*
*
* @param values
* The {@link Iterable} values
* @return The operator
* @category no_message
*/
default StepIterable containsAny(final Iterable values) {
return this.containsAny(values, null);
}
/**
* Asserts that the given {@link Iterable} contains ANY element of
* {@code values}.
*
*
* precondition: neither {@link Iterable} can be {@code null} or empty
*
*
*
* Assertor.that(iterable).containsAny(values, "no element found").orElseThrow();
*
*
* @param values
* The {@link Iterable} values
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable containsAny(final Iterable values, final CharSequence message, final Object... arguments) {
return this.containsAny(values, null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} contains ANY element of
* {@code values}.
*
*
* precondition: neither {@link Iterable} can be {@code null} or empty
*
*
*
* Assertor.that(iterable).containsAny(values, Locale.US, "no element found").orElseThrow();
*
*
* @param values
* The {@link Iterable} values
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable containsAny(final Iterable values, final Locale locale, final CharSequence message,
final Object... arguments) {
return () -> AssertorIterable.containsAny(this.getStep(), values, MessageAssertor.of(locale, message, arguments));
}
/**
* Asserts that the given {@link Iterable} contains ALL elements of
* {@code values} in the same order.
*
*
* precondition: neither {@link Iterable} can be {@code null} or empty
*
*
*
* Assertor.that(iterable).containsInOrder(values).orElseThrow();
*
*
* @param values
* The {@link Iterable} values
* @return The operator
* @category no_message
*/
default StepIterable containsInOrder(final Iterable values) {
return this.containsInOrder(values, null);
}
/**
* Asserts that the given {@link Iterable} contains ALL elements of
* {@code values} in the same order.
*
*
* precondition: neither {@link Iterable} can be {@code null} or empty
*
*
*
* Assertor.that(iterable).containsInOrder(values, "elements aren't found or in the same order").orElseThrow();
*
*
* @param values
* The {@link Iterable} values
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category message
*/
default StepIterable containsInOrder(final Iterable values, final CharSequence message, final Object... arguments) {
return this.containsInOrder(values, null, message, arguments);
}
/**
* Asserts that the given {@link Iterable} contains ALL elements of
* {@code values} in the same order.
*
*
* precondition: neither {@link Iterable} can be {@code null} or empty
*
*
*
* Assertor.that(iterable).containsInOrder(values, Locale.US, "elements aren't found or in the same order").orElseThrow();
*
*
* @param values
* The {@link Iterable} values
* @param locale
* The locale of the message (only used to format this message,
* otherwise use {@link Assertor#setLocale})
* @param message
* The message on mismatch
* @param arguments
* The arguments of the message, use {@link String#format}
* @return The operator
* @category localized_message
*/
default StepIterable containsInOrder(final Iterable values, final Locale locale, final CharSequence message,
final Object... arguments) {
return () -> AssertorIterable.containsInOrder(this.getStep(), values, MessageAssertor.of(locale, message, arguments));
}
}