| /* |
| * Copyright (c) 2011 Google, Inc. |
| * |
| * 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 com.google.common.truth; |
| |
| import com.google.common.annotations.GwtIncompatible; |
| import com.google.common.base.Optional; |
| import com.google.common.collect.ListMultimap; |
| import com.google.common.collect.Multimap; |
| import com.google.common.collect.Multiset; |
| import com.google.common.collect.SetMultimap; |
| import com.google.common.collect.Table; |
| |
| import com.google.common.truth.AbstractVerb.DelegatedVerb; |
| |
| import java.util.Collection; |
| import java.util.List; |
| import java.util.Map; |
| |
| import javax.annotation.CheckReturnValue; |
| |
| /** |
| * Truth - a proposition framework for tests, supporting JUnit style |
| * assertion and assumption semantics in a fluent style. |
| * |
| * Truth is the simplest entry point class. A developer can statically |
| * import the assertThat() method to get easy access to the library's |
| * capabilities. Then, instead of writing: |
| * |
| * <pre>{@code |
| * Assert.assertEquals(a, b); |
| * Assert.assertTrue(c); |
| * Assert.assertTrue(d.contains(a)); |
| * Assert.assertTrue(d.contains(a) && d.contains(b)); |
| * Assert.assertTrue(d.contains(a) || d.contains(b) || d.contains(c)); |
| * }</pre> |
| * one would write: |
| * <pre>{@code |
| * assertThat(a).isEqualTo(b); |
| * assertThat(c).isTrue(); |
| * assertThat(d).contains(a); |
| * assertThat(d).containsAllOf(a, b); |
| * assertThat(d).containsAnyOf(a, b, c); |
| * }</pre> |
| * |
| * Tests should be easier to read, and flow more clearly. |
| * |
| * @author David Saff |
| * @author Christian Gruber (cgruber@israfil.net) |
| */ |
| public final class Truth { |
| |
| public static final FailureStrategy THROW_ASSERTION_ERROR = |
| new FailureStrategy() { |
| @Override public void failComparing( |
| String message, CharSequence expected, CharSequence actual) { |
| throw Platform.comparisonFailure(message, expected.toString(), actual.toString()); |
| } |
| }; |
| |
| public static final TestVerb ASSERT = new TestVerb(THROW_ASSERTION_ERROR); |
| |
| public static TestVerb assert_() { return ASSERT; } |
| |
| /** |
| * Returns a {@link TestVerb} that will prepend the given message to the failure message in |
| * the event of a test failure. |
| */ |
| public static TestVerb assertWithMessage(String messageToPrepend) { |
| return assert_().withFailureMessage(messageToPrepend); |
| } |
| |
| /** |
| * The recommended method of extension of Truth to new types, which is |
| * documented in {@link com.google.common.truth.delegation.DelegationTest}. |
| * |
| * @param factory a SubjectFactory<S, T> implementation |
| * @returns A custom verb for the type returned by the SubjectFactory |
| */ |
| public static <S extends Subject<S, T>, T, SF extends SubjectFactory<S, T>> DelegatedVerb<S, T> |
| assertAbout(SF factory) { |
| return assert_().about(factory); |
| } |
| |
| @CheckReturnValue |
| public static <T extends Comparable<?>> ComparableSubject<?, T> assertThat(T target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static Subject<DefaultSubject, Object> assertThat(Object target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| @GwtIncompatible("ClassSubject.java") |
| public static ClassSubject assertThat(Class<?> target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static ThrowableSubject assertThat(Throwable target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static LongSubject assertThat(Long target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static IntegerSubject assertThat(Integer target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static BooleanSubject assertThat(Boolean target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static StringSubject assertThat(String target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static <T, C extends Iterable<T>> IterableSubject<? extends IterableSubject<?, T, C>, T, C> |
| assertThat(Iterable<T> target) { |
| return assert_().that(target); |
| } |
| |
| /** |
| * @deprecated Use the {@link Iterable} overload instead. |
| */ |
| @Deprecated |
| @CheckReturnValue |
| public static <T, C extends Collection<T>> |
| CollectionSubject<? extends CollectionSubject<?, T, C>, T, C> |
| assertThat(Collection<T> target) { |
| return assert_().that(target); |
| } |
| |
| /** |
| * @deprecated Use the {@link Iterable} overload instead. |
| */ |
| @Deprecated |
| @CheckReturnValue |
| public static <T, C extends List<T>> |
| ListSubject<? extends ListSubject<?, T, C>, T, C> |
| assertThat(List<T> target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static <T> ObjectArraySubject<T> assertThat(T[] target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static PrimitiveBooleanArraySubject assertThat(boolean[] target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static PrimitiveIntArraySubject assertThat(int[] target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static PrimitiveLongArraySubject assertThat(long[] target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static PrimitiveByteArraySubject assertThat(byte[] target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static PrimitiveCharArraySubject assertThat(char[] target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static PrimitiveFloatArraySubject assertThat(float[] target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static PrimitiveDoubleArraySubject assertThat(double[] target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static <T> OptionalSubject<T> assertThat(Optional<T> target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static <K, V, M extends Map<K, V>> MapSubject<? extends MapSubject<?, K, V, M>, K, V, M> |
| assertThat(Map<K, V> target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static <K, V, M extends Multimap<K, V>> |
| MultimapSubject<? extends MultimapSubject<?, K, V, M>, K, V, M> assertThat( |
| Multimap<K, V> target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static <K, V, M extends ListMultimap<K, V>> |
| ListMultimapSubject<? extends ListMultimapSubject<?, K, V, M>, K, V, M> assertThat( |
| ListMultimap<K, V> target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static <K, V, M extends SetMultimap<K, V>> |
| SetMultimapSubject<? extends SetMultimapSubject<?, K, V, M>, K, V, M> assertThat( |
| SetMultimap<K, V> target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static <E, M extends Multiset<E>> |
| MultisetSubject<? extends MultisetSubject<?, E, M>, E, M> assertThat(Multiset<E> target) { |
| return assert_().that(target); |
| } |
| |
| @CheckReturnValue |
| public static <R, C, V, M extends Table<R, C, V>> |
| TableSubject<? extends TableSubject<?, R, C, V, M>, R, C, V, M> assertThat( |
| Table<R, C, V> target) { |
| return assert_().that(target); |
| } |
| } |