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

org.hamcrest.junit.MatcherAssume Maven / Gradle / Ivy

There is a newer version: 2.0.0.0
Show newest version
package org.hamcrest.junit;

import org.hamcrest.Matcher;
import org.hamcrest.junit.internal.Matching;
import org.hamcrest.junit.internal.MismatchAction;
import org.junit.AssumptionViolatedException;

/**
 * A set of methods useful for stating assumptions about the conditions in which a test is meaningful.
 * A failed assumption does not mean the code is broken, but that the test provides no useful information.
 * The default JUnit runner treats tests with failing assumptions as ignored.  Custom runners may behave differently.
 *
 * For example:
 * 
 * // only provides information if database is reachable.
 * \@Test public void calculateTotalSalary() {
 *    DBConnection dbc = Database.connect();
 *    assumeNotNull(dbc);
 *    // ...
 * }
 * 
* These methods can be used directly: Assume.assumeTrue(...), however, they * read better if they are referenced through static import:
*
 * import static org.junit.Assume.*;
 *    ...
 *    assumeTrue(...);
 * 
* * @since 4.4 */ public class MatcherAssume { /** * Call to assume that actual satisfies the condition specified by matcher. * If not, the test halts and is ignored. * Example: *
:
     *   assumeThat(1, equalTo(1)); // passes
     *   foo(); // will execute
     *   assumeThat(0, equalTo(1)); // assumption failure! test halts
     *   int x = 1 / 0; // will never execute
     * 
* * @param the static type accepted by the matcher (this can flag obvious compile-time problems such as assumeThat(1, is("a"))} * @param actual the computed value being compared * @param matcher an expression, built of {@link Matcher}s, specifying allowed values * @see org.hamcrest.Matcher * @see JUnitMatchers */ public static void assumeThat(T actual, Matcher matcher) { assumeThat("", actual, matcher); } /** * Call to assume that actual satisfies the condition specified by matcher. * If not, the test halts and is ignored. * Example: *
:
     *   assumeThat(1, is(1)); // passes
     *   foo(); // will execute
     *   assumeThat(0, is(1)); // assumption failure! test halts
     *   int x = 1 / 0; // will never execute
     * 
* * @param the static type accepted by the matcher (this can flag obvious compile-time problems such as {@code assumeThat(1, is("a"))} * @param actual the computed value being compared * @param matcher an expression, built of {@link Matcher}s, specifying allowed values * @see org.hamcrest.CoreMatchers * @see JUnitMatchers */ public static void assumeThat(String message, T actual, Matcher matcher) { Matching.checkMatch(message, actual, matcher, new MismatchAction() { @Override public void mismatch(String description) { throw new AssumptionViolatedException(description); } }); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy