carbidecpp22devenv/plugins/org.eclipse.test.source_3.5.0.r20080925/src/org.junit4_4.5.0.v20090423/junitsrc/org/junit/experimental/results/ResultMatchers.java
changeset 636 3ef299ba838f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/carbidecpp22devenv/plugins/org.eclipse.test.source_3.5.0.r20080925/src/org.junit4_4.5.0.v20090423/junitsrc/org/junit/experimental/results/ResultMatchers.java	Fri Dec 04 11:49:54 2009 -0600
@@ -0,0 +1,49 @@
+package org.junit.experimental.results;
+
+import org.hamcrest.BaseMatcher;
+import org.hamcrest.Description;
+import org.hamcrest.Matcher;
+import org.junit.internal.matchers.TypeSafeMatcher;
+
+public class ResultMatchers {
+	public static Matcher<PrintableResult> isSuccessful() {
+		return failureCountIs(0);
+	}
+
+	public static Matcher<PrintableResult> failureCountIs(final int count) {
+		return new TypeSafeMatcher<PrintableResult>() {
+			public void describeTo(Description description) {
+				description.appendText("has " + count + " failures");
+			}
+
+			@Override
+			public boolean matchesSafely(PrintableResult item) {
+				return item.getFailures().size() == count;
+			}
+		};
+	}
+	
+	public static Matcher<Object> hasSingleFailureContaining(final String string) {
+		return new BaseMatcher<Object>() {
+			public boolean matches(Object item) {
+				return item.toString().contains(string) && failureCountIs(1).matches(item);
+			}
+
+			public void describeTo(Description description) {
+				description.appendText("has single failure containing " + string);
+			}
+		};
+	}
+	
+	public static Matcher<PrintableResult> hasFailureContaining(final String string) {
+		return new BaseMatcher<PrintableResult>() {
+			public boolean matches(Object item) {
+				return item.toString().contains(string);
+			}
+
+			public void describeTo(Description description) {
+				description.appendText("has failure containing " + string);
+			}
+		};
+	}
+}