IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

Subversion

Cet article traite de l'installation et de l'utilisation de Subversion sous Windows. Il abordera son utilisation en protocole HTTP et montrera une façon simple et rapide de créer son serveur de version.

Article lu   fois.

L'auteur

Profil ProSite personnel

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

I. Introduction

Remerciements

Je tiens à remercier sjrd pour la correction de cet article, Ricky81, elitost et Gnux pour leurs conseils. Mes remerciements vont également droit vers les membres de Developpez.com qui œuvrent pour un processus de publication d'une qualité remarquable.

I-A. Prérequis

Le lecteur, dans l'idéal, a déjà installé les outils nécessaires à ce tutoriel. Cependant, cet article reste à la portée de tout le monde si on ne s'attache pas à comprendre certaines parties (comme le paramétrage Apache).

I-B. Pourquoi cet article ?

Subversion est de plus en plus utilisé, mais les documentations qui s'y rapportent sont hétéroclites ou ne contiennent pas toujours toutes les informations nécessaires à son bon fonctionnement. Ici nous aborderons son utilisation dans un environnement Windows. Le lecteur pourra ainsi installer et utiliser une interface graphique et un serveur web en quelques clics.

I-C. Qu'est-ce que Subversion ?

I-C-1. Généralités

Subversion est un outil de gestion de documents. Il se veut comme successeur logique de CVS et nous provient du monde de l'open source. Vous pourrez consulter à cette adresse le site du projet Subversion.

I-C-2. Spécificités

Cet outil reprend toutes les fonctionnalités de CVS, à savoir :

  • la consultation et la possibilité de restauration des anciennes versions d'un fichier ;
  • les raisons des modifications apportées et les auteurs de celles-ci ;
  • les modifications de versions sont stockées sous forme de delta (différence entre deux versions) pour les fichiers textes. Ce qui implique qu'une propagation est proportionnelle aux modifications apportées et non à la taille des données initiales.

