Eclipse Luna sous Debian 7 ne démarre pas

En train de tester en parallèle les IDE Netbeans et Eclipse sous Debian 7 Wheezy, on constate rapidement que les versions dans le dépôt ne sont pas les plus récentes. En effet Debian 7 est livré avec java 6. Netbeans et Eclipse sont respectivement disponibles en version 7 et 3.8.

Un petit passage par le gestionnaire de paquet aptitude permet de récupérer java 7 en version openjdk comme la 6 installée par défaut. D’autres jvm sont présentes, il suffit d’aller voir en faisant:

ls -l /usr/lib/jvm

Afin de bénéficier de java 8 il faudra télécharger la JVM chez Oracle. On pourra installer les JDK Oracles n’importe où et ajouter des liens symboliques dans le répertoire /usr/lib/jvm

La dernière version de Netbeans, 8.0.1 est obtenu sous la forme d’un installeur sh qui trouve immédiatement le dernier JDK (sans doute en scannant le répertoire cité précédemment). L’installation du dernier Eclipse, nom de code Luna, version 4.4.1 est un peu plus brute: c’est une simple archive.

Arrive le moment du lancement: Netbeans démarre sans souci, à l’aide du raccourci ajouté sur le bureau. Malheureusement je ne peux pas en dire autant d’Eclipse qui plante au bout d’une dizaine de seconde sur le “splash screen”.  La JVM par défaut sous Debian 7 est l’open-jdk 6, j’ai eu donc l’idée de tester Eclipse avec les autres JVM disponibles sous mon système: java 6 en version oracle, java 7 en open-jdk, en oracle, java 8 de oracle. Pour cela il faut utiliser le fichier eclipse.ini en ajoutant l’option -vm comme par exemple

-vm
/usr/lib/jvm/jdk1.8.0/bin/java

Rien à faire, Eclipse plante toujours. La pile d’erreur indique un problème avec GTK et finalement c’est le prix à payer quand on ne fait pas du pure Java. Ah ! Eclipse que tous les développeurs ont adoptés parce que SWT, le boîte à outils graphique, faisait du natif là où Swing écrit les widget avec du code Java donc plus lent. Voilà ce qui arrive quand on vend son âme au diable, fini le WORA. C’est un comble pour un développeur Java de devoir modifier son IDE pour lui dire d’utiliser GTK2, solution pour faire fonctionner Eclipse sous Debian 7. Dans le fichier eclipse.ini il faut mettre juste après l’option startup :

--launcher.GTK_version
2

 

Un environnement de developpement Java: Création de l’arborescence du projet

Le gestionnaire de source installé et paramétré, il est maintenant possible d’y importer la première mouture de l’arborescence du projet. Il s’agit de l’étape sine-qua-none d’un développement distribué et multi-utilisateur. Comme nous utilisons un gestionnaire de source gérant le renommage et le déplacement de fichier, il n’est pas nécessaire d’avoir la structure de répertoire définitive. Il suffit d’ajouter au repository une structure fonctionnel c’est-à-dire qui compile au moins et nous pourrons toujours la modifier par la suite.

Nous adoptons l’arborescence de projet définie par Maven 2 et l”DE utilisé Netbeans, va nous simplifier la tâche en nous apportant une intégration poussée avec Maven. Pour cela aller dans le menu Tools > plugin puis l’onglet Available Plugins. Sélectionner Maven puis cliquer sur Installer.

Netbeans > Menu Tools > PLugin Ajout duplugin Maven

Le plugin maven permet d’ajouter dans Netbeans des menus pour lancer des goals maven et une intégration poussée des concepts de Maven dans les fenêtres d’éditions.

La création d’un projet Maven dans Netbeans est alors très simplifiée. Aller dans le menu File > New Project puis choisir la catégorie Maven et le type Maven Project. Cela donne accès à une liste d’archetype c’est-à-dire de modèle de projet Maven. Il en existe de trés nombreux et le chargement de cette liste est un peu long  la première fois qu’on l’utilise (En effet sont contenu est rapatrié depuis internet). Pour les besoins de l’article nous allons simplement choisir Maven Quickstart Archetype. Il permet de créer un projet qui génère un jar. Il en existe de beaucoup plus complexe et Maven nous  permet d’en créer nous même afin de répondre à tous les besoins. Le dernier écran permet de renseigner les informations primordiales du nouveau projet: nom, paquet, version.

Fênetre de création de projet de Netbeans Fenêtre de selection de l'archetype utilisé dans la création de projet Maven Fenetre de personnalisation du projet qui va être créé par un archetype Maven

