Browse Source

1. Fix bug where <move> ignored <filterset>s.

2. Add filterset based test to CopyTest.
3. Add MoveTest.


git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@271675 13f79535-47bb-0310-9956-ffa450edef68
master
Magesh Umasankar 23 years ago
parent
commit
5c5b959ca7
8 changed files with 174 additions and 31 deletions
  1. +2
    -0
      WHATSNEW
  2. +1
    -0
      src/etc/testcases/taskdefs/copy.filterset
  3. +9
    -0
      src/etc/testcases/taskdefs/copy.xml
  4. +1
    -0
      src/etc/testcases/taskdefs/expected/copy.filterset.filtered
  5. +18
    -0
      src/etc/testcases/taskdefs/move.xml
  6. +25
    -16
      src/main/org/apache/tools/ant/taskdefs/Move.java
  7. +28
    -15
      src/testcases/org/apache/tools/ant/taskdefs/CopyTest.java
  8. +90
    -0
      src/testcases/org/apache/tools/ant/taskdefs/MoveTest.java

+ 2
- 0
WHATSNEW View File

@@ -38,6 +38,8 @@ Changes that could break older environments:

Fixed bugs:
-----------
* Fixed bug where <move> ignored <filterset>s.

* Ant works properly with the combination of Java1.4/WindowsXP

* Fixed bug where <java> used to sometimes invoke class constructors twice.


+ 1
- 0
src/etc/testcases/taskdefs/copy.filterset View File

@@ -0,0 +1 @@
This is the @TITLE@.

+ 9
- 0
src/etc/testcases/taskdefs/copy.xml View File

@@ -44,6 +44,14 @@
</copy>
</target>
<target name="testFilterSet">
<copy file="copy.filterset" tofile="copy.filterset.tmp">
<filterset>
<filter token="TITLE" value="Apache Ant Project"/>
</filterset>
</copy>
</target>

<target name="cleanup">
<delete file="copytest1.tmp"/>
<delete file="copytest3.tmp"/>
@@ -51,6 +59,7 @@
<delete file="copytest3b.tmp"/>
<delete file="copytest3c.tmp"/>
<delete file="copytest_single_file_fileset.tmp"/>
<delete file="copy.filterset.tmp"/>
<delete dir="copytest1dir"/>
</target>



+ 1
- 0
src/etc/testcases/taskdefs/expected/copy.filterset.filtered View File

@@ -0,0 +1 @@
This is the Apache Ant Project.

+ 18
- 0
src/etc/testcases/taskdefs/move.xml View File

@@ -0,0 +1,18 @@
<?xml version="1.0"?>

<project name="move-test" basedir="." default="testFilterSet">

<target name="testFilterSet">
<copy file="copy.filterset" tofile="move.filterset"/>
<move file="move.filterset" tofile="move.filterset.tmp">
<filterset>
<filter token="TITLE" value="Apache Ant Project"/>
</filterset>
</move>
</target>

<target name="cleanup">
<delete file="move.filterset.tmp"/>
</target>

</project>

+ 25
- 16
src/main/org/apache/tools/ant/taskdefs/Move.java View File

@@ -63,6 +63,7 @@ import org.apache.tools.ant.types.FileSet;
import java.io.File;
import java.io.IOException;
import java.util.Enumeration;
import java.util.Vector;