Les avantages rajoutés par Subversion sont entre autres (cf. page d'accueil du site ci-dessus) ceux-ci :

  • Subversion permet de tracer les versions de répertoires, de fichiers et de droits sur les fichiers ;
  • Subversion permet de renommer un fichier ou un répertoire tout en conservant son historique ;
  • les propagations de version (commit) sont atomiques. Une propagation réussit uniquement si tous les fichiers de la version sont correctement propagés ;
  • les numéros de versions concernent une propagation et non les fichiers eux-mêmes ;
  • Subversion peut se coupler avec le protocole HTTP Webdav/deltaV ;
  • les sauvegardes par delta sont aussi possibles sur les fichiers binaires.

Voici quelques points de vocabulaire pour la suite de cet article :

  • repository/répertoire de dépôt : ce répertoire contiendra tout votre référentiel de versionnage. C'est une base de données et un ensemble de fichiers de configuration ;
  • working area/copie de travail : Une copie de travail est une image complète ou partielle du répertoire de dépôt. Une copie de travail peut se synchroniser avec le répertoire de dépôt suivant des mécanismes que nous verrons plus bas.

II. Installation

II-A. Outils nécessaires

Dans cet article, nous traiterons d'une installation sur un système Windows. Nous allons donc utiliser un ensemble de logiciels, tous issus du monde libre, afin de nous permettre de créer un serveur de configuration très rapidement. Téléchargez les logiciels suivants :

  • Apache 2 : serveur web. Ce logiciel ne sera pas nécessaire sur les postes clients ;
  • Subversion : gestionnaire de version. Ce logiciel ne sera pas nécessaire sur les postes clients ;
  • TortoiseSvn : interface graphique pour subversion.

Si vous travaillez sur des sites Internet ou Intranet en PHP, n'hésitez pas à utiliser Wamp contenant apache2, mysql5, php5.

II-B. Mode opératoire et configuration

Pour tous les logiciels cités plus haut, contentez-vous de suivre les écrans d'installation de leur installateur respectif.
Une fois vos logiciels installés, nous allons maintenant les configurer pour les faire fonctionner ensemble.
La première étape consiste à créer son répertoire de dépôt. Nous allons pour cela utiliser l'interface graphique de TortoiseSvn.
Si votre installation s'est bien passée, vous devriez avoir des options supplémentaires dans le menu contextuel de l'explorateur Windows.

menu contextuel
menu contextuel

Attention, si vous utilisez une plateforme 64 bits, le menu contextuel ne sera pas modifié dans l'explorateur Windows. Cependant, vous pourrez utiliser l'explorateur d’Internet Explorer qui est resté compatible 32 bits.

Choisissez donc un répertoire, par exemple d:\svn et utilisez l'option : « Create repository here ». Ici vous aurez la possibilité de choisir deux types de bases de données pour stocker vos versions :

  • Berkeley DB ;
  • FSFS (native file system).

Traditionnellement, on conseille d'utiliser FSFS qui est développé par Subversion. Cependant les deux possèdent des avantages et inconvénients. Vous pourrez trouver des informations sur les deux bases de données ici.

Vous avez donc maintenant un répertoire de dépôt pleinement opérationnel. Nous allons le rendre accessible par HTTP. Vous pouvez déjà l'explorer à partir du repo-browser en mode file.
Dans le répertoire bin/ d'installation de subversion, vous devez trouver les fichiers suivants : mod_authz_svn.so et mod_dav_svn.so. Copiez-les dans le répertoire Apache2\modules de Apache.
Ouvrez maintenant le fichier Apache2\conf\httpd.conf. Vous allez activer les modules qui permettront à Subversion d'utiliser le protocole http et l'authentification.

 
Sélectionnez
# Décommentez la ligne : LoadModule dav_module modules/mod_dav.so
LoadModule dav_module modules/mod_dav.so
# et ajoutez les lignes suivantes en dessous :
LoadModule dav_svn_module modules/mod_dav_svn.so
LoadModule authz_svn_module modules/mod_authz_svn.so

Les modules sont activés, mais nous allons maintenant rajouter un emplacement pour accéder à votre dépôt :

 
Sélectionnez
# nom du répertoire. L'accès se fera par http://localhost/svnrepository
<Location /svnrepository>
  DAV svn
# répertoire de dépôt
  SVNPath d:/svn
  SVNIndexXSLT "/svnindex.xsl"
  SVNAutoversioning on
 
# Indique comment authentifier les utilisateurs
   AuthType Basic
   AuthName "Référentiel Subversion"
# fichiers des utilisateurs
   AuthUserFile d:\svn\conf\utilisateurs.txt
   Require valid-user  
# fichiers des permissions   
   AuthzSVNAccessFile e:\GDASvn\conf\authz
   ErrorDocument 404 default
</Location>

Afin d'explorer le répertoire de dépôt à partir d'un navigateur web, nous avons ajouté la directive SVNIndexXSLT "/svnindex.xsl" qui permet de définir une feuille de style pour l'affichage. La feuille de style de base se trouve sur le site de subversion. Les fichiers svnindex.xsl et svnindex.css doivent être déposés dans le répertoire racine des documents Apache. (Le répertoire www si vous préférez).

Désormais il ne reste plus qu'à gérer les permissions et les utilisateurs. Les fichiers qui les définissent sont dans votre répertoire de dépôt sous le répertoire conf. Nous allons d'abord nous intéresser au fichier des permissions : authz.

 
Sélectionnez
# Ce fichier a le gros avantage d'être documenté et surtout, bien documenté. 
# Voici un exemple de fichier qui définit deux groupes, des développeurs, des traducteurs.
# Le répertoire svn contient 
# - un répertoire html qui est accessible aux traducteurs
# - des répertoires src/ accessible aux développeurs
# - un répertoire changelog accessible à tous
 
### This file is an example authorization file for svnserve.
### Its format is identical to that of mod_authz_svn authorization
### files.
### As shown below each section defines authorizations for the path and
### (optional) repository specified by the section name.
### The authorizations follow. An authorization line can refer to a
### single user, to a group of users defined in a special [groups]
### section, or to anyone using the '*' wildcard.  Each definition can
### grant read ('r') access, read-write ('rw') access, or no access
### ('').
 
[groups]
dev = user1,user2,user3
trad = user4,user5
 
[svnrepository:/]
@dev = rw
* =
 
[svnrepository:/html]
@trad = rw
@dev = rw
* = 
 
[svnrepository:/src]
@trad = 
@dev = rw
* = 
 
[svnrepository:/changelog]
@dev = rw
* = r

Vos permissions sont définies, mais votre application ne connaît pour l'instant aucun utilisateur. Ceux-ci doivent être définis dans le fichier utilisateurs.txt. Ce fichier est géré par htpasswd, utilitaire fourni avec Apache dans son répertoire bin.

N'hésitez pas à ajouter le répertoire Apache2/bin dans le PATH (variable d'environnement Windows), cela vous évitera de taper le chemin complet de l'utilitaire à chaque fois.

