blob: 1497151256a28723e064175a04663178a8292079 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.tools.ant.taskdefs.optional.junit;
import java.util.ArrayList;
import java.util.List;
import junit.framework.Test;
import junit.framework.TestListener;
import junit.framework.TestResult;
/**
* Records ignored and skipped tests reported as part of the execution of
* JUnit 4 tests.
*
*/
public class IgnoredTestResult extends TestResult {
private List<IgnoredTestListener> listeners = new ArrayList<IgnoredTestListener>();
private List<TestIgnored> ignored = new ArrayList<TestIgnored>();
private List<TestIgnored> skipped = new ArrayList<TestIgnored>();
public IgnoredTestResult() {
super();
}
public synchronized void addListener(TestListener listener) {
if (listener instanceof IgnoredTestListener) {
listeners.add((IgnoredTestListener) listener);
}
super.addListener(listener);
}
public synchronized void removeListener(TestListener listener) {
if (listener instanceof IgnoredTestListener) {
listeners.remove(listener);
}
super.removeListener(listener);
}
/**
* Record a test as having been ignored, normally by the @Ignore annotation.
* @param test the test that was ignored.
* @throws Exception is the listener thrown an exception on handling the notification.
*/
public synchronized void testIgnored(Test test) throws Exception {
ignored.add(new TestIgnored(test));
for (IgnoredTestListener listener : listeners) {
listener.testIgnored(test);
}
}
/**
* Report how many tests were ignored.
* @return the number of tests reported as ignored during the current execution.
*/
public long ignoredCount() {
return ignored.size();
}
/**
* Records a test as having an assumption failure so JUnit will no longer be executing it.
* Under normal circumstances this would be counted as a skipped test.
* @param test the test to record
* @param cause the details of the test and assumption failure.
*/
public void testAssumptionFailure(Test test, Throwable cause) {
skipped.add(new TestIgnored(test));
for (IgnoredTestListener listener : listeners) {
listener.testAssumptionFailure(test, cause);
}
}
/**
* Report how many tests has assumption failures.
* @return the number of tests that reported assumption failures during the current execution.
*/
public long skippedCount() {
return skipped.size();
}
}