Se préparer à développer un produit Archetypes
Retrouvez ici la marche à suivre pour installer les outils nécessaires au développement d'un produit Plone (3 ou 4)
La création d'un produit Plone basé sur Archetypes suit généralement ces différentes étapes :
- Création d'un modèle UML contenant les classes détaillées (diagramme de classe) ainsi que les workflows (diagramme d'états-transitions)
- Génération d'un squelette de produit à partir du modèle UML (la modification du modèle et la regénération est possible à tout moment, sans perte des éléments rajoutés manuellement)
- Ajout dans le produit de modifications manuelles : contenu des méthodes, redéfinition de templates, écriture de tests...
Installation d'ArgoUML (outil de modélisation UML)
L'outil recommandé est ArgoUML car ce dernier est utilisé par la communauté de développeurs ArchGenXML, en outre il s'agit évidemment d'un outil libre et très facile à installer...
- récupérer la dernière version d'ArgoUML (0.30.2 au 10/2010) sur http://argouml.tigris.org/
- comme il s'agit d'un outil de modélisation développé en Java, l'installation de JRE est nécessaire
- pour lancer ArgoUML il suffit d'utiliser les fichiers de commandes argouml.bat (Windows) ou argouml.sh (Linux)
Il est intéressant d'utiliser ArgoUML avec un profil adapté à Plone. Ce profil nommé "argouml_profile.xmi" se trouve sur le svn dans le produit ArchGenXML (voir point plus bas "Configuration d'ArgoUML pour utiliser le profil d'ArchGenXML (archgenxml_profile.xml)").
Installation d'ArchGenXML2 (générateur de code)
Installation de Python
La meilleure chose est de créer un python propre (via virtualenv) pour y installer ArchGenXML2. Ce package dépend en effet de différents packages zope et une installation à part permettra d'éviter tout problème de compatibilité de packages par la suite. Suivez les points 6, 6.1 et 6.2 présents ici : www.communesplone.org/support/documentation/manual/installation-dun-serveur-de-production/installation-de-python-2.4
Création d'un virtualenv pour ArchGenXML
En utilisant le python fraichement installé :
/srv/python246/bin/virtualenv --no-site-packages /srv/archgenxml/agx2
Installation d'ArchGenXML2
easy_install installera archgenxml pour nous...
/srv/archgenxml/agx2/bin/python /srv/install/ez_setup.py
/srv/archgenxml/agx2/bin/easy_install archgenxml
ou
/srv/archgenxml/agx2/bin/easy_install "archgenxml==2.4.1" pour une version précise
Configuration d'ArgoUML pour utiliser le profil d'ArchGenXML (archgenxml_profile.xml)
Dans Edition-->Préférences-->Profiles, cliquez sur le bouton "Add" et recherchez le chemin (juste le chemin et pas le fichier) vers l'endroit où vous avez récupéré le fichier archgenxml_profile.xml. Par exemple dans /srv/archgenxml. Coupez ArgoUML et redémarrez le. A nouveau dans Edition-->Préférences-->Profiles, sélectionnez maintenant AGXProfile dans la colonne de gauche et faites le glisser à droite grâce au bouton ">>". Retirez le profil "UML 1.4" qui n'est plus utile. Lors de la création d'un projet, allez sur l'icône "Propriétés" (4 ème icône en haut à gauche) et sélectionnez uniquement le profil
Mise en place de la structure du produit
Au sein d'une instance Zope-2.10.x avec un Plone 3.x
Génération d'un produit AVEC structure d'egg
- dans le dossier /src de l'instance, exécuter paster pour créer la structure en egg du produit (par exemple Products.myproduct)
PATH_TO_PASTER/paster create -t basic_namespace Products.myproduct
- créer dans le sous dossier Products.myproduct/Products/myproduct un dossier /model qui contiendra le modèle UML
- ajouter un fichier generate.conf dans le dossier /model qui contiendra les paramètres de configuration nécessaires à ArchGenXML (voir un exemple sur http://svn.communesplone.org/svn/communesplone/CPClassifiedAd/trunk/model/generate.conf)
- ajouter un fichier generate.sh qui contiendra la ligne de commande appelant ArchGenXML (plus simple que d'écrire la ligne de commande lors de chaque génération) :
PATH_TO_ARCHGENXML --cfg generate.conf CPClassifiedAd.zargo -o ..
Génération d'un produit SANS structure d'egg
- dans le dossier /products de l'instance, ajouter un dossier avec le nom du produit à créer (par exemple "MyProduct")
- créer un dossier /model dans le dossier du produit dans lequel le modèle UML sera stocké
- ajouter un fichier generate.conf dans le dossier /model qui contiendra les paramètres de configuration nécessaires à ArchGenXML (voir un exemple sur http://svn.communesplone.org/svn/communesplone/CPClassifiedAd/trunk/model/generate.conf)
- ajouter un fichier generate.sh qui contiendra la ligne de commande appelant ArchGenXML (plus simple que d'écrire la ligne de commande lors de chaque génération) :
PATH_TO_ARCHGENXML --cfg generate.conf CPClassifiedAd.zargo -o ..
Génération du produit Archetypes
Dans le dossier du produit :
- sauvegarder le modèle UML dans le dossier /model du produit
- exécuter le fichier generate.sh en tapant "./generate.sh"
- le produit est alors généré et ArchGenXML nous affiche le déroulement dans un log à l'écran et nous prévient s'il y a eu un problème
Conclusion
Lorsque le produit est généré il peut déjà être testé dans l'interface de Plone. ArchGenXML est un générateur de squelette de produit Archetypes. Les profils, workflows et schemas seront générés entièrement depuis le modèle tandis que le corps des méthodes, les vues et autre fonctionnalités propres devront être complétées manuellement.
Pour plus d'informations, consultez le manuel du développeur présent sur le site plone.org à l'adresse : plone.org/documentation/manual/developer-manual
Précédent : Installer sur sa machine un environnement de développement

