Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.github.gv2011.testutil.Matchers Maven / Gradle / Ivy
package com.github.gv2011.testutil;
/*-
* #%L
* util-test
* %%
* Copyright (C) 2016 - 2017 Vinz (https://github.com/gv2011)
* %%
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
* #L%
*/
/*-
* %---license-start---
* The MIT License (MIT)
* %
* Copyright (C) 2016 - 2017 Vinz (https://github.com/gv2011)
* %
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
* %---license-end---
*/
import static com.github.gv2011.util.CollectionUtils.toISet;
import static com.github.gv2011.util.Equal.equal;
import static com.github.gv2011.util.ex.Exceptions.format;
import java.util.Collection;
import java.util.Map;
import java.util.Optional;
import java.util.function.Function;
import java.util.function.Predicate;
import javax.xml.namespace.NamespaceContext;
import org.hamcrest.Description;
import org.hamcrest.Matcher;
import org.hamcrest.TypeSafeMatcher;
import com.github.gv2011.util.bytes.ByteUtils;
import com.github.gv2011.util.bytes.Bytes;
import com.github.gv2011.util.icol.ISet;
public final class Matchers {
public static Matcher> isPresent(){
return OptionalMatchers.isPresent();
}
public static Matcher> isEmptyOptional(){
return OptionalMatchers.isEmpty();
}
public static Matcher> isOpt(final T value){
return OptionalMatchers.isOpt(value);
}
/**
* Creates a matcher that matches if the examined object matches ALL of the specified matchers.
*
* For example:
* assertThat("myValue", allOf(startsWith("my"), containsString("Val")))
*/
public static Matcher allOf(final Iterable> matchers) {
return org.hamcrest.core.AllOf.allOf(matchers);
}
/**
* Creates a matcher that matches if the examined object matches ALL of the specified matchers.
*
* For example:
* assertThat("myValue", allOf(startsWith("my"), containsString("Val")))
*/
@SafeVarargs
public static Matcher allOf(final Matcher super T>... matchers) {
return org.hamcrest.core.AllOf.allOf(matchers);
}
/**
* Creates a matcher that matches if the examined object matches ALL of the specified matchers.
*
* For example:
* assertThat("myValue", allOf(startsWith("my"), containsString("Val")))
*/
public static Matcher allOf(final Matcher super T> first, final Matcher super T> second) {
return org.hamcrest.core.AllOf.allOf(first, second);
}
/**
* Creates a matcher that matches if the examined object matches ALL of the specified matchers.
*
* For example:
* assertThat("myValue", allOf(startsWith("my"), containsString("Val")))
*/
public static Matcher allOf(final Matcher super T> first, final Matcher super T> second, final Matcher super T> third) {
return org.hamcrest.core.AllOf.allOf(first, second, third);
}
/**
* Creates a matcher that matches if the examined object matches ALL of the specified matchers.
*
* For example:
* assertThat("myValue", allOf(startsWith("my"), containsString("Val")))
*/
public static Matcher allOf(final Matcher super T> first, final Matcher super T> second, final Matcher super T> third, final Matcher super T> fourth) {
return org.hamcrest.core.AllOf.allOf(first, second, third, fourth);
}
/**
* Creates a matcher that matches if the examined object matches ALL of the specified matchers.
*
* For example:
* assertThat("myValue", allOf(startsWith("my"), containsString("Val")))
*/
public static Matcher allOf(final Matcher super T> first, final Matcher super T> second, final Matcher super T> third, final Matcher super T> fourth, final Matcher super T> fifth) {
return org.hamcrest.core.AllOf.allOf(first, second, third, fourth, fifth);
}
/**
* Creates a matcher that matches if the examined object matches ALL of the specified matchers.
*
* For example:
* assertThat("myValue", allOf(startsWith("my"), containsString("Val")))
*/
public static Matcher allOf(final Matcher super T> first, final Matcher super T> second, final Matcher super T> third, final Matcher super T> fourth, final Matcher super T> fifth, final Matcher super T> sixth) {
return org.hamcrest.core.AllOf.allOf(first, second, third, fourth, fifth, sixth);
}
/**
* Creates a matcher that matches if the examined object matches ANY of the specified matchers.
*
* For example:
* assertThat("myValue", anyOf(startsWith("foo"), containsString("Val")))
*/
public static org.hamcrest.core.AnyOf anyOf(final Iterable> matchers) {
return org.hamcrest.core.AnyOf.anyOf(matchers);
}
/**
* Creates a matcher that matches if the examined object matches ANY of the specified matchers.
*
* For example:
* assertThat("myValue", anyOf(startsWith("foo"), containsString("Val")))
*/
public static org.hamcrest.core.AnyOf anyOf(final Matcher first, final Matcher super T> second, final Matcher super T> third) {
return org.hamcrest.core.AnyOf.anyOf(first, second, third);
}
/**
* Creates a matcher that matches if the examined object matches ANY of the specified matchers.
*
* For example:
* assertThat("myValue", anyOf(startsWith("foo"), containsString("Val")))
*/
public static org.hamcrest.core.AnyOf anyOf(final Matcher first, final Matcher super T> second, final Matcher super T> third, final Matcher super T> fourth) {
return org.hamcrest.core.AnyOf.anyOf(first, second, third, fourth);
}
/**
* Creates a matcher that matches if the examined object matches ANY of the specified matchers.
*
* For example:
* assertThat("myValue", anyOf(startsWith("foo"), containsString("Val")))
*/
public static org.hamcrest.core.AnyOf anyOf(final Matcher first, final Matcher super T> second, final Matcher super T> third, final Matcher super T> fourth, final Matcher super T> fifth) {
return org.hamcrest.core.AnyOf.anyOf(first, second, third, fourth, fifth);
}
/**
* Creates a matcher that matches if the examined object matches ANY of the specified matchers.
*
* For example:
* assertThat("myValue", anyOf(startsWith("foo"), containsString("Val")))
*/
public static org.hamcrest.core.AnyOf anyOf(final Matcher first, final Matcher super T> second, final Matcher super T> third, final Matcher super T> fourth, final Matcher super T> fifth, final Matcher super T> sixth) {
return org.hamcrest.core.AnyOf.anyOf(first, second, third, fourth, fifth, sixth);
}
/**
* Creates a matcher that matches if the examined object matches ANY of the specified matchers.
*
* For example:
* assertThat("myValue", anyOf(startsWith("foo"), containsString("Val")))
*/
public static org.hamcrest.core.AnyOf anyOf(final Matcher first, final Matcher super T> second) {
return org.hamcrest.core.AnyOf.anyOf(first, second);
}
/**
* Creates a matcher that matches if the examined object matches ANY of the specified matchers.
*
* For example:
* assertThat("myValue", anyOf(startsWith("foo"), containsString("Val")))
*/
@SafeVarargs
public static org.hamcrest.core.AnyOf anyOf(final Matcher super T>... matchers) {
return org.hamcrest.core.AnyOf.anyOf(matchers);
}
/**
* Creates a matcher that matches when both of the specified matchers match the examined object.
*
* For example:
* assertThat("fab", both(containsString("a")).and(containsString("b")))
*/
public static org.hamcrest.core.CombinableMatcher.CombinableBothMatcher both(final Matcher super LHS> matcher) {
return org.hamcrest.core.CombinableMatcher.both(matcher);
}
/**
* Creates a matcher that matches when either of the specified matchers match the examined object.
*
* For example:
* assertThat("fan", either(containsString("a")).and(containsString("b")))
*/
public static org.hamcrest.core.CombinableMatcher.CombinableEitherMatcher either(final Matcher super LHS> matcher) {
return org.hamcrest.core.CombinableMatcher.either(matcher);
}
/**
* Wraps an existing matcher, overriding its description with that specified. All other functions are
* delegated to the decorated matcher, including its mismatch description.
*
* For example:
* describedAs("a big decimal equal to %0", equalTo(myBigDecimal), myBigDecimal.toPlainString())
*
* @param description
* the new description for the wrapped matcher
* @param matcher
* the matcher to wrap
* @param values
* optional values to insert into the tokenised description
*/
public static Matcher describedAs(final java.lang.String description, final Matcher matcher, final java.lang.Object... values) {
return org.hamcrest.core.DescribedAs.describedAs(description, matcher, values);
}
/**
* Creates a matcher for {@link Iterable}s that only matches when a single pass over the
* examined {@link Iterable} yields items that are all matched by the specified
* itemMatcher
.
*
* For example:
* assertThat(Arrays.asList("bar", "baz"), everyItem(startsWith("ba")))
*
* @param itemMatcher
* the matcher to apply to every item provided by the examined {@link Iterable}
*/
public static Matcher> everyItem(final Matcher itemMatcher) {
return org.hamcrest.core.Every.everyItem(itemMatcher);
}
/**
* A shortcut to the frequently used is(equalTo(x))
.
*
* For example:
* assertThat(cheese, is(smelly))
* instead of:
* assertThat(cheese, is(equalTo(smelly)))
*/
public static Matcher is(final T value) {
return org.hamcrest.core.Is.is(value);
}
/**
* Decorates another Matcher, retaining its behaviour, but allowing tests
* to be slightly more expressive.
*
* For example:
* assertThat(cheese, is(equalTo(smelly)))
* instead of:
* assertThat(cheese, equalTo(smelly))
*/
public static Matcher is(final Matcher matcher) {
return org.hamcrest.core.Is.is(matcher);
}
/**
* A shortcut to the frequently used is(instanceOf(SomeClass.class))
.
*
* For example:
* assertThat(cheese, isA(Cheddar.class))
* instead of:
* assertThat(cheese, is(instanceOf(Cheddar.class)))
*/
public static Matcher isA(final Class> type) {
return new TypeSafeMatcher(){
@Override
public void describeTo(final Description description) {
description.appendText(format("An instance of {}.",type.getName()));
}
@Override
protected boolean matchesSafely(final Object obj) {
return type.isInstance(obj);
}};
}
public static Matcher notNull() {
return not(nullValue());
}
public static Matcher toStringIs(final String str) {
return new TypeSafeMatcher(){
@Override
public void describeTo(final Description description) {
description.appendText(format("An object whose toString() method returns {}.", str));
}
@Override
protected boolean matchesSafely(final Object obj) {
return equal(obj.toString(),str);
}};
}
/**
* Creates a matcher that always matches, regardless of the examined object.
*/
public static Matcher anything() {
return org.hamcrest.core.IsAnything.anything();
}
/**
* Creates a matcher that always matches, regardless of the examined object, but describes
* itself with the specified {@link String}.
*
* @param description
* a meaningful {@link String} used when describing itself
*/
public static Matcher anything(final java.lang.String description) {
return org.hamcrest.core.IsAnything.anything(description);
}
/**
* Creates a matcher for {@link Iterable}s that only matches when a single pass over the
* examined {@link Iterable} yields at least one item that is equal to the specified
* item
. Whilst matching, the traversal of the examined {@link Iterable}
* will stop as soon as a matching item is found.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), hasItem("bar"))
*
* @param item
* the item to compare against the items provided by the examined {@link Iterable}
*/
public static Matcher> hasItem(final T item) {
return org.hamcrest.core.IsCollectionContaining.hasItem(item);
}
/**
* Creates a matcher for {@link Iterable}s that only matches when a single pass over the
* examined {@link Iterable} yields at least one item that is matched by the specified
* itemMatcher
. Whilst matching, the traversal of the examined {@link Iterable}
* will stop as soon as a matching item is found.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), hasItem(startsWith("ba")))
*
* @param itemMatcher
* the matcher to apply to items provided by the examined {@link Iterable}
*/
public static Matcher> hasItem(final Matcher super T> itemMatcher) {
return org.hamcrest.core.IsCollectionContaining.hasItem(itemMatcher);
}
/**
* Creates a matcher for {@link Iterable}s that matches when consecutive passes over the
* examined {@link Iterable} yield at least one item that is equal to the corresponding
* item from the specified items
. Whilst matching, each traversal of the
* examined {@link Iterable} will stop as soon as a matching item is found.
*
* For example:
* assertThat(Arrays.asList("foo", "bar", "baz"), hasItems("baz", "foo"))
*
* @param items
* the items to compare against the items provided by the examined {@link Iterable}
*/
@SafeVarargs
public static Matcher> hasItems(final T... items) {
return org.hamcrest.core.IsCollectionContaining.hasItems(items);
}
/**
* Creates a matcher for {@link Iterable}s that matches when consecutive passes over the
* examined {@link Iterable} yield at least one item that is matched by the corresponding
* matcher from the specified itemMatchers
. Whilst matching, each traversal of
* the examined {@link Iterable} will stop as soon as a matching item is found.
*
* For example:
* assertThat(Arrays.asList("foo", "bar", "baz"), hasItems(endsWith("z"), endsWith("o")))
*
* @param itemMatchers
* the matchers to apply to items provided by the examined {@link Iterable}
*/
@SafeVarargs
public static Matcher> hasItems(final Matcher super T>... itemMatchers) {
return org.hamcrest.core.IsCollectionContaining.hasItems(itemMatchers);
}
/**
* Creates a matcher that matches when the examined object is logically equal to the specified
* operand
, as determined by calling the {@link java.lang.Object#equals} method on
* the examined object.
*
* If the specified operand is null
then the created matcher will only match if
* the examined object's equals
method returns true
when passed a
* null
(which would be a violation of the equals
contract), unless the
* examined object itself is null
, in which case the matcher will return a positive
* match.
*
* The created matcher provides a special behaviour when examining Array
s, whereby
* it will match if both the operand and the examined object are arrays of the same length and
* contain items that are equal to each other (according to the above rules) in the same
* indexes .
*
* For example:
*
* assertThat("foo", equalTo("foo"));
* assertThat(new String[] {"foo", "bar"}, equalTo(new String[] {"foo", "bar"}));
*
*/
public static Matcher equalTo(final T operand) {
return org.hamcrest.core.IsEqual.equalTo(operand);
}
/**
* Creates a matcher that matches when the examined object is an instance of the specified type
,
* as determined by calling the {@link java.lang.Class#isInstance(Object)} method on that type, passing the
* the examined object.
*
* The created matcher forces a relationship between specified type and the examined object, and should be
* used when it is necessary to make generics conform, for example in the JMock clause
* with(any(Thing.class))
*
* For example:
* assertThat(new Canoe(), instanceOf(Canoe.class));
*/
public static Matcher any(final java.lang.Class type) {
return org.hamcrest.core.IsInstanceOf.any(type);
}
/**
* Creates a matcher that matches when the examined object is an instance of the specified type
,
* as determined by calling the {@link java.lang.Class#isInstance(Object)} method on that type, passing the
* the examined object.
*
* The created matcher assumes no relationship between specified type and the examined object.
*
* For example:
* assertThat(new Canoe(), instanceOf(Paddlable.class));
*/
public static Matcher instanceOf(final java.lang.Class> type) {
return org.hamcrest.core.IsInstanceOf.instanceOf(type);
}
/**
* Creates a matcher that wraps an existing matcher, but inverts the logic by which
* it will match.
*
* For example:
* assertThat(cheese, is(not(equalTo(smelly))))
*
* @param matcher
* the matcher whose sense should be inverted
*/
public static Matcher not(final Matcher matcher) {
return org.hamcrest.core.IsNot.not(matcher);
}
/**
* A shortcut to the frequently used not(equalTo(x))
.
*
* For example:
* assertThat(cheese, is(not(smelly)))
* instead of:
* assertThat(cheese, is(not(equalTo(smelly))))
*
* @param value
* the value that any examined object should not equal
*/
public static Matcher not(final T value) {
return org.hamcrest.core.IsNot.not(value);
}
/**
* Creates a matcher that matches if examined object is null
.
*
* For example:
* assertThat(cheese, is(nullValue())
*/
public static Matcher nullValue() {
return org.hamcrest.core.IsNull.nullValue();
}
/**
* Creates a matcher that matches if examined object is null
. Accepts a
* single dummy argument to facilitate type inference.
*
* For example:
* assertThat(cheese, is(nullValue(Cheese.class))
*
* @param type
* dummy parameter used to infer the generic type of the returned matcher
*/
public static Matcher nullValue(final java.lang.Class type) {
return org.hamcrest.core.IsNull.nullValue(type);
}
/**
* A shortcut to the frequently used not(nullValue())
.
*
* For example:
* assertThat(cheese, is(notNullValue()))
* instead of:
* assertThat(cheese, is(not(nullValue())))
*/
public static Matcher notNullValue() {
return org.hamcrest.core.IsNull.notNullValue();
}
/**
* A shortcut to the frequently used not(nullValue(X.class)). Accepts a
* single dummy argument to facilitate type inference.
.
*
* For example:
* assertThat(cheese, is(notNullValue(X.class)))
* instead of:
* assertThat(cheese, is(not(nullValue(X.class))))
*
* @param type
* dummy parameter used to infer the generic type of the returned matcher
*/
public static Matcher notNullValue(final java.lang.Class type) {
return org.hamcrest.core.IsNull.notNullValue(type);
}
/**
* Creates a matcher that matches only when the examined object is the same instance as
* the specified target object.
*
* @param target
* the target instance against which others should be assessed
*/
public static Matcher sameInstance(final T target) {
return org.hamcrest.core.IsSame.sameInstance(target);
}
/**
* Creates a matcher that matches only when the examined object is the same instance as
* the specified target object.
*
* @param target
* the target instance against which others should be assessed
*/
public static Matcher theInstance(final T target) {
return org.hamcrest.core.IsSame.theInstance(target);
}
/**
* Creates a matcher that matches if the examined {@link String} contains the specified
* {@link String} anywhere.
*
* For example:
* assertThat("myStringOfNote", containsString("ring"))
*
* @param substring
* the substring that the returned matcher will expect to find within any examined string
*/
public static Matcher containsString(final java.lang.String substring) {
return org.hamcrest.core.StringContains.containsString(substring);
}
/**
* Creates a matcher that matches if the examined {@link String} starts with the specified
* {@link String}.
*
* For example:
* assertThat("myStringOfNote", startsWith("my"))
*
* @param prefix
* the substring that the returned matcher will expect at the start of any examined string
*/
public static Matcher startsWith(final java.lang.String prefix) {
return org.hamcrest.core.StringStartsWith.startsWith(prefix);
}
/**
* Creates a matcher that matches if the examined {@link String} ends with the specified
* {@link String}.
*
* For example:
* assertThat("myStringOfNote", endsWith("Note"))
*
* @param suffix
* the substring that the returned matcher will expect at the end of any examined string
*/
public static Matcher endsWith(final java.lang.String suffix) {
return org.hamcrest.core.StringEndsWith.endsWith(suffix);
}
/**
* Creates a matcher that matches arrays whose elements are satisfied by the specified matchers. Matches
* positively only if the number of matchers specified is equal to the length of the examined array and
* each matcher[i] is satisfied by array[i].
*
* For example:
* assertThat(new Integer[]{1,2,3}, is(array(equalTo(1), equalTo(2), equalTo(3))))
*
* @param elementMatchers
* the matchers that the elements of examined arrays should satisfy
*/
@SafeVarargs
public static org.hamcrest.collection.IsArray array(final Matcher super T>... elementMatchers) {
return org.hamcrest.collection.IsArray.array(elementMatchers);
}
/**
* A shortcut to the frequently used hasItemInArray(equalTo(x))
.
*
* For example:
* assertThat(hasItemInArray(x))
* instead of:
* assertThat(hasItemInArray(equalTo(x)))
*
* @param element
* the element that should be present in examined arrays
*/
public static Matcher hasItemInArray(final T element) {
return org.hamcrest.collection.IsArrayContaining.hasItemInArray(element);
}
/**
* Creates a matcher for arrays that matches when the examined array contains at least one item
* that is matched by the specified elementMatcher
. Whilst matching, the traversal
* of the examined array will stop as soon as a matching element is found.
*
* For example:
* assertThat(new String[] {"foo", "bar"}, hasItemInArray(startsWith("ba")))
*
* @param elementMatcher
* the matcher to apply to elements in examined arrays
*/
public static Matcher hasItemInArray(final Matcher super T> elementMatcher) {
return org.hamcrest.collection.IsArrayContaining.hasItemInArray(elementMatcher);
}
/**
* Creates a matcher for arrays that matches when each item in the examined array satisfies the
* corresponding matcher in the specified list of matchers. For a positive match, the examined array
* must be of the same length as the specified list of matchers.
*
* For example:
* assertThat(new String[]{"foo", "bar"}, contains(Arrays.asList(equalTo("foo"), equalTo("bar"))))
*
* @param itemMatchers
* a list of matchers, each of which must be satisfied by the corresponding item in an examined array
*/
public static Matcher arrayContaining(final java.util.List> itemMatchers) {
return org.hamcrest.collection.IsArrayContainingInOrder.arrayContaining(itemMatchers);
}
/**
* Creates a matcher for arrays that matcheswhen each item in the examined array is
* logically equal to the corresponding item in the specified items. For a positive match,
* the examined array must be of the same length as the number of specified items.
*
* For example:
* assertThat(new String[]{"foo", "bar"}, contains("foo", "bar"))
*
* @param items
* the items that must equal the items within an examined array
*/
@SafeVarargs
public static Matcher arrayContaining(final E... items) {
return org.hamcrest.collection.IsArrayContainingInOrder.arrayContaining(items);
}
/**
* Creates a matcher for arrays that matches when each item in the examined array satisfies the
* corresponding matcher in the specified matchers. For a positive match, the examined array
* must be of the same length as the number of specified matchers.
*
* For example:
* assertThat(new String[]{"foo", "bar"}, contains(equalTo("foo"), equalTo("bar")))
*
* @param itemMatchers
* the matchers that must be satisfied by the items in the examined array
*/
@SafeVarargs
public static Matcher arrayContaining(final Matcher super E>... itemMatchers) {
return org.hamcrest.collection.IsArrayContainingInOrder.arrayContaining(itemMatchers);
}
/**
* Creates an order agnostic matcher for arrays that matches when each item in the
* examined array is logically equal to one item anywhere in the specified items.
* For a positive match, the examined array must be of the same length as the number of
* specified items.
*
* N.B. each of the specified items will only be used once during a given examination, so be
* careful when specifying items that may be equal to more than one entry in an examined
* array.
*
* For example:
*
assertThat(new String[]{"foo", "bar"}, containsInAnyOrder("bar", "foo"))
*
* @param items
* the items that must equal the entries of an examined array, in any order
*/
@SafeVarargs
public static Matcher arrayContainingInAnyOrder(final E... items) {
return org.hamcrest.collection.IsArrayContainingInAnyOrder.arrayContainingInAnyOrder(items);
}
/**
* Creates an order agnostic matcher for arrays that matches when each item in the
* examined array satisfies one matcher anywhere in the specified matchers.
* For a positive match, the examined array must be of the same length as the number of
* specified matchers.
*
* N.B. each of the specified matchers will only be used once during a given examination, so be
* careful when specifying matchers that may be satisfied by more than one entry in an examined
* array.
*
* For example:
*
assertThat(new String[]{"foo", "bar"}, arrayContainingInAnyOrder(equalTo("bar"), equalTo("foo")))
*
* @param itemMatchers
* a list of matchers, each of which must be satisfied by an entry in an examined array
*/
@SafeVarargs
public static Matcher arrayContainingInAnyOrder(final Matcher super E>... itemMatchers) {
return org.hamcrest.collection.IsArrayContainingInAnyOrder.arrayContainingInAnyOrder(itemMatchers);
}
/**
* Creates an order agnostic matcher for arrays that matches when each item in the
* examined array satisfies one matcher anywhere in the specified collection of matchers.
* For a positive match, the examined array must be of the same length as the specified collection
* of matchers.
*
* N.B. each matcher in the specified collection will only be used once during a given
* examination, so be careful when specifying matchers that may be satisfied by more than
* one entry in an examined array.
*
* For example:
*
assertThat(new String[]{"foo", "bar"}, arrayContainingInAnyOrder(Arrays.asList(equalTo("bar"), equalTo("foo"))))
*
* @param itemMatchers
* a list of matchers, each of which must be satisfied by an item provided by an examined array
*/
public static Matcher arrayContainingInAnyOrder(final Collection> itemMatchers) {
return org.hamcrest.collection.IsArrayContainingInAnyOrder.arrayContainingInAnyOrder(itemMatchers);
}
/**
* Creates a matcher for arrays that matches when the length
of the array
* satisfies the specified matcher.
*
* For example:
* assertThat(new String[]{"foo", "bar"}, arrayWithSize(equalTo(2)))
*
* @param sizeMatcher
* a matcher for the length of an examined array
*/
public static Matcher arrayWithSize(final Matcher super java.lang.Integer> sizeMatcher) {
return org.hamcrest.collection.IsArrayWithSize.arrayWithSize(sizeMatcher);
}
/**
* Creates a matcher for arrays that matches when the length
of the array
* equals the specified size
.
*
* For example:
* assertThat(new String[]{"foo", "bar"}, arrayWithSize(2))
*
* @param size
* the length that an examined array must have for a positive match
*/
public static Matcher arrayWithSize(final int size) {
return org.hamcrest.collection.IsArrayWithSize.arrayWithSize(size);
}
/**
* Creates a matcher for arrays that matches when the length
of the array
* is zero.
*
* For example:
* assertThat(new String[0], emptyArray())
*/
public static Matcher emptyArray() {
return org.hamcrest.collection.IsArrayWithSize.emptyArray();
}
/**
* Creates a matcher for {@link Collection}s that matches when the size()
method returns
* a value that satisfies the specified matcher.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), hasSize(equalTo(2)))
*
* @param sizeMatcher
* a matcher for the size of an examined {@link Collection}
*/
public static Matcher> hasSize(final Matcher super java.lang.Integer> sizeMatcher) {
return org.hamcrest.collection.IsCollectionWithSize.hasSize(sizeMatcher);
}
/**
* Creates a matcher for {@link Collection}s that matches when the size()
method returns
* a value equal to the specified size
.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), hasSize(2))
*
* @param size
* the expected size of an examined {@link Collection}
*/
public static Matcher> hasSize(final int size) {
return org.hamcrest.collection.IsCollectionWithSize.hasSize(size);
}
public static Matcher> mapWithSize(final int size) {
return IsMapWithSize.hasSize(size);
}
/**
* Creates a matcher for {@link Collection}s matching examined collections whose isEmpty
* method returns true
.
*
* For example:
* assertThat(new ArrayList<String>(), is(empty()))
*/
public static Matcher> empty() {
return org.hamcrest.collection.IsEmptyCollection.empty();
}
/**
* Creates a matcher for {@link Collection}s matching examined collections whose isEmpty
* method returns true
.
*
* For example:
* assertThat(new ArrayList<String>(), is(emptyCollectionOf(String.class)))
*
* @param type
* the type of the collection's content
*/
public static Matcher> emptyCollectionOf(final java.lang.Class type) {
return org.hamcrest.collection.IsEmptyCollection.emptyCollectionOf(type);
}
/**
* Creates a matcher for {@link Iterable}s matching examined iterables that yield no items.
*
* For example:
* assertThat(new ArrayList<String>(), is(emptyIterable()))
*/
public static Matcher> emptyIterable() {
return org.hamcrest.collection.IsEmptyIterable.emptyIterable();
}
/**
* Creates a matcher for {@link Iterable}s matching examined iterables that yield no items.
*
* For example:
* assertThat(new ArrayList<String>(), is(emptyIterableOf(String.class)))
*
* @param type
* the type of the iterable's content
*/
public static Matcher> emptyIterableOf(final java.lang.Class type) {
return org.hamcrest.collection.IsEmptyIterable.emptyIterableOf(type);
}
/**
* Creates a matcher for {@link Iterable}s that matches when a single pass over the
* examined {@link Iterable} yields a series of items, each satisfying the corresponding
* matcher in the specified matchers. For a positive match, the examined iterable
* must be of the same length as the number of specified matchers.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), contains(equalTo("foo"), equalTo("bar")))
*
* @param itemMatchers
* the matchers that must be satisfied by the items provided by an examined {@link Iterable}
*/
@SafeVarargs
public static Matcher> contains(final Matcher super E>... itemMatchers) {
return org.hamcrest.collection.IsIterableContainingInOrder.contains(itemMatchers);
}
/**
* Creates a matcher for {@link Iterable}s that matches when a single pass over the
* examined {@link Iterable} yields a series of items, each logically equal to the
* corresponding item in the specified items. For a positive match, the examined iterable
* must be of the same length as the number of specified items.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), contains("foo", "bar"))
*
* @param items
* the items that must equal the items provided by an examined {@link Iterable}
*/
@SafeVarargs
public static Matcher> contains(final E... items) {
return org.hamcrest.collection.IsIterableContainingInOrder.contains(items);
}
/**
* Creates a matcher for {@link Iterable}s that matches when a single pass over the
* examined {@link Iterable} yields a single item that satisfies the specified matcher.
* For a positive match, the examined iterable must only yield one item.
*
* For example:
* assertThat(Arrays.asList("foo"), contains(equalTo("foo")))
*
* @param itemMatcher
* the matcher that must be satisfied by the single item provided by an
* examined {@link Iterable}
*/
public static Matcher> contains(final Matcher super E> itemMatcher) {
return org.hamcrest.collection.IsIterableContainingInOrder.contains(itemMatcher);
}
/**
* Creates a matcher for {@link Iterable}s that matches when a single pass over the
* examined {@link Iterable} yields a series of items, each satisfying the corresponding
* matcher in the specified list of matchers. For a positive match, the examined iterable
* must be of the same length as the specified list of matchers.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), contains(Arrays.asList(equalTo("foo"), equalTo("bar"))))
*
* @param itemMatchers
* a list of matchers, each of which must be satisfied by the corresponding item provided by
* an examined {@link Iterable}
*/
public static Matcher> contains(final java.util.List> itemMatchers) {
return org.hamcrest.collection.IsIterableContainingInOrder.contains(itemMatchers);
}
/**
* Creates an order agnostic matcher for {@link Iterable}s that matches when a single pass over
* the examined {@link Iterable} yields a series of items, each logically equal to one item
* anywhere in the specified items. For a positive match, the examined iterable
* must be of the same length as the number of specified items.
*
* N.B. each of the specified items will only be used once during a given examination, so be
* careful when specifying items that may be equal to more than one entry in an examined
* iterable.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), containsInAnyOrder("bar", "foo"))
*
* @param items
* the items that must equal the items provided by an examined {@link Iterable} in any order
*/
@SafeVarargs
public static Matcher> containsInAnyOrder(final T... items) {
return org.hamcrest.collection.IsIterableContainingInAnyOrder.containsInAnyOrder(items);
}
/**
* Creates an order agnostic matcher for {@link Iterable}s that matches when a single pass over
* the examined {@link Iterable} yields a series of items, each satisfying one matcher anywhere
* in the specified collection of matchers. For a positive match, the examined iterable
* must be of the same length as the specified collection of matchers.
*
* N.B. each matcher in the specified collection will only be used once during a given
* examination, so be careful when specifying matchers that may be satisfied by more than
* one entry in an examined iterable.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), containsInAnyOrder(Arrays.asList(equalTo("bar"), equalTo("foo"))))
*
* @param itemMatchers
* a list of matchers, each of which must be satisfied by an item provided by an examined {@link Iterable}
*/
public static Matcher> containsInAnyOrder(final Collection> itemMatchers) {
return org.hamcrest.collection.IsIterableContainingInAnyOrder.containsInAnyOrder(itemMatchers);
}
/**
* Creates an order agnostic matcher for {@link Iterable}s that matches when a single pass over
* the examined {@link Iterable} yields a series of items, each satisfying one matcher anywhere
* in the specified matchers. For a positive match, the examined iterable must be of the same
* length as the number of specified matchers.
*
* N.B. each of the specified matchers will only be used once during a given examination, so be
* careful when specifying matchers that may be satisfied by more than one entry in an examined
* iterable.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), containsInAnyOrder(equalTo("bar"), equalTo("foo")))
*
* @param itemMatchers
* a list of matchers, each of which must be satisfied by an item provided by an examined {@link Iterable}
*/
@SafeVarargs
public static Matcher> containsInAnyOrder(final Matcher super T>... itemMatchers) {
return org.hamcrest.collection.IsIterableContainingInAnyOrder.containsInAnyOrder(itemMatchers);
}
/**
* Creates a matcher for {@link Iterable}s that matches when a single pass over the
* examined {@link Iterable} yields a single item that satisfies the specified matcher.
* For a positive match, the examined iterable must only yield one item.
*
* For example:
* assertThat(Arrays.asList("foo"), containsInAnyOrder(equalTo("foo")))
*
* @deprecated use contains(Matcher super E> itemMatcher) instead
* @param itemMatcher
* the matcher that must be satisfied by the single item provided by an
* examined {@link Iterable}
*/
@Deprecated
public static Matcher> containsInAnyOrder(final Matcher super E> itemMatcher) {
return org.hamcrest.collection.IsIterableContainingInAnyOrder.containsInAnyOrder(itemMatcher);
}
/**
* Creates a matcher for {@link Iterable}s that matches when a single pass over the
* examined {@link Iterable} yields an item count that satisfies the specified
* matcher.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), iterableWithSize(equalTo(2)))
*
* @param sizeMatcher
* a matcher for the number of items that should be yielded by an examined {@link Iterable}
*/
public static Matcher> iterableWithSize(final Matcher super java.lang.Integer> sizeMatcher) {
return org.hamcrest.collection.IsIterableWithSize.iterableWithSize(sizeMatcher);
}
/**
* Creates a matcher for {@link Iterable}s that matches when a single pass over the
* examined {@link Iterable} yields an item count that is equal to the specified
* size
argument.
*
* For example:
* assertThat(Arrays.asList("foo", "bar"), iterableWithSize(2))
*
* @param size
* the number of items that should be yielded by an examined {@link Iterable}
*/
public static Matcher> iterableWithSize(final int size) {
return org.hamcrest.collection.IsIterableWithSize.iterableWithSize(size);
}
/**
* Creates a matcher for {@link java.util.Map}s matching when the examined {@link java.util.Map} contains
* at least one entry whose key equals the specified key
and whose value equals the
* specified value
.
*
* For example:
* assertThat(myMap, hasEntry("bar", "foo"))
*
* @param key
* the key that, in combination with the value, must be describe at least one entry
* @param value
* the value that, in combination with the key, must be describe at least one entry
*/
public static Matcher> hasEntry(final K key, final V value) {
return org.hamcrest.collection.IsMapContaining.hasEntry(key, value);
}
/**
* Creates a matcher for {@link java.util.Map}s matching when the examined {@link java.util.Map} contains
* at least one entry whose key satisfies the specified keyMatcher
and whose
* value satisfies the specified valueMatcher
.
*
* For example:
* assertThat(myMap, hasEntry(equalTo("bar"), equalTo("foo")))
*
* @param keyMatcher
* the key matcher that, in combination with the valueMatcher, must be satisfied by at least one entry
* @param valueMatcher
* the value matcher that, in combination with the keyMatcher, must be satisfied by at least one entry
*/
public static Matcher> hasEntry(final Matcher super K> keyMatcher, final Matcher super V> valueMatcher) {
return org.hamcrest.collection.IsMapContaining.hasEntry(keyMatcher, valueMatcher);
}
/**
* Creates a matcher for {@link java.util.Map}s matching when the examined {@link java.util.Map} contains
* at least one key that satisfies the specified matcher.
*
* For example:
* assertThat(myMap, hasKey(equalTo("bar")))
*
* @param keyMatcher
* the matcher that must be satisfied by at least one key
*/
public static Matcher> hasKey(final Matcher super K> keyMatcher) {
return org.hamcrest.collection.IsMapContaining.hasKey(keyMatcher);
}
/**
* Creates a matcher for {@link java.util.Map}s matching when the examined {@link java.util.Map} contains
* at least one key that is equal to the specified key.
*
* For example:
* assertThat(myMap, hasKey("bar"))
*
* @param key
* the key that satisfying maps must contain
*/
public static Matcher> hasKey(final K key) {
return org.hamcrest.collection.IsMapContaining.hasKey(key);
}
/**
* Creates a matcher for {@link java.util.Map}s matching when the examined {@link java.util.Map} contains
* at least one value that is equal to the specified value.
*
* For example:
* assertThat(myMap, hasValue("foo"))
*
* @param value
* the value that satisfying maps must contain
*/
public static Matcher> hasValue(final V value) {
return org.hamcrest.collection.IsMapContaining.hasValue(value);
}
/**
* Creates a matcher for {@link java.util.Map}s matching when the examined {@link java.util.Map} contains
* at least one value that satisfies the specified valueMatcher.
*
* For example:
* assertThat(myMap, hasValue(equalTo("foo")))
*
* @param valueMatcher
* the matcher that must be satisfied by at least one value
*/
public static Matcher> hasValue(final Matcher super V> valueMatcher) {
return org.hamcrest.collection.IsMapContaining.hasValue(valueMatcher);
}
/**
* Creates a matcher that matches when the examined object is found within the
* specified collection.
*
* For example:
* assertThat("foo", isIn(Arrays.asList("bar", "foo")))
*
* @param collection
* the collection in which matching items must be found
*/
public static Matcher isIn(final Collection collection) {
return org.hamcrest.collection.IsIn.isIn(collection);
}
public static Matcher isIn(final T[] param1) {
return org.hamcrest.collection.IsIn.isIn(param1);
}
/**
* Creates a matcher that matches when the examined object is equal to one of the
* specified elements.
*
* For example:
* assertThat("foo", isIn("bar", "foo"))
*
* @param elements
* the elements amongst which matching items will be found
*/
@SafeVarargs
public static Matcher isOneOf(final T... elements) {
return org.hamcrest.collection.IsIn.isOneOf(elements);
}
/**
* Creates a matcher of {@link Double}s that matches when an examined double is equal
* to the specified