Índice de contenidos
- 1. Introducción
- 2. Entorno
- 3. Configurando el pom.xml
- 4. Generando un archivo EAR usando Ant
- 5. Conclusiones
- 6. Sobre el autor
1. Introducción
Ya hemos visto varios tutoriales de Maven, y hemos vistos que con Maven podemos hacer muuuuuchas cosas. Sin embargo siempre encontraremos alguna tarea que no es capaz de hacer (por ejemplo en el campo de la generación de código, donde Maven está más flojo).
En estas ocasiones podemos desarrollar un plugin de Maven (Javier Antoniucci ya nos contó como enhttps://adictosaltrabajo.com/tutoriales/tutoriales.php?pagina=PluginsMaven). Otra opción sería llamar a tareas de Ant (http://ant.apache.org/) para hacer lo que necesitamos.
En este tutorial vamos a explorar un poco la segunda opción, viendo como podemos, desde nuestro pom.xml, invocar tareas de Ant.
Otro motivo muy interesante por el cual nos puede interesar invocar tareas de Ant desde el pom.xml, es para migrar poco a poco proyectos que actualmente tenemos con Ant, a Maven.
2. Entorno
El tutorial está escrito usando el siguiente entorno:
- Hardware: Portátil Asus G1 (Core 2 Duo a 2.1 GHz, 2048 MB RAM, 120 GB HD).
- Sistema Operativo: GNU / Linux, Debian (unstable), Kernel 2.6.23, KDE 3.5
- JDK 1.5.0_13 (instalada con el paquete sun-java5-jdk de Debian)
- Maven 2.0.8
- Ant 1.7.0
3. Configurando el pom.xml
Para ejecutar tareas de Ant en nuestro pom.xml
basta con configurar el plugin maven-antrun-plugin
(http://maven.apache.org/plugins/maven-antrun-plugin/):
<groupId>org.apache.maven.plugins</groupId> <artifactId>maven-antrun-plugin</artifactId>
Vamos a ver un ejemplo sencillo (sacado de la propia documentación del plugin):
4.0.0 my-test-group my-test-app 1.0-SNAPSHOT org.apache.maven.plugins maven-antrun-plugin show-classpaths compile run
Como al configurar cualquier plugin de Maven, con <goal>
le indicamos que objetivo del plugin queremos ejecutar, en este caso el run
. Y con <phase>
indicamos en que fase del ciclo de vida de Maven queremos hacer la ejecución.
Lo interesante es lo que tenemos en el elemento <tasks>
, aquí estamos escribiendo directamente tareas de Ant. En el ejemplo vemos como asignamos a propiedades los distintos classpath, y luego los mostramos por consola.
Si bien esto es posible, no es muy recomendable, ya que el pom.xml
queda muy “cargado”. Es mejor tener nuestras tareas de Ant en un build.xml
e invocar a este con la tarea de Ant <ant>
. En el apartado siguiente veremos un ejemplo de esto.
4. Generando un archivo EAR usando Ant
Ahora vamos a ver un ejemplo de como generar un archivo EAR usando un script en Ant. Ojo, esto es sólo un ejemplo de como integrar scripts de Ant con Maven, si queremos generar un archivo EAR desde Maven, es más interesante usar el plugin maven-ear-plugin
(http://maven.apache.org/plugins/maven-ear-plugin/index.html).
Volvamos al ejemplo:
4.0.0 com.autentia.tutorial ant-example 1.0-SNAPSHOT org.apache.maven.plugins maven-antrun-plugin package-ear package run
En este ejemplo podemos ver como estamos invocando el target ear
de nuestro script build.xml
(no es necesario especificar el nombre del fichero porque build.xml
es la opción por defecto). También podemos ver como le podemos pasar parámetros a nuestro script de Ant.
Ahora mostramos como sería el script build.xml:
5. Conclusiones
Con estos sencillos ejemplos hemos visto como podemos aumentar la potencia de Maven, llamando a scripts de Ant.
Antes de terminar lo que si os quiero aconsejar es que no abuséis de esta técnica, Maven ya tiene multitud de plugins para hacer prácticamente de todo; así que os recomiendo que, aunque tengáis experiencia con Ant y estéis empezando con Maven, os deis una vuelta por http://maven.apache.org/plugins/.
Usar directamente los plugins de Maven siempre os va a ofrecer más ventajas, ya que se integran con todo el ciclo de vida de Maven. Por ejemplo, en el ejemplo que hemos visto antes en el que generamos un archivo EAR, este archivo no se instalará en nuestro repositorio local al hacer mvn install
, ni en el remoto al hacer mvn deploy
.
6. Sobre el autor
Alejandro Pérez García, Ingeniero en Informática (especialidad de Ingeniería del Software)
Socio fundador de Autentia (Formación, Consultoría, Desarrollo de sistemas transaccionales)
mailto:alejandropg@autentia.com
Autentia Real Business Solutions S.L. – “Soporte a Desarrollo”
Muy útil, gracias Alejandro!