Browse Source

<junit> now works again as it did before tasks started to be

configured at runtime.


git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@267990 13f79535-47bb-0310-9956-ffa450edef68
master
Stefan Bodewig 25 years ago
parent
commit
53ff5c3147
5 changed files with 153 additions and 92 deletions
  1. +1
    -1
      build.xml
  2. +107
    -0
      src/main/org/apache/tools/ant/taskdefs/optional/junit/BaseTest.java
  3. +5
    -31
      src/main/org/apache/tools/ant/taskdefs/optional/junit/BatchTest.java
  4. +39
    -15
      src/main/org/apache/tools/ant/taskdefs/optional/junit/JUnitTask.java
  5. +1
    -45
      src/main/org/apache/tools/ant/taskdefs/optional/junit/JUnitTest.java

+ 1
- 1
build.xml View File

@@ -317,7 +317,7 @@

<formatter type="plain" usefile="false" />

<batchtest fork="yes">
<batchtest>
<fileset dir="${src.tests.dir}">
<include name="**/*Test*" />
<exclude name="**/All*" />


+ 107
- 0
src/main/org/apache/tools/ant/taskdefs/optional/junit/BaseTest.java View File

@@ -0,0 +1,107 @@
/*
* The Apache Software License, Version 1.1
*
* Copyright (c) 2000 The Apache Software Foundation. All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* 3. The end-user documentation included with the redistribution, if
* any, must include the following acknowlegement:
* "This product includes software developed by the
* Apache Software Foundation (http://www.apache.org/)."
* Alternately, this acknowlegement may appear in the software itself,
* if and wherever such third-party acknowlegements normally appear.
*
* 4. The names "The Jakarta Project", "Tomcat", and "Apache Software
* Foundation" must not be used to endorse or promote products derived
* from this software without prior written permission. For written
* permission, please contact apache@apache.org.
*
* 5. Products derived from this software may not be called "Apache"
* nor may "Apache" appear in their names without prior written
* permission of the Apache Group.
*
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
* ====================================================================
*
* This software consists of voluntary contributions made by many
* individuals on behalf of the Apache Software Foundation. For more
* information on the Apache Software Foundation, please see
* <http://www.apache.org/>.
*/

package org.apache.tools.ant.taskdefs.optional.junit;

import java.util.Vector;

/**
* Baseclass for BatchTest and JUnitTest.
*
* @author <a href="mailto:stefan.bodewig@megabit.net">Stefan Bodewig</a>
*/
public abstract class BaseTest {
protected boolean haltOnError = false;
protected boolean haltOnFail = false;
protected boolean fork = false;
protected String ifProperty = null;
protected String unlessProperty = null;
protected Vector formatters = new Vector();

public void setFork(boolean value) {
fork = value;
}

public boolean getFork() {
return fork;
}

public void setHaltonerror(boolean value) {
haltOnError = value;
}

public void setHaltonfailure(boolean value) {
haltOnFail = value;
}

public boolean getHaltonerror() {
return haltOnError;
}

public boolean getHaltonfailure() {
return haltOnFail;
}

public void setIf(String propertyName) {
ifProperty = propertyName;
}

public void setUnless(String propertyName) {
unlessProperty = propertyName;
}

public void addFormatter(FormatterElement elem) {
formatters.addElement(elem);
}
}

+ 5
- 31
src/main/org/apache/tools/ant/taskdefs/optional/junit/BatchTest.java View File

