package org.junit.rules; import org.junit.internal.AssumptionViolatedException; import org.junit.runners.model.FrameworkMethod; import org.junit.runners.model.Statement; /** * TestWatchman is a base class for Rules that take note of the testing * action, without modifying it. For example, this class will keep a log of each * passing and failing test: * *
 * public static class WatchmanTest {
 * 	private static String watchedLog;
 * 
 * 	@Rule
 * 	public MethodRule watchman= new TestWatchman() {
 * 		@Override
 * 		public void failed(Throwable e, FrameworkMethod method) {
 * 			watchedLog+= method.getName() + " " + e.getClass().getSimpleName()
 * 					+ "\n";
 * 		}
 * 
 * 		@Override
 * 		public void succeeded(FrameworkMethod method) {
 * 			watchedLog+= method.getName() + " " + "success!\n";
 * 		}
 * 	};
 * 
 * 	@Test
 * 	public void fails() {
 * 		fail();
 * 	}
 * 
 * 	@Test
 * 	public void succeeds() {
 * 	}
 * }
 * 
* * @deprecated {@link MethodRule} is deprecated. * Use {@link TestWatcher} implements {@link TestRule} instead. */ @Deprecated public class TestWatchman implements MethodRule { public Statement apply(final Statement base, final FrameworkMethod method, Object target) { return new Statement() { @Override public void evaluate() throws Throwable { starting(method); try { base.evaluate(); succeeded(method); } catch (AssumptionViolatedException e) { throw e; } catch (Throwable t) { failed(t, method); throw t; } finally { finished(method); } } }; } /** * Invoked when a test method succeeds * * @param method */ public void succeeded(FrameworkMethod method) { } /** * Invoked when a test method fails * * @param e * @param method */ public void failed(Throwable e, FrameworkMethod method) { } /** * Invoked when a test method is about to start * * @param method */ public void starting(FrameworkMethod method) { } /** * Invoked when a test method finishes (whether passing or failing) * * @param method */ public void finished(FrameworkMethod method) { } }