La création du projet va prendre quelque seconde la première fois que vous utilisez cette fonction. En effet le principe de maven est de ne pas inclure les dépendances d’un projet. L’éxecution de l’archétype pour le création d’un projet est un cas particulier de build maven. Les dépendances sont donc téléchargées depuis le repository central de Maven. Ce téléchargement n’interviendra qu’une seule fois et les dépendances seront conservées dans le repository maven 2 du plugin Netbeans i.e. quelque part dans les fichiers internes de Netbeans.

Voici un exemple de log d’éxecution quand il n’est pas nécessaire de résoudre par internet les dépendances manquantes:

Scanning for projects…
project-execute
Setting property: classpath.resource.loader.class => ‘org.codehaus.plexus.velocity.ContextClassLoaderResourceLoader’.
Setting property: velocimacro.messages.on => ‘false’.
Setting property: resource.loader => ‘classpath’.
Setting property: resource.manager.logwhenfound => ‘false’.
**************************************************************
Starting Jakarta Velocity v1.4
RuntimeInstance initializing.
Default Properties File: org/apache/velocity/runtime/defaults/velocity.properties
Default ResourceManager initializing. (class org.apache.velocity.runtime.resource.ResourceManagerImpl)
Resource Loader Instantiated: org.codehaus.plexus.velocity.ContextClassLoaderResourceLoader
ClasspathResourceLoader : initialization starting.
ClasspathResourceLoader : initialization complete.
ResourceCache : initialized. (class org.apache.velocity.runtime.resource.ResourceCacheImpl)
Default ResourceManager initialization complete.
Loaded System Directive: org.apache.velocity.runtime.directive.Literal
Loaded System Directive: org.apache.velocity.runtime.directive.Macro
Loaded System Directive: org.apache.velocity.runtime.directive.Parse
Loaded System Directive: org.apache.velocity.runtime.directive.Include
Loaded System Directive: org.apache.velocity.runtime.directive.Foreach
Created: 20 parsers.
Velocimacro : initialization starting.
Velocimacro : adding VMs from VM library template : VM_global_library.vm
[ERROR]ResourceManager : unable to find resource ‘VM_global_library.vm’ in any resource loader.
Velocimacro : error using  VM library template VM_global_library.vm : org.apache.velocity.exception.ResourceNotFoundException: Unable to find resource ‘VM_global_library.vm’
Velocimacro :  VM library template macro registration complete.
Velocimacro : allowInline = true : VMs can be defined inline in templates
Velocimacro : allowInlineToOverride = false : VMs defined inline may NOT replace previous VM definitions
Velocimacro : allowInlineLocal = false : VMs defined inline will be  global in scope if allowed.
Velocimacro : initialization complete.
Velocity successfully started.
[archetype:create]
—————————————————————————-
Using following parameters for creating Archetype: maven-archetype-quickstart:1.0
—————————————————————————-
Parameter: groupId, Value: net.bressure
Parameter: packageName, Value: net.bressure.vroom
Parameter: package, Value: net.bressure.vroom
Parameter: artifactId, Value: vroom
Parameter: basedir, Value: /home/thierry/NetBeansProjects
Parameter: version, Value: 1.0-SNAPSHOT
********************* End of debug info from resources from generated POM ***********************
Archetype created in dir: /home/thierry/NetBeansProjects/vroom
————————————————————————
BUILD SUCCESSFUL
————————————————————————
Total time: < 1 second
Finished at: Mon Oct 06 12:50:15 CEST 2008
Final Memory: 66M/69M
————————————————————————

Le projet qui vien d’être créé est compilable et comporte déjà les prémices de l’atelier de développement Java agile. Le build du projet passe par une phase d’éxécution des tests unitaires. Voici un exemple de sortie en faisant un clic-droit sur le projet et sélectionnant build :