@@ -68,16 +68,10 @@ import java.util.*;
* @author <a href="mailto:jeff.martin@synamic.co.uk">Jeff Martin</a>
* @author <a href="mailto:stefan.bodewig@megabit.net">Stefan Bodewig</a>
*/
public final class BatchTest {
private boolean fork=false;
private boolean haltOnError=false;
private boolean haltOnFailure=false;
public final class BatchTest extends BaseTest {
private Project project;
private String ifCond = null;
private String unlessCond = null;

private Vector filesets = new Vector();
private Vector formatters = new Vector();

public BatchTest(Project project){
this.project = project;
@@ -87,30 +81,10 @@ public final class BatchTest {
filesets.addElement(fs);
}

public void addFormatter(FormatterElement elem) {
formatters.addElement(elem);
}

public void setIf(String propertyName) {
ifCond = propertyName;
}

public void setUnless(String propertyName) {
unlessCond = propertyName;
}

public final void setFork(boolean value) {
this.fork = value;
}
public final void setHaltonerror(boolean value) {
this.haltOnError = value;
}
public final void setHaltonfailure(boolean value) {
this.haltOnFailure = value;
}
public final Enumeration elements(){
return new FileList();
}

public class FileList implements Enumeration{
private String files[]=null;
private int i=0;
@@ -142,10 +116,10 @@ public final class BatchTest {
if(hasMoreElements()){
JUnitTest test = new JUnitTest(javaToClass(files[i]));
test.setHaltonerror(haltOnError);
test.setHaltonfailure(haltOnFailure);
test.setHaltonfailure(haltOnFail);
test.setFork(fork);
test.setIf(ifCond);
test.setUnless(unlessCond);
test.setIf(ifProperty);
test.setUnless(unlessProperty);
Enumeration list = formatters.elements();
while (list.hasMoreElements()) {
test.addFormatter((FormatterElement)list.nextElement());


+ 39
- 15
src/main/org/apache/tools/ant/taskdefs/optional/junit/JUnitTask.java View File

@@ -92,16 +92,23 @@ public class JUnitTask extends Task {
private Vector batchTests = new Vector();
private Vector formatters = new Vector();

private JUnitTest defaults = new JUnitTest();
private Integer timeout = null;
private boolean summary = false;

public void setHaltonerror(boolean value) {
defaults.setHaltonerror(value);
Enumeration enum = allTests();
while (enum.hasMoreElements()) {
BaseTest test = (BaseTest) enum.nextElement();
test.setHaltonerror(value);
}
}

public void setHaltonfailure(boolean value) {
defaults.setHaltonfailure(value);
Enumeration enum = allTests();
while (enum.hasMoreElements()) {
BaseTest test = (BaseTest) enum.nextElement();
test.setHaltonfailure(value);
}
}

public void setPrintsummary(boolean value) {
@@ -114,7 +121,6 @@ public class JUnitTask extends Task {
} else {
createJvmarg().setValue("-Xmx"+max);
}
}

public void setTimeout(Integer value) {
@@ -122,7 +128,11 @@ public class JUnitTask extends Task {
}

public void setFork(boolean value) {
defaults.setFork(value);
Enumeration enum = allTests();
while (enum.hasMoreElements()) {
BaseTest test = (BaseTest) enum.nextElement();
test.setFork(value);
}
}

public void setJvm(String value) {
@@ -138,17 +148,11 @@ public class JUnitTask extends Task {
}

public void addTest(JUnitTest test) {
test.setHaltonerror(defaults.getHaltonerror());
test.setHaltonfailure(defaults.getHaltonfailure());
test.setFork(defaults.getFork());
tests.addElement(test);
}

public BatchTest createBatchTest() {
BatchTest test = new BatchTest(project);
test.setHaltonerror(defaults.getHaltonerror());
test.setHaltonfailure(defaults.getHaltonfailure());
test.setFork(defaults.getFork());
batchTests.addElement(test);
return test;
}
@@ -171,16 +175,18 @@ public class JUnitTask extends Task {
boolean errorOccurred = false;
boolean failureOccurred = false;

Vector runTests = (Vector) tests.clone();

Enumeration list = batchTests.elements();
while (list.hasMoreElements()) {
BatchTest test = (BatchTest)list.nextElement();
Enumeration list2 = test.elements();
while (list2.hasMoreElements()) {
tests.addElement(list2.nextElement());
runTests.addElement(list2.nextElement());
}
}

list = tests.elements();
list = runTests.elements();
while (list.hasMoreElements()) {
JUnitTest test = (JUnitTest)list.nextElement();

@@ -194,8 +200,6 @@ public class JUnitTask extends Task {

int exitValue = JUnitTestRunner.ERRORS;
System.err.println(test.getFork());

if (!test.getFork()) {
JUnitTestRunner runner =
new JUnitTestRunner(test, test.getHaltonerror(),
@@ -312,4 +316,24 @@ public class JUnitTask extends Task {
if (dest.exists()) dest.delete();
src.renameTo(dest);
}

protected Enumeration allTests() {

return new Enumeration() {
private Enumeration testEnum = tests.elements();
private Enumeration batchEnum = batchTests.elements();
public boolean hasMoreElements() {
return testEnum.hasMoreElements() ||
batchEnum.hasMoreElements();
}
public Object nextElement() {
if (testEnum.hasMoreElements()) {
return testEnum.nextElement();
}
return batchEnum.nextElement();
}
};
}
}

+ 1
- 45
src/main/org/apache/tools/ant/taskdefs/optional/junit/JUnitTest.java View File

@@ -65,18 +65,13 @@ import java.util.Vector;
* @author Thomas Haas
* @author <a href="mailto:stefan.bodewig@megabit.net">Stefan Bodewig</a>
*/
public class JUnitTest {
private boolean haltOnError = false;
private boolean haltOnFail = false;
public class JUnitTest extends BaseTest {
private String name = null;
private File outfile = null;
private boolean fork = false;

private long runs, failures, errors;
private long runTime;

private Vector formatters = new Vector();

public JUnitTest() {
}

@@ -90,22 +85,6 @@ public class JUnitTest {
this.haltOnFail = haltOnFail;
}

public void setFork(boolean value) {
fork = value;
}

public boolean getFork() {
return fork;
}

public void setHaltonerror(boolean value) {
haltOnError = value;
}

public void setHaltonfailure(boolean value) {
haltOnFail = value;
}

public void setName(String value) {
name = value;
}
@@ -114,14 +93,6 @@ public class JUnitTest {
outfile = value;
}

public boolean getHaltonerror() {
return haltOnError;
}

public boolean getHaltonfailure() {
return haltOnFail;
}

public String getName() {
return name;
}
@@ -148,17 +119,6 @@ public class JUnitTest {
public long errorCount() {return errors;}
public long getRunTime() {return runTime;}

private String ifProperty = null;
private String unlessProperty = null;

public void setIf(String propertyName) {
ifProperty = propertyName;
}

public void setUnless(String propertyName) {
unlessProperty = propertyName;
}

public boolean shouldRun(Project p) {
if (ifProperty != null && p.getProperty(ifProperty) == null) {
return false;
@@ -169,10 +129,6 @@ public class JUnitTest {
return true;
}

public void addFormatter(FormatterElement elem) {
formatters.addElement(elem);
}

public FormatterElement[] getFormatters() {
FormatterElement[] fes = new FormatterElement[formatters.size()];
formatters.copyInto(fes);


Loading…
Cancel
Save