/**
* Moves a file or directory to a new file or directory. By default,
@@ -87,6 +88,8 @@ import java.util.Enumeration;
*/
public class Move extends Copy {

private Vector filterSets = null;

public Move() {
super();
forceOverwrite = true;
@@ -97,6 +100,8 @@ public class Move extends Copy {
//************************************************************************

protected void doFileOperations() {
filterSets = getFilterSets();

//Attempt complete directory renames, if any, first.
if (completeDirMap.size() > 0) {
Enumeration e = completeDirMap.keys();
@@ -274,26 +279,30 @@ public class Move extends Copy {
throws IOException, BuildException {

boolean renamed = true;
if (!filtering) {
// ensure that parent dir of dest file exists!
// not using getParentFile method to stay 1.1 compat
String parentPath = destFile.getParent();
if (parentPath != null) {
File parent = new File(parentPath);
if (!parent.exists()) {
parent.mkdirs();
if (filterSets != null && filterSets.size() > 0) {
renamed = false;
} else {
if (!filtering) {
// ensure that parent dir of dest file exists!
// not using getParentFile method to stay 1.1 compat
String parentPath = destFile.getParent();
if (parentPath != null) {
File parent = new File(parentPath);
if (!parent.exists()) {
parent.mkdirs();
}
}
}

if (destFile.exists()) {
if (!destFile.delete()) {
throw new BuildException("Unable to remove existing file "
+ destFile);
if (destFile.exists()) {
if (!destFile.delete()) {
throw new BuildException("Unable to remove existing file "
+ destFile);
}
}
renamed = sourceFile.renameTo(destFile);
} else {
renamed = false;
}
renamed = sourceFile.renameTo(destFile);
} else {
renamed = false;
}
return renamed;
}


+ 28
- 15
src/testcases/org/apache/tools/ant/taskdefs/CopyTest.java View File

@@ -56,24 +56,27 @@ package org.apache.tools.ant.taskdefs;

import org.apache.tools.ant.BuildFileTest;
import org.apache.tools.ant.Project;
import org.apache.tools.ant.util.FileUtils;

import java.io.File;
import java.io.IOException;

/**
* Tests FileSet using the Copy task.
*
* @author David Rees <dave@ubiqsoft.com>
* @author David Rees <dave@ubiqsoft.com>
*/
public class CopyTest extends BuildFileTest {
public CopyTest(String name) {
public class CopyTest extends BuildFileTest {
public CopyTest(String name) {
super(name);
}

public void setUp() {
public void setUp() {
configureProject("src/etc/testcases/taskdefs/copy.xml");
}

public void test1() {
public void test1() {
executeTarget("test1");
File f = new File(getProjectDir(), "copytest1.tmp");
if ( !f.exists()) {
@@ -85,14 +88,14 @@ public class CopyTest extends BuildFileTest {
executeTarget("cleanup");
}

public void test2() {
public void test2() {
executeTarget("test2");
File f = new File(getProjectDir(), "copytest1dir/copy.xml");
if ( !f.exists()) {
fail("Copy failed");
}
}
public void test3() {
executeTarget("test3");
File file3 = new File(getProjectDir(), "copytest3.tmp");
@@ -103,7 +106,7 @@ public class CopyTest extends BuildFileTest {
assertTrue(file3b.exists());
File file3c = new File(getProjectDir(), "copytest3c.tmp");
assertTrue(file3c.exists());
//file length checks rely on touch generating a zero byte file
if(file3.length()==0) {
fail("could not overwrite an existing, older file");
@@ -114,19 +117,29 @@ public class CopyTest extends BuildFileTest {
if(file3b.length()==0) {
fail("unexpectedly overwrote an existing, newer file");
}
//file time checks for java1.2+
//file time checks for java1.2+
if (Project.getJavaVersion() != Project.JAVA_1_1) {
assertTrue(file3a.lastModified()==file3.lastModified());
assertTrue(file3c.lastModified()<file3a.lastModified());
assertTrue(file3a.lastModified()==file3.lastModified());
assertTrue(file3c.lastModified()<file3a.lastModified());
}

}
public void testSingleFileFileset() {
executeTarget("test_single_file_fileset");
File file = new File(getProjectDir(),
File file = new File(getProjectDir(),
"copytest_single_file_fileset.tmp");
assertTrue(file.exists());
}

public void testFilterSet() throws IOException {
executeTarget("testFilterSet");
FileUtils fileUtils = FileUtils.newFileUtils();
File tmp = new File(getProjectDir(), "copy.filterset.tmp");
File check = new File(getProjectDir(),
"expected/copy.filterset.filtered");
assertTrue(tmp.exists());
assertTrue(fileUtils.contentEquals(tmp, check));
}
}

+ 90
- 0
src/testcases/org/apache/tools/ant/taskdefs/MoveTest.java View File

@@ -0,0 +1,90 @@
/*
* The Apache Software License, Version 1.1
*
* Copyright (c) 2000-2002 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", "Ant", 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;

import org.apache.tools.ant.BuildFileTest;
import org.apache.tools.ant.Project;
import org.apache.tools.ant.util.FileUtils;
import java.io.File;
import java.io.IOException;

/**
* Tests the Move task.
*
* @author <a href="mailto:umagesh@apache.org">Magesh Umasankar</a>
*/
public class MoveTest extends BuildFileTest {

public MoveTest(String name) {
super(name);
}

public void setUp() {
configureProject("src/etc/testcases/taskdefs/move.xml");
}

public void tearDown() {
executeTarget("cleanup");
}

public void testFilterSet() throws IOException {
executeTarget("testFilterSet");
FileUtils fileUtils = FileUtils.newFileUtils();
File tmp = new File(getProjectDir(), "move.filterset.tmp");
File check = new File(getProjectDir(), "expected/copy.filterset.filtered");
assertTrue(tmp.exists());
assertTrue(fileUtils.contentEquals(tmp, check));
}
}

Loading…
Cancel
Save