Pour créer votre fichier utilisateurs.txt avec votre premier utilisateur :
htpasswd -bc utilisateurs.txt user1 passwordUser1
Pour rajouter un utilisateur :
htpasswd -bm utilisateurs.txt user2 passwordUser2

Voilà, votre serveur est désormais configuré et vous pouvez y accéder par votre repo-browser à partir de l'adresse : http://votreadresse/svnrepository

III. Utilisation

Les personnes désirant utiliser le serveur que vous venez de créer devront tout d'abord installer TortoiseSvn. Subversion et Apache2 ne sont pas nécessaires sur le poste client.

III-A. Créer son espace de travail

Afin de créer sa copie de travail, les utilisateurs doivent créer un répertoire vide. Puis, dans le menu contextuel svn, ils doivent sélectionner checkout.

checkout
checkout

Une fenêtre s'ouvre alors. Vous devez donner l'URL du répertoire de dépôt et le nom du répertoire de destination (qui doit être vide). Les autres cases peuvent être laissées par défaut. Vous remarquerez notamment qu'il vous est possible de faire un checkout d'une version précise. Par défaut vous prendrez la version HEAD, qui est la dernière.

checkout
checkout

Une fois cette opération effectuée, une fenêtre s'ouvre et vous liste tous les fichiers créés sur votre copie de travail. Vous obtenez aussi le numéro de la révision actuelle.
(Note : l'exemple est une fenêtre d'update vide, car aucune mise à jour n'a été récupérée. La fenêtre est cependant identique.)

checkout
checkout

Une opération essentielle à connaître pour maintenir votre copie de travail est la relocalisation. En effet, si le serveur change d'adresse, vous aurez besoin de relocaliser votre copie de travail. L'option relocate se trouve dans le menu contextuel :

relocalisation
relocalisation

Une fenêtre s'ouvre alors afin de vous demander la nouvelle adresse. Comme vous le voyez sur l'exemple, vous pouvez ne relocaliser qu'un répertoire en particulier.

relocalisation
relocalisation

III-B. Icône de la copie de travail

TortoiseSvn vous a ajouté des options dans le menu contextuel de l'explorateur, mais il a aussi ajouté la gestion des icônes reflétant l'état des fichiers.

icones
icônes
  • Ajout : ces fichiers vont être ajoutés au référentiel Subversion.
  • Delete : ces fichiers vont être supprimés du référentiel.
  • Conflit : ces fichiers de votre copie de travail sont en conflit avec les versions du répertoire de dépôt.
  • Dans Subversion : ces fichiers sont sous contrôle de version.
  • Locké : ces fichiers sont verrouillés.
  • Modifié : ces fichiers ont été modifiés sur votre copie de travail.
  • Lecture seule : ces fichiers ne peuvent être modifiés.

Ces icônes sont cependant modifiables, celles-ci correspondent au style par défaut (XP classic).

III-C. Mettre à jour sa copie de travail

Nous allons maintenant mettre à jour notre version de travail. Cette mise à jour se fait avec l'option « update » du menu contextuel. La fenêtre qui va s'ouvrir alors va nous fournir un ensemble d'informations. Nous allons ainsi connaître le détail de la mise à jour fichier par fichier, le type de mise à jour (ajout, suppression, modification) et les éventuels conflits avec notre version locale. Subversion est capable de gérer pour vous la fusion de documents lorsque les différences entre la version locale et la version distante ne portent pas sur les mêmes lignes.

mise à jour
mise à jour

Les dernières informations de cette fenêtre vous donnent un bilan de la mise à jour, l'état de la mise à jour et le numéro de version du référentiel récupéré. Dans notre exemple, notre mise à jour a entraîné un conflit sur au moins un fichier.

conflit
conflit

L'une des options intéressantes de cette fenêtre est le bouton « show log ». Cette fonctionnalité est aussi accessible par le menu contextuel. Elle permet de retrouver toutes les modifications d'un fichier ou d'une arborescence, les dates de modifications et les auteurs. Une version étant une propagation d'un ensemble de fichiers, nous sommes en mesure de voir tous les fichiers qui ont été modifiés en même temps que celui que nous observons et un commentaire de la personne qui a propagé cette modification.

versions
versions

Sur les deux écrans que nous venons d'étudier, nous avons la possibilité de cliquer sur le nom des fichiers et de visualiser les différences entre la version précédente et la version pointée. TortoiseSvn va alors ouvrir un visualiseur fourni avec l'interface. Ce visualiseur nous fournit des informations sur les différences de façon intuitive à partir d'un code couleur.

diff
diff

III-D. Propager ses modifications

Nous avons vu comment recevoir le fruit du travail des autres, voilà maintenant comment propager le nôtre. En pratique il existe deux méthodes, la propagation directe et la propagation par soumission de patch. Sur certains projets, typiquement les projets open source, le référentiel est ouvert en lecture à tout le monde, mais seuls les développeurs ont accès en écriture. Les développeurs sont donc les seuls à pouvoir propager directement. Mais les personnes voulant contribuer de façon occasionnelle peuvent modifier leur copie de travail et créer leur patch pour l'envoyer à l'équipe de développement. Celle-ci se chargera d'appliquer le patch si nécessaire.
Voyons tout d'abord la méthode directe. Faites un clic droit sur un fichier que vous avez modifié. Ce fichier doit avoir une icône rouge comme vu plus haut. Sélectionnez : « commit ». Une fenêtre apparaît. Ici vous devez saisir un texte décrivant la version que vous envoyez sur le référentiel. L'écran du bas liste les fichiers concernés par la propagation. Il vous est encore possible de ne pas propager certains fichiers en les décochant.

mise à jour
mise à jour

Pour la propagation par patch, l'opération est sensiblement la même. Dans le menu contextuel vous choisissez « create patch ». Une fenêtre s'ouvre dans laquelle vous choisissez les fichiers. Vous avez alors la possibilité de créer un fichier .patch ou .diff. Ce fichier est exploitable par les développeurs qui pourront l'appliquer à leur copie de travail.
Ce fichier diff ou patch adopte un format qui se rapproche d'un diff unique. En voici un exemple :

 
Sélectionnez
Index: E:/workEclipse/L2jfree_GameServer_c4/java/net/sf/l2j/gameserver/model/L2Character.java
===================================================================
--- E:/workEclipse/L2jfree_GameServer_c4/java/net/sf/l2j/gameserver/model/L2Character.java    (révision 285)
+++ E:/workEclipse/L2jfree_GameServer_c4/java/net/sf/l2j/gameserver/model/L2Character.java    (copie de travail)
@@ -48,6 +48,7 @@
 import net.sf.l2j.gameserver.model.L2Skill.SkillType;
 import net.sf.l2j.gameserver.model.actor.appearance.CharAppearance;
 import net.sf.l2j.gameserver.model.actor.instance.L2ArtefactInstance;
+import net.sf.l2j.gameserver.model.actor.instance.L2SummonInstance;
 import net.sf.l2j.gameserver.model.actor.instance.L2BoatInstance;
 import net.sf.l2j.gameserver.model.actor.instance.L2DoorInstance;
 import net.sf.l2j.gameserver.model.actor.instance.L2MonsterInstance;
@@ -3618,6 +3619,16 @@
                }
            }
 