Scanning for projects…
project-execute
[#process-resources]
[resources:resources]
Using default encoding to copy filtered resources.
[#compile]
[compiler:compile]
Nothing to compile – all classes are up to date
[#process-test-resources]
[resources:testResources]
Using default encoding to copy filtered resources.
[#test-compile]
[compiler:testCompile]
Nothing to compile – all classes are up to date
[#test]
[surefire:test]
Surefire report directory: /home/thierry/NetBeansProjects/vroom/target/surefire-reports
——————————————————-
T E S T S
——————————————————-
Running net.bressure.vroom.AppTest
Results :
[#package]
[jar:jar]
[#install]
[install:install]
Installing /home/thierry/NetBeansProjects/vroom/target/vroom-1.0-SNAPSHOT.jar to /home/thierry/.m2/repository/net/bressure/vroom/1.0-SNAPSHOT/vroom-1.0-SNAPSHOT.jar
————————————————————————
BUILD SUCCESSFUL
————————————————————————
Total time: 1 second
Finished at: Mon Oct 06 16:23:49 CEST 2008
Final Memory: 18M/56M
————————————————————————

Un projet qui build est un projet qui doit être partagé. Nous allons importer dans le repository l’arborescence du projet. Pour ce faire Netbeans s’interface avec Subversion à merveille. Sur le projet utiliser un clic droit > Versionning > Import to Subversion Repository pour accéder à la fenêtre de dialogue pour choisir l’emplacement sur le serveur subversion.

Nebeans Menu d'import de nouveau sources dans Subversion Netbeans Dialogue d'import de sources dans subversion

L’url à renseignée est de la forme svn://<serveur>/<projet>/trunk et dans le cas de l’article cela donne svn://localhost/vroom/trunk

Dans la boite de dialogue suivante supprimer le dernier répertoire pour ne garder que <projet>/trunk

Le trunk final est important car cela respecte l’arborescence classique des projets sous Subversion. Le trunk est l’équivalent de la HEAD sous CVS.

Nous avons créé un projet maven 2 en utilisant un archétype. Le projet est disponible dans le référentiel de source Subversion. La prochaine étape va être la mise en place de l’intégration continue.

Un environnement de developpement Java: Création de l’arborescence du projet

Le gestionnaire de source installé et paramétré, il est maintenant possible d’y importer la première mouture de l’arborescence du projet. Il s’agit de l’étape sine-qua-none d’un développement distribué et multi-utilisateur. Comme nous utilisons un gestionnaire de source gérant le renommage et le déplacement de fichier, il n’est pas nécessaire d’avoir la structure de répertoire définitive. Il suffit d’ajouter au repository une structure fonctionnel c’est-à-dire qui compile au moins et nous pourrons toujours la modifier par la suite.

Nous adoptons l’arborescence de projet définie par Maven 2 et l”DE utilisé Netbeans, va nous simplifier la tâche en nous apportant une intégration poussée avec Maven. Pour cela aller dans le menu Tools > plugin puis l’onglet Available Plugins. Sélectionner Maven puis cliquer sur Installer.

Netbeans > Menu Tools > PLugin Ajout duplugin Maven

Le plugin maven permet d’ajouter dans Netbeans des menus pour lancer des goals maven et une intégration poussée des concepts de Maven dans les fenêtres d’éditions.

La création d’un projet Maven dans Netbeans est alors très simplifiée. Aller dans le menu File > New Project puis choisir la catégorie Maven et le type Maven Project. Cela donne accès à une liste d’archetype c’est-à-dire de modèle de projet Maven. Il en existe de trés nombreux et le chargement de cette liste est un peu long  la première fois qu’on l’utilise (En effet sont contenu est rapatrié depuis internet). Pour les besoins de l’article nous allons simplement choisir Maven Quickstart Archetype. Il permet de créer un projet qui génère un jar. Il en existe de beaucoup plus complexe et Maven nous  permet d’en créer nous même afin de répondre à tous les besoins. Le dernier écran permet de renseigner les informations primordiales du nouveau projet: nom, paquet, version.

Fênetre de création de projet de Netbeans Fenêtre de selection de l'archetype utilisé dans la création de projet Maven Fenetre de personnalisation du projet qui va être créé par un archetype Maven

La création du projet va prendre quelque seconde la première fois que vous utilisez cette fonction. En effet le principe de maven est de ne pas inclure les dépendances d’un projet. L’éxecution de l’archétype pour le création d’un projet est un cas particulier de build maven. Les dépendances sont donc téléchargées depuis le repository central de Maven. Ce téléchargement n’interviendra qu’une seule fois et les dépendances seront conservées dans le repository maven 2 du plugin Netbeans i.e. quelque part dans les fichiers internes de Netbeans.

Voici un exemple de log d’éxecution quand il n’est pas nécessaire de résoudre par internet les dépendances manquantes:

Scanning for projects…
project-execute
Setting property: classpath.resource.loader.class => ‘org.codehaus.plexus.velocity.ContextClassLoaderResourceLoader’.
Setting property: velocimacro.messages.on => ‘false’.
Setting property: resource.loader => ‘classpath’.
Setting property: resource.manager.logwhenfound => ‘false’.
**************************************************************
Starting Jakarta Velocity v1.4
RuntimeInstance initializing.
Default Properties File: org/apache/velocity/runtime/defaults/velocity.properties
Default ResourceManager initializing. (class org.apache.velocity.runtime.resource.ResourceManagerImpl)
Resource Loader Instantiated: org.codehaus.plexus.velocity.ContextClassLoaderResourceLoader
ClasspathResourceLoader : initialization starting.
ClasspathResourceLoader : initialization complete.
ResourceCache : initialized. (class org.apache.velocity.runtime.resource.ResourceCacheImpl)
Default ResourceManager initialization complete.
Loaded System Directive: org.apache.velocity.runtime.directive.Literal
Loaded System Directive: org.apache.velocity.runtime.directive.Macro
Loaded System Directive: org.apache.velocity.runtime.directive.Parse
Loaded System Directive: org.apache.velocity.runtime.directive.Include
Loaded System Directive: org.apache.velocity.runtime.directive.Foreach
Created: 20 parsers.
Velocimacro : initialization starting.
Velocimacro : adding VMs from VM library template : VM_global_library.vm
[ERROR]ResourceManager : unable to find resource ‘VM_global_library.vm’ in any resource loader.
Velocimacro : error using  VM library template VM_global_library.vm : org.apache.velocity.exception.ResourceNotFoundException: Unable to find resource ‘VM_global_library.vm’
Velocimacro :  VM library template macro registration complete.
Velocimacro : allowInline = true : VMs can be defined inline in templates
Velocimacro : allowInlineToOverride = false : VMs defined inline may NOT replace previous VM definitions
Velocimacro : allowInlineLocal = false : VMs defined inline will be  global in scope if allowed.
Velocimacro : initialization complete.
Velocity successfully started.
[archetype:create]
—————————————————————————-
Using following parameters for creating Archetype: maven-archetype-quickstart:1.0
—————————————————————————-
Parameter: groupId, Value: net.bressure
Parameter: packageName, Value: net.bressure.vroom
Parameter: package, Value: net.bressure.vroom
Parameter: artifactId, Value: vroom
Parameter: basedir, Value: /home/thierry/NetBeansProjects
Parameter: version, Value: 1.0-SNAPSHOT
********************* End of debug info from resources from generated POM ***********************
Archetype created in dir: /home/thierry/NetBeansProjects/vroom
————————————————————————
BUILD SUCCESSFUL
————————————————————————
Total time: < 1 second
Finished at: Mon Oct 06 12:50:15 CEST 2008
Final Memory: 66M/69M
————————————————————————

Le projet qui vien d’être créé est compilable et comporte déjà les prémices de l’atelier de développement Java agile. Le build du projet passe par une phase d’éxécution des tests unitaires. Voici un exemple de sortie en faisant un clic-droit sur le projet et sélectionnant build :

Scanning for projects…
project-execute
[#process-resources]
[resources:resources]
Using default encoding to copy filtered resources.
[#compile]
[compiler:compile]
Nothing to compile – all classes are up to date
[#process-test-resources]
[resources:testResources]
Using default encoding to copy filtered resources.
[#test-compile]
[compiler:testCompile]
Nothing to compile – all classes are up to date
[#test]
[surefire:test]
Surefire report directory: /home/thierry/NetBeansProjects/vroom/target/surefire-reports
——————————————————-
T E S T S
——————————————————-
Running net.bressure.vroom.AppTest
Results :
[#package]
[jar:jar]
[#install]
[install:install]
Installing /home/thierry/NetBeansProjects/vroom/target/vroom-1.0-SNAPSHOT.jar to /home/thierry/.m2/repository/net/bressure/vroom/1.0-SNAPSHOT/vroom-1.0-SNAPSHOT.jar
————————————————————————
BUILD SUCCESSFUL
————————————————————————
Total time: 1 second
Finished at: Mon Oct 06 16:23:49 CEST 2008
Final Memory: 18M/56M
————————————————————————

Un projet qui build est un projet qui doit être partagé. Nous allons importer dans le repository l’arborescence du projet. Pour ce faire Netbeans s’interface avec Subversion à merveille. Sur le projet utiliser un clic droit > Versionning > Import to Subversion Repository pour accéder à la fenêtre de dialogue pour choisir l’emplacement sur le serveur subversion.

Nebeans Menu d'import de nouveau sources dans Subversion Netbeans Dialogue d'import de sources dans subversion

L’url à renseignée est de la forme svn://<serveur>/<projet>/trunk et dans le cas de l’article cela donne svn://localhost/vroom/trunk

Dans la boite de dialogue suivante supprimer le dernier répertoire pour ne garder que <projet>/trunk

Le trunk final est important car cela respecte l’arborescence classique des projets sous Subversion. Le trunk est l’équivalent de la HEAD sous CVS.

Nous avons créé un projet maven 2 en utilisant un archétype. Le projet est disponible dans le référentiel de source Subversion. La prochaine étape va être la mise en place de l’intégration continue.

Un environnement de developpement Java

J’ai eu envie de faire un petit développement personnel en Java et comme j’avais réinstallé mon ordinateur, je devais refaire mon environnement depuis le début. Ce n’est d’ailleurs pas un si grand mal et l’exercice serait même intéressant car il arrive que nous devions le faire quand par exemple une défaillance de notre IDE survient comme un crash d’Eclipse réduisant à néant la configuration du workspace.

En partant d’une distribution classique Ubuntu 64 bit avec les dépôts officiels, peut-on monter un environnement de développement Java ? Est-il nécessaire d’installer des logiciels manuellement et donc maintenir par soi-même les mise-à-jour ? Est-ce que l’installation est accessible ou nécessite-t-elle une équipe système ? Pour réponde à ces questions il faut commencer par définir ce dont nous avons besoin.

Le système d’exploitation est un Linux abordable: Ubuntu. Nous supposons qu’il est déjà installé et fonctionnel. C’est une supposition très raisonnable. A partir de là il nous faut obtenir un environnement de développement Java complet comprenant :

  • un outils de modélisation
  • un éditeur de source
  • un compilateur
  • un outils de versionnage
  • un outils d’intégration continue

L’outil de modélisation sera bien pratique pour les phases préliminaires avant tout codage et devra permettre au moins la génération de code. L’opération inverse sera aussi utile car une fois emporté dans le code on risque bien d’oublier l’architecture générale et voire même la galvauder dans notre élan. Nous pouvons soit opter pour outils dédié  comme BOUML ou bien se contenter des fonctions UML de l’IDE. LEs 2 IDE open-source majeurs propose de l’UML.

L’IDE doit permettre d’écrire du code, d’apporter la coloration syntaxique, l’assistance à la frappe, le debogguage et le support de plusieurs JVM. L’IDE ne doit pas nous enfermé dans un système propriétaire de build et devra donc s’interfacer simplement avec notre outil de build préféré : Maven. Nous porterons notre choix sur Netbeans dont l’offre “packagée” estplus complète que Eclipse et mieux adapté que ce dernier pour une utilisation avec Maven.  La version 6.0 est installable directement depuis Ubuntu en utilisant Synaptic. Il faudra ajouter les plugins Subversion, Maven et UML pour completer l’installation de base. Cela ce fait directement depuis l’ID.

La partie compilateur dans le cas de java se compose du JDK  qui est l’ensemble des outils pour compiler et debugger des programmes écrit en Java. Le JDK contient aussi un JRE qui permet d’éxécuter les programmes Java. C’est le point de départ de notre environnement. Les dépots officiels d’Ubuntu propose OpenJDK 1.6 donc son installation se fera le plus simplement du monde via le gestionnaire de paquet Synaptic.

L’outils de versionnage devra permettre un refactoring constant du code et devra gérer le renommage les déplacements de fichiers sans perte d’historique sans avoir recours à l’administration du serveur. On choisira naturellement subversion dont l’installation est possible depuis les dépôt Ubuntu.

L’intégration continue est une pratique obligatoire dans les projets nécessitant plusieurs développeurs ou plusieurs module devant être assemblés. Cependant même dans le cas d’un seul développeur il aura besoin de découper le projet en modules qui devront être assemblés. Un outils permettant d’assurer le que l’ensemble “fonctionnent” correctement est nécessaire. Afin de simplifier l’intégration nous allons choisir Continuum qui se marie à merveille avec Maven. Son installation se fera manuellement en décompressant l’archive trouvé sur le site officiel de continuum

Enfin pour terminer la liste des outils nous mentionnerons l’outils de build maven qui est avec l’intégration continue les éléments le splus importants de l’environnement de developpement d’un point de vue structurel. Nous allons installer maven par le biais de Synaptic. Pour simplifier et offrir une évolutivité maximal dans l’utilisation de maven nous allons utiliser le gestionnaire de repository Apache Archiva

Maintenant que tout est installé, il faut s’assurer que tout fonctionne bien ensemble. Pour cela l’article suivant traitera de la création initiale du projet.