Maven - Build & Test Project
Quello che abbiamo imparato nel capitolo Creazione del progetto è come creare un'applicazione Java utilizzando Maven. Ora vedremo come costruire e testare l'applicazione.
Vai alla directory C: / MVN in cui hai creato la tua applicazione java. ApertoconsumerBankingcartella. Vedrai il filePOM.xml file con i seguenti contenuti.
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.companyname.projectgroup</groupId>
<artifactId>project</artifactId>
<version>1.0</version>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
</dependency>
</dependencies>
</project>
Qui puoi vedere, Maven ha già aggiunto Junit come framework di test. Per impostazione predefinita, Maven aggiunge un file di origineApp.java e un file di prova AppTest.java nella sua struttura di directory predefinita, come discusso nel capitolo precedente.
Apriamo la console dei comandi, andiamo nella directory C: \ MVN \ consumerBanking ed eseguiamo quanto segue mvn comando.
C:\MVN\consumerBanking>mvn clean package
Maven inizierà a costruire il progetto.
[INFO] Scanning for projects...
[INFO] -------------------------------------------------------------------
[INFO] Building consumerBanking
[INFO] task-segment: [clean, package]
[INFO] -------------------------------------------------------------------
[INFO] [clean:clean {execution: default-clean}]
[INFO] Deleting directory C:\MVN\consumerBanking\target
[INFO] [resources:resources {execution: default-resources}]
[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources,
i.e. build is platform dependent!
[INFO] skip non existing resourceDirectory C:\MVN\consumerBanking\src\main\resources
[INFO] [compiler:compile {execution: default-compile}]
[INFO] Compiling 1 source file to C:\MVN\consumerBanking\target\classes
[INFO] [resources:testResources {execution: default-testResources}]
[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources,
i.e. build is platform dependent!
[INFO] skip non existing resourceDirectory C:\MVN\consumerBanking\src\test\resources
[INFO] [compiler:testCompile {execution: default-testCompile}]
[INFO] Compiling 1 source file to C:\MVN\consumerBanking\target\test-classes
[INFO] [surefire:test {execution: default-test}]
[INFO] Surefire report directory: C:\MVN\consumerBanking\target\surefire-reports
-----------------------------------------------------
T E S T S
-----------------------------------------------------
Running com.companyname.bank.AppTest
Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.027 sec
Results :
Tests run: 1, Failures: 0, Errors: 0, Skipped: 0
[INFO] [jar:jar {execution: default-jar}]
[INFO] Building jar: C:\MVN\consumerBanking\target\
consumerBanking-1.0-SNAPSHOT.jar
[INFO]-----------------------------------------------
[INFO] BUILD SUCCESSFUL
[INFO]-----------------------------------------------
[INFO] Total time: 2 seconds
[INFO] Finished at: Tue Jul 10 16:52:18 IST 2012
[INFO] Final Memory: 16M/89M
[INFO]-----------------------------------------------
Hai costruito il tuo progetto e creato il file jar finale, di seguito sono riportati i concetti chiave di apprendimento:
Diamo a Maven due obiettivi, prima di pulire la directory di destinazione (clean) e quindi impacchettare l'output della build del progetto come jar (pacchetto).
Il jar confezionato è disponibile nella cartella consumerBanking \ target come consumerBanking-1.0-SNAPSHOT.jar.
I rapporti di prova sono disponibili nella cartella consumerBanking \ target \ surefire-reports.
Maven compila i file del codice sorgente e quindi verifica i file del codice sorgente.
Quindi Maven esegue i casi di test.
Infine, Maven crea il pacchetto.
Ora apri la console dei comandi, vai nella directory C: \ MVN \ consumerBanking \ target \ classes ed esegui il seguente comando java.
>java com.companyname.bank.App
Vedrai il risultato come segue:
Hello World!
Aggiunta di file di origine Java
Vediamo come possiamo aggiungere ulteriori file Java nel nostro progetto. Apri la cartella C: \ MVN \ consumerBanking \ src \ main \ java \ com \ companyname \ bank, crea la classe Util in essa come Util.java.
package com.companyname.bank;
public class Util {
public static void printMessage(String message){
System.out.println(message);
}
}
Aggiorna la classe App per usare la classe Util.
package com.companyname.bank;
/**
* Hello world!
*
*/
public class App {
public static void main( String[] args ){
Util.printMessage("Hello World!");
}
}
Ora apri la console dei comandi, vai su C:\MVN\consumerBanking directory ed eseguire quanto segue mvn comando.
>mvn clean compile
Dopo che la compilazione di Maven ha avuto esito positivo, vai alla directory C: \ MVN \ consumerBanking \ target \ classes ed esegui il seguente comando java.
>java -cp com.companyname.bank.App
Vedrai il risultato come segue:
Hello World!