+           else if(this instanceof L2SummonInstance)
+           {
+               ((L2SummonInstance)this).displayHitMessage(damage,crit,miss);
+           }
+           else if(this instanceof L2PetInstance)
+           {
+              ((L2PetInstance)this).displayHitMessage(damage,crit,miss);
+           }        
+           
+
            // If L2Character target is a L2PcInstance, send a system message
            if (target instanceof L2PcInstance)
            {

Conclusion

Voici quelques liens qui pourront vous être utiles pour trouver les outils cités dans cet article.

  • Apache : serveur web. Si vous travaillez sur des sites Web, n'hésitez pas à utiliser Wamp contenant apache2, mysql5, php5.
  • Subversion : gestionnaire de versions. Ce logiciel ne sera pas nécessaire sur les postes clients.
  • TortoiseSvn : interface graphique pour Subversion.

Et voici quelques articles Développez.com qui traitent de gestion de versions.

Cet article ne se veut pas exhaustif sur la question. Il a un but didactique afin de répondre à des besoins simples et traite essentiellement de points que j'utilise moi-même régulièrement. Toutefois, si vous désirez l'enrichir de vos remarques, vous pouvez me contacter par MP forum.

De multiples captures d'écran de cet article ont été faites à partir d'un dépôt ouvert à tous d'un projet open source. Ils ont permis de fournir un éventail d'écrans représentatifs.

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+   

Copyright © 2020 hugo123. Aucune reproduction, même partielle, ne peut être faite de ce site ni de l'ensemble de son contenu : textes, documents, images, etc. sans l'autorisation expresse de l'auteur. Sinon vous encourez selon la loi jusqu'à trois ans de prison et jusqu'à 300 000 € de dommages et intérêts.