- Using zip distribution (without GUI), in Linux
- Using Luntbuild installer (with GUI), in Linux
- Using Luntbuild installer (with GUI), in Windows
Tuesday, May 13, 2008
Luntbuild : Installation
Tuesday, May 6, 2008
Luntbuild : Introduction
Sunday, April 27, 2008
JUnit
What is JUnit?
JUnit is a simple, open source framework to write and run repeatable tests. It is an instance of the xUnit architecture for unit testing frameworks. JUnit features include:
- Assertions for testing expected results
- Test fixtures for sharing common test data
- Test runners for running tests
When should tests be written?
Tests should be written before the code. Test-first programming is practiced by only writing new code when an automated test is failing.
Good tests tell you how to best design the system for its intended use. They effectively communicate in an executable format how to use the software. They also prevent tendencies to over-build the system based on speculation. When all the tests pass, you know you're done!
Whenever a customer test fails or a bug is reported, first write the necessary unit test(s) to expose the bug(s), then fix them. This makes it almost impossible for that particular bug to resurface later.
Test-driven development is a lot more fun than writing tests after the code seems to be working. Give it a try!
Basic test template
import org.junit.*;
import static org.junit.Assert.*;
public class SampleTest {
private java.util.List emptyList;
/**
* Sets up the test fixture.
* (Called before every test case method.)
*/
@Before
public void setUp() {
emptyList = new java.util.ArrayList();
}
/**
* Tears down the test fixture.
* (Called after every test case method.)
*/
@After
public void tearDown() {
emptyList = null;
}
@Test
public void testSomeBehavior() {
assertEquals("Empty list should have 0 elements", 0, emptyList.size());
}
@Test(expected=IndexOutOfBoundsException.class)
public void testForException() {
Object o = emptyList.get(0);
}
}
Handling Exception
* How test that passes when an expected exception is thrown?
Add the optional expected attribute to the @Test annotation. The following is an example test that passes when the expected IndexOutOfBoundsException is raised:
@Test(expected=IndexOutOfBoundsException.class)
public void testIndexOutOfBoundsException() {
ArrayList emptyList = new ArrayList();
Object o = emptyList.get(0);
}
* How test that fails when an unexpected exception is thrown?
Declare the exception in the throws clause of the test method and don't catch the exception within the test method. Uncaught exceptions will cause the test to fail with an error.
The following is an example test that fails when the IndexOutOfBoundsException is raised:
@Test
public void testIndexOutOfBoundsExceptionNotRaised()
throws IndexOutOfBoundsException {
ArrayList emptyList = new ArrayList();
Object o = emptyList.get(0);
}
Assertion Statement Reference
This is a list of the different types of assertion statements that are used to test your code. Any Java data type or object can be used in the statement. These assertions are taken from the JUnit API.
- assertEquals(expected, actual)
- assertEquals(message, expected, actual)
- assertEquals(expected, actual, delta) - used on doubles or floats, where delta is the difference in precision
- assertEquals(message, expected, actual, delta) - used on doubles or floats, where delta is the difference in precision
- assertFalse(condition)
- assertFalse(message, condition)
- assertNotNull(object)
- assertNotNull(message, object)
- assertNotSame(expected, actual)
- assertNotSame(message, expected, actual)
- assertNull(object)
- assertNull(message, object)
- assertSame(expected, actual)
- assertSame(message, expected, actual)
- assertTrue(condition)
- assertTrue(message, condition)
- fail()
- fail(message)
- failNotEquals(message, expected, actual)
- failNotSame(message, expected, actual)
- failSame(message)
Ref:
Pre and Post condition
- A pre-condition is an expression of type Boolean that should always hold before the execution of the body of the method,conditions for each function that must be true for it to behave correctly
- A post-condition is an expression of type Boolean that should always hold after the execution of the body of the method,conditional expressions that must be true when a method returns
- The strategy is to construct a JUnit test case for each accessible method in the class under test, where each test case verifies both the preconditions and postconditions of the method. Example
public class RangeTest extends TestCase {
private Range mRange;
public RangeTest(String name) {
super(name);
}
protected void setUp() throws Exception {
super.setUp();
mRange = new Range(1, 5);
}
public void testConstructor() {
// pre: aLower < aUpper
try {
new Range(6, 4);
fail("[6,4] should be precluded");
}
catch (AssertionError e) { }
// pre: aLower == aUpper new Range(-3, -3);
// post: aLower == getLower()
Assert.assertEquals("[1,5].getLower() should be 1", 1,
mRange.getLower());
// post: aUpper == getUpper()
Assert.assertEquals("[1,5].getUpper() should be 5", 5,
mRange.getUpper());
}
public void testGetLower() {
// pre: object constructed
Assert.assertNotNull("[1,5] could not be constructed", mRange);
// post: getLower() == aLower provided to c'tor
Assert.assertEquals("[1,5].getLower() should be 1", 1,
mRange.getLower());
}
public void testGetUpper() {
// pre: object constructed
Assert.assertNotNull("[1,5] could not be constructed",
mRange);
// post: getUpper() == aUpper provided to c'tor
Assert.assertEquals("[1,5].getUpper() should be 5", 5,
mRange.getUpper());
}
public void testIntersects() {
// pre: anOther != null
try {
mRange.intersects(null);
fail("intersects(null) should be precluded");
}
catch (AssertionError e) { }
// post: true if two ranges have an integer in common
Assert.assertTrue(!mRange.intersects(new Range(-3, -1)));
Assert.assertTrue(!mRange.intersects(new Range(6, 7)));
Assert.assertTrue(!mRange.intersects(new Range(-2, 1)));
Assert.assertTrue(!mRange.intersects(new Range(5, 7)));
Assert.assertTrue(mRange.intersects(new Range(0, 2)));
Assert.assertTrue(mRange.intersects(new Range(3, 4)));
Assert.assertTrue(mRange.intersects(new Range(4, 8)));
}}
- If these test cases pass, then we can be confident that all methods in Range are:
- Checking for violation of their preconditions (and objecting by throwing a Runtime exception of some sort)
- Adhering to their postconditions.
Ref: http://www.hacknot.info/hacknot/action/showEntry?eid=17
Monday, April 7, 2008
Renaming a MySQL database
However, use of this statement could result in loss of database contents, which is why it was removed. Do not useRENAME DATABASE
in earlier versions in which it is present.
- But there might be times when you want to do this, and the simple workaround I use is this.
- Just export the current database. You can use mysqldump or any other GUI tool like HeidiSQL or phpMyAdmin.
- The dump typically contains SQL statements to create the table, populate it, or both.
- Then create a database with the name you want, the new database.
- Then just mysqlimport the exported SQL file to the new database you just created.
- Final step would be to drop the old database.
If you are doing a backup on the server and your tables all are MyISAM
tables, consider using the mysqlhotcopy instead because it can accomplish faster backups and faster restores.
Sunday, March 23, 2008
Ant: Simple JUnit Test
This is the final part of the so called Ant series I have been writing in this blog, about Apache Ant. This is an extremely brief tutorial on JUnit. The goal is to test Ant and JUnit framework integration .
The previous posts on Ant can be found here:
- Apache Ant
- Ant: Installation
- Ant: Hello World in Ant
- Ant: Java Hello World in Ant
- Ant: Java Swing Hello World in Ant
Prerequisites
In order to do this we will need to have a Java compiler, Ant, and JUnit installed.
Java Classes
First, we need a Java class to test. I had to make this example too simple according to my Java knowledge. This lacks any Java Docs or comments, but it's a pretty simple bit of code. :)
public class Math {
static public int add(int a, int b) {
return a + b;
}
static public int multiply ( int a, int b) {
return a * b;
}
}
Then to test this code, we need a second Java class that will
- import junit.framework.*
- extend TestCase
There are two important points to note in the sample. First, the routine is named testAdd. This convention tells that the routine is supposed to be a test and that it's targeting the add functionality. Here's the matching example.
import junit.framework.*;
public class TestMath extends TestCase {
protected void setUp() {
// put common setup code in here
}
protected void tearDown() {
// put common cleanup code in here
}
public void testAdd() {
int num1 = 3;
int num2 = 2;
int total = 5;
int sum = 0;
sum = Math.add(num1, num2);
assertEquals(sum, total);
}
public void testMulitply() {
int num1 = 3;
int num2 = 7;
int total = 21;
int sum = 0;
sum = Math.multiply(num1, num2);
assertEquals("Problem with multiply", sum, total);
num1 = 5;
num2 = 4;
total = 20;
sum = Math.multiply(num1, num2);
assertEquals("Problem with multiply", sum, total);
}
}
And both these files could be kept in a sub-folder named src
Ant Script
The last step is how to run your JUnit tests using Ant. Create a file called build.xml and place it in the main folder. The core of this scripts is the following, which does the JUnit tests.
<junit printsummary="yes" haltonfailure="yes" showoutput="yes" >
<classpath>
<pathelement path="${build}"/>
<fileset dir="lib">
<include name="**/*.jar"/>
</fileset>
</classpath>
<batchtest fork="yes" todir="${reports}/raw/">
<formatter type="xml"/>
<fileset dir="${src}">
<include name="**/*Test*.java"/>
</fileset>
</batchtest>
</junit>
The file I used is this one. (The inner details of this scripts are Ant Scripting and XML, which is not explained in this document, but really straightforward to understand)
Output
Run ant test in command line:
[root@nimal junit-sample]# ant test
Buildfile: build.xml
init:
compile:
[javac] Compiling 2 source files to /opt/junit-sample/bin
run-tests:
[junit] Running TestMath
[junit] Tests run: 2, Failures: 0, Errors: 0, Time elapsed: 0.321 sec
test:
[junitreport] Processing /opt/junit-sample/reports/TESTS-TestSuites.xml to /tmp/null1227203872
[junitreport] Loading stylesheet jar:file:/usr/local/ant/lib/ant-junit.jar!/org/apache/tools/ant
/taskdefs/optional/junit/xsl/junit-frames.xsl
[junitreport] Transform time: 1714ms
[junitreport] Deleting: /tmp/null1227203872
BUILD SUCCESSFUL
Total time: 6 seconds
Ant will also do nice things like create nice HTML reports! I've linked to a simple Ant script that will compile all the code in your "src" folder, run all the tests named "test*" and then create an HTML report in your "reports\html" folder.
I've linked to a zip file (ant-junit-sample.zip) that contains the build.xml file, the source code and the test class. (If you try to run it and get errors about JUnit not being found, remember to add that junit.jar to your Ant lib folder.)
Attachments
- ant-junit-sample.zip (109.6 kB) -
Scripts for Test
, - build.xml (2.7 kB) -
Ant+JUnit build script
,
Thursday, March 6, 2008
Ant: Java Swing Hello World in Ant
This is the fourth part of the so called Ant series I have been writing in this blog, about Apache Ant. This post is mainly about building and running a Java Swing program using Ant.
The previous posts on Ant can be found here:
1. Apache Ant
2. Ant: Installation
3. Ant: Hello World in Ant
4. Ant: Java Hello World in Ant
Java Swing Program
Create the following simple swing program and save it as HelloWorldSwing.java in a sub folder src:
import javax.swing.JFrame;
import javax.swing.JLabel;
public class HelloWorldSwing {
public static void main(String[] args) {
JFrame frame = new JFrame("HelloWorldSwing"); final JLabel label = new JLabel("Hello World");
frame.getContentPane().add(label);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.pack();
frame.setVisible(true); }
}
Ant Script
Use a text editor to create a file called build.xml and place it in the main folder:
<?xml version="1.0" encoding="UTF-8"?>
<project name="Run Test" default="run" basedir=".">
<target name="clean"> <delete dir="build"/>
</target>
<target name="compile" depends="clean">
<mkdir dir="build/classes"/>
<javac srcdir="src" destdir="build/classes"/> </target>
<target name="jar" depends="compile">
<mkdir dir="build/jar"/>
<jar destfile="build/jar/HelloWorldSwing.jar" basedir="build/classes"> <manifest>
<attribute name="Main-Class" value="HelloWorldSwing"/>
</manifest>
</jar>
</target>
<target name="run" depends="jar"> <java jar="build/jar/HelloWorldSwing.jar" fork="true"/>
</target>
</project>
Outputs and Problems
When we run this is text mode it, it compiles but fails to run. But when in GUI it runs.
[root@sanjaya-vm ant-swing]# ant
Buildfile: build.xml
clean:
[delete] Deleting directory /opt/ant-swing/build
compile:
[mkdir] Created dir: /opt/ant-swing/build/classes
[javac] Warning: HelloWorldSwing.java modified in the future.
[javac] Compiling 1 source file to /opt/ant-swing/build/classes
jar:
[mkdir] Created dir: /opt/ant-swing/build/jar
[jar] Building jar: /opt/ant-swing/build/jar/HelloWorldSwing.jar
run:
[java] Exception in thread "main" java.awt.HeadlessException:
[java] No X11 DISPLAY variable was set, but this program performed an operation which requires it.
[java] at java.awt.GraphicsEnvironment.checkHeadless(GraphicsEnvironment.java:159)
...
...
[java] at java.awt.Window.<init>(Window.java:406)
[java] at java.awt.Frame.<init>(Frame.java:402)
[java] at javax.swing.JFrame.<init>(JFrame.java:207)
[java] at HelloWorldSwing.main(Unknown Source) [java] Java Result: 1
BUILD SUCCESSFUL
Total time: 3 seconds
Feedback and questions are welcome via comment or you can email me at talkout AT SPAMFREE gmail DOT com
Wednesday, February 27, 2008
Ant: Java Hello World in Ant
The previous posts on Ant can be found here:
Java Program
Create the following simple program and save it as HelloWorld.java in a sub folder src:
public class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello World");
}
}
Ant Script
Use a text editor to create a file called build.xml and place it in the main folder:
<?xml version="1.0" encoding="UTF-8"?>
<project name="Run Test" default="run" basedir=".">
<target name="clean"> <delete dir="build"/>
</target>
<target name="compile" depends="clean">
<mkdir dir="build/classes"/>
<javac srcdir="src" destdir="build/classes"/> </target>
<target name="jar" depends="compile">
<mkdir dir="build/jar"/>
<jar destfile="build/jar/HelloWorld.jar"
basedir="build/classes"> <manifest>
<attribute name="Main-Class" value="HelloWorld"/>
</manifest>
</jar>
</target>
<target name="run" depends="jar"> <java jar="build/jar/HelloWorld.jar" fork="true"/>
</target>
</project>
Output
Run ant in command line:
[root@nimal ant-hw]# ant
Buildfile: build.xml
clean:
[delete] Deleting directory /opt/ant-hw/build
compile:
[mkdir] Created dir: /opt/ant-hw/build/classes
[javac] Warning: HelloWorld.java modified in the future. [javac] Compiling 1 source file to /opt/ant-hw/build/classes
jar:
[mkdir] Created dir: /opt/ant-hw/build/jar
[jar] Building jar: /opt/ant-hw/build/jar/HelloWorld.jar
run:
[java] Hello World
BUILD SUCCESSFUL
Total time: 4 seconds
Enhance the build file
Now we have a working buildfile we could do some enhancements: many time you are referencing the same directories, main-class and jar-name are hard coded, and while invocation you have to remember the right order of build steps.
<project name="HelloWorld" basedir="." default="main">
<property name="src.dir" value="src"/>
<property name="build.dir" value="build"/>
<property name="classes.dir" value="${build.dir}/classes"/>
<property name="jar.dir" value="${build.dir}/jar"/>
<property name="main-class" value="HelloWorld"/>
<target name="clean">
<delete dir="${build.dir}"/>
</target>
<target name="compile">
<mkdir dir="${classes.dir}"/> <javac srcdir="${src.dir}" destdir="${classes.dir}"/>
</target>
<target name="jar" depends="compile">
<mkdir dir="${jar.dir}"/>
<jar destfile="${jar.dir}/${ant.project.name}.jar"
basedir="${classes.dir}">
<manifest>
<attribute name="Main-Class" value="${main-class}"/> </manifest>
</jar>
</target>
<target name="run" depends="jar">
<java jar="${jar.dir}/${ant.project.name}.jar" fork="true"/> </target>
<target name="clean-build" depends="clean,jar"/>
<target name="main" depends="clean,run"/>
</project>
Saturday, February 23, 2008
Ant: Installation
In this series of Ant, I put and introductory post which is followed by a Hello World post, and then I got a couple of IMs asking how could one come to Hello World before an installation post. (Seems thats the standard way of tutorial, so I said I'm not writing any tutorials, but thought of posting this now... :) ... ).
System Requirements for Ant
Ant has been used successfully on many platforms, including Linux, MacOS X, Windows XP and Unix. To build and use Ant, you must have a JAXP-compliant XML parser installed and available on your classpath, such as Xerces.
Note: I did this installation on a HP server running Red Hat Enterprise Linux WS Version 4 Update 4.
For the current version of Ant, you will also need a JDK installed on your system, version 1.2 or later required, 1.5 or later strongly recommended. The later the version of Java, the more Ant tasks you get.
Note: If a JDK is not present, only the JRE runtime, then many tasks will not work.
Building Ant
Obtaining Ant
To build Ant from source, you can either install the Ant source distribution or checkout the Ant module from SVN. I obtained the Ant source version and placed it at /opt/
Once you have obtained the source, change into the installation directory and run,
[root@nimal opt]# tar -xzvf apache-ant-1.7.0-src.tar.gz
This will creat Set the JAVA_HOME environment variable to the directory where the JDK is installed. See Installing Ant for examples on how to do this for your operating system.
Note: The bootstrap process of Ant requires a greedy compiler like Sun's javac or jikes. It does not work with gcj or kjc.
Make sure you have downloaded any auxiliary jars required to build tasks you are interested in. These should be added to the lib/optional directory of the source tree. See Library Dependencies for a list of JAR requirements for various features. Note that this will make the auxiliary JAR available for the building of Ant only. For running Ant you will still need to make the JARs available as described under Installing Ant.
In our case we need the JUnit jar.
Environment Settings
Linux/Unix (bash)
Assume Ant is installed in /usr/local/ant. The following sets up the environment:
export ANT_HOME=/usr/local/ant export JAVA_HOME=/usr/java/jdk1.6.0/ export PATH=${PATH}:${ANT_HOME}/bin
The above can be set by editing the .bashrc file.
[root@nimal ~]# vi ~/.
Once this file is opened it will look like this.
# .bashrc
# User specific aliases and functions
alias rm='rm -i'
alias cp='cp -i'
alias mv='mv -i'
# Source global definitions
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi
Append these lines below the end of the if clause below fi
export ANT_HOME=/usr/local/ant/
export JAVA_HOME=/usr/java/jdk1.6.0/
export PATH=${PATH}:${ANT_HOME}/bin
And the final file should look like this; save and close the file.
# .bashrcNormal build and install
# User specific aliases and functions
alias rm='rm -i'
alias cp='cp -i'
alias mv='mv -i'
# Source global definitions
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi
export ANT_HOME=/usr/local/ant/
export JAVA_HOME=/usr/java/jdk1.6.0/
export PATH=${PATH}:${ANT_HOME}/bin
Your are now ready to build Ant:
build -Ddist.dir=<directory_to_contain_Ant_distribution> dist (Windows) sh build.sh -Ddist.dir=<directory_to_contain_Ant_distribution> dist (Unix)
[root@nimal opt]# cd /opt/apache-ant-1.7.0/
[root@nimal apache-ant-1.7.0]# sh build.sh -Ddist.dir=/usr/local/ant/ dist
Buildfile: build.xml
dist:
prepare:
check_for_optional_packages:
build:
[copy] Copying 2 files to /opt/apache-ant-1.7.0/build/classes
jars:
[jar] Building jar: /opt/apache-ant-1.7.0/build/lib/ant.jar
.
.
.
compile-tests:
test-jar:
dist-lite:
[mkdir] Created dir: /usr/local/ant
[mkdir] Created dir: /usr/local/ant/bin
[mkdir] Created dir: /usr/local/ant/lib
[copy] Copying 8 files to /usr/local/ant/lib
[copy] Copying 2 files to /usr/local/ant/lib
[copy] Copying 13 files to /usr/local/ant/bin
javadoc_check:
javadocs:
[mkdir] Created dir: /opt/apache-ant-1.7.0/build/javadocs
[javadoc] Generating Javadoc
.
.
.
[javadoc] 114 warnings
dist_javadocs:
[mkdir] Created dir: /usr/local/ant/docs/manual/api
[copy] Copying 1180 files to /usr/local/ant/docs/manual/api
internal_dist:
[mkdir] Created dir: /usr/local/ant/etc
[copy] Copying 1 file to /usr/local/ant/lib
[copy] Copying 1 file to /usr/local/ant/lib
[copy] Copying 25 files to /usr/local/ant/lib
[copy] Copying 1 file to /usr/local/ant/lib
[copy] Copying 259 files to /usr/local/ant/docs
[copy] Copying 33 files to /usr/local/ant/docs
[copy] Copying 11 files to /usr/local/ant
[copy] Copying 15 files to /usr/local/ant/etc
BUILD SUCCESSFUL
Total time: 59 seconds
This will create a binary distribution of Ant in the directory you specified.
The above action does the following:
- If necessary it will bootstrap the Ant code. Bootstrapping involves the manual compilation of enough Ant code to be able to run Ant. The bootstrapped Ant is used for the remainder of the build steps.
- Invokes the bootstrapped Ant with the parameters passed to the build script. In this case, these parameters define an Ant property value and specify the "dist" target in Ant's own build.xml file.
- Create the ant.jar and ant-launcher.jar JAR files
- Create optional JARs for which the build had the relevant libraries. If a particular library is missing from ANT_HOME/lib/optional, then the matching ant- JAR file will not be created. For example, ant-junit.jar is only built if there is a junit.jar in the optional directory.
Other ways to build and install
On most occasions you will not need to explicitly bootstrap Ant since the build scripts do that for you. If however, the build file you are using makes use of features not yet compiled into the bootstrapped Ant, you will need to manually bootstrap. Run bootstrap.bat (Windows) or bootstrap.sh (UNIX) to build a new bootstrap version of Ant. If you wish to install the build into the current ANT_HOME directory, you can use:
build install (Windows)
sh build.sh install (Unix)
You can avoid the lengthy Javadoc step, if desired, with:
build install-lite (Windows)
sh build.sh install-lite (Unix)
This will only install the bin and lib directories.
Both the install and install-lite targets will overwrite the current Ant version in ANT_HOME.
Checking the InstallationNow we have built and installed Ant, and we can check if everything works properly, as shown below.
[root@nimal ~]# which antThis is just a brief document related to Ant installation which I did on a RHEL4 server. I think this should work on other environments as well, but I'm not sure about that. If someone of you try this using my doc and if you are successful just let me know via a comment. Also if you have any doubts you can ask me, but I can assure answers, if-and-only-if its under my intellectual capacity :).
/usr/local/ant/bin/ant
[root@nimal ~]# ant -version
Apache Ant version 1.7.0 compiled on November 13 2007
Reference: http://ant.apache.org/manual/install.html
Monday, February 18, 2008
Ant: Hello World in Ant
Use a text editor to create a file called build.xml:
<?xml version="1.0"?>
<project name="My Project" default="hello">
<target name="hello">
<echo>Hello World!</echo>
</target>
</project>
The first line in the file tells the system that this is an XML file. The next line tells ant that we have a project named "My Project" and that it has a default target called "hello". Note that the file must always start with a <project> and end with a </project>. The central three lines are the one and only target in the file. They give the target a name and the target has just one task called "echo"
You can now open a shell and type "ant". The default task is a required attribute of the project. Each target must have a name.
Output of Hello World
[root@nimal ant-tests]# ant
Buildfile: build.xml
hello:
[echo] Hello World!
BUILD SUCCESSFUL
Total time: 1 second
[root@nimal ant-tests]#
Variations
The following variations of echo will also give similar output.
<echo message="Hello There!"></echo>
<echo message="Hello There!"/>
Saturday, January 26, 2008
Apache Ant
Apache Ant (or simply Ant) is an XML-based build scripting language used heavily by the Open Source community. This is specially handy when it come is to automating the build process. Also Ant is infamous for its good going with Java projects, though it is very much capable of doing various other stuff.
Apache Ant:
- An operating system and language neutral XML based "Build Tool"
- A scripting language for executing any complex file-system processes that can be run from a command line interface
- A.N.T. – Another Neat Tool
- User for Building the Project
- Ant Project – a collection of named targets that can run in any order depending on the time stamps of the files in the file system. Each build file contains one project.
- Ant Target – a fixed series of ant tasks in a specified order that can depend on other named targets. Targets can depend only on other targets, not on projects or tasks.
- Ant Task – something that ant can execute such as a compile, copy or replace. Most tasks have very convenient default values. See the Ant manual for a complete list of tasks.
There is lot more to read and learn about Ant and even I don't know much about it except to my using it for a build automation project. So it'll be best to read from some external resources to get a better idea about it.
Happy Building with Apache Ant...!
Another Beginning : Sharing Your Knowlegde
Hi Friend, In these modern age, knowlege is the wealth. We meet many persons who are expertise in many fields. They have all the knowledge about it. But not only them, others also may need that knowledge for their works. If one person work in his field for a long time, he get much more knowlegde, new ways and means about doing things, and many more things. You know sharing is a good habit. Then for who knows , who expertise in some technology or field, the best thing he can do is share that knowlegde with all others who don't know about them.
So I thought to start another tech blog for sharing our knowledge, experiences about what we know, what we are familiar with. For anyone who is interested in sharing his/her knowledge can blog in this site. ( Actually, before blogging send me a email mentioning your mail address with a description about you, so i can add you as a blogger in this site. or add a comment to this post mentioning your mail address with a description about you.)