SubVersion/TP

From air
Revision as of 10:12, 8 March 2011 by Donsez (talk | contribs)
Jump to navigation Jump to search

Ce fichier de commande Windows illustre l'usage des principales commandes de SubVersion pour la gestion de révisions.

Il simule 1 administrateur et 2 éditeurs collaborant (avec des conflits) sur une base de code locale gérée par Subversion.


rem ===========================================================================
rem Tutoriel SubVersion
rem Ce fichier de commande Windows illustre l'usage des principales commandes de
rem SubVersion pour la gestion de révisions.
rem (c) Didier Donsez, 2007
rem ===========================================================================

rem Telecharger SubVersion pour Windows depuis http://subversion.tigris.org
rem Installer (Unzip %SVN_HOME%
rem set SVN_HOME=c:\devtools\svn-win32-1.4.4
rem puis set PATH=%PATH%;%SVN_HOME%\bin
rem Démarrer -> Exécuter -> Taper "cmd"

rem en parallele des commandes en ligne, vous pouvez utiliser le client Windows TortoiseSVN disponible gratuitement sur http://www.tortoisesvn.org/

rem Aide des principales commandes 
svn help
svnadmin help
svnlook help
svndumpfilter help
svnserve help

svn --version

cd c:\

rem Creation du dépôt
mkdir repository
svnadmin create repository
rem svnadmin create repository --fs-type fsfs
dir repository

rem Creation d'un projet hello a partir d'un archetype Maven (@see http://www.sonatype.com/book/archetypes.html#using)
mvn archetype:create -DgroupId=demo.svn -DartifactId=hello

rem Importation des fichier du projet hello dans le dépôt
svn import hello file:///c:/repository/hello --message "initial import"
svnlook youngest repository
svnlook tree repository

rem Création d'une copie de travail (checkout)
mkdir workingcopy1
svn checkout file:///c:/repository/hello workingcopy1

rem Ajout et Suppression de fichiers
echo This is a readme file > workingcopy1\LISEZMOI.txt
svn status workingcopy1\LISEZMOI.txt
svn add workingcopy1\LISEZMOI.txt
svn status workingcopy1\LISEZMOI.txt
svn commit workingcopy1\LISEZMOI.txt --message "add a readme file"

svn delete workingcopy1\LISEZMOI.txt
svn status workingcopy1\LISEZMOI.txt
svn commit workingcopy1\LISEZMOI.txt --message "delete a readme file"

rem Renommer un fichier dans la copie de travail
echo This is a readme file > workingcopy1\LISEZMOI.txt
svn commit workingcopy1 --message "add a readme file"

svn rename workingcopy1\LISEZMOI.txt workingcopy1\README.txt
svn status workingcopy1
svn commit workingcopy1 --message "add the readme file"

rem Modification d'un fichier dans la copie de travail
echo Contributors: >> workingcopy1\README.txt
type  workingcopy1\README.txt
rem par exemple, ajoutez votre nom des contributeurs dans le commentaire de la classe
svn status workingcopy1\README.txt --verbose

Partager les modifications (commit)
svn commit workingcopy1 --message "first modification"

rem Inspection des logs
svn log workingcopy1
svn update workingcopy1
svn log workingcopy1

rem Editions concurrences
svn update workingcopy1\README.txt
rem modifiez le nom de l'auteur
echo didier >> workingcopy1\README.txt
type  workingcopy1\README.txt
svn update workingcopy1\README.txt
rem modifiez le nom de l'auteur
echo donsez >> workingcopy2\README.txt

svn status workingcopy1
svn status workingcopy2

svn commit workingcopy1 --message "second modification"
svn commit workingcopy2 --message "second modification"


rem Traitement du conflit entre plusieurs rédacteurs par un "merge" manuellement
svn update workingcopy2
dir workingcopy2
svn status workingcopy2\README.txt --verbose
type workingcopy2\README.txt
rem edit workingcopy2\README.txt
echo This is a readme file > workingcopy2\README.txt
echo Contributor: didier donsez > workingcopy2\README.txt
del workingcopy2\README.txt.mine
del workingcopy2\README.txt.r*
svn resolved workingcopy2\README.txt
svn commit workingcopy2 --message "third modification"

rem Revenir en arrière
svn update workingcopy1
edit workingcopy1\src\test\java\demo\svn\AppTest.java
svn status workingcopy1\src\test\java\demo\svn\AppTest.java
svn diff workingcopy1\src\test\java\demo\svn\AppTest.java
svn revert workingcopy1\src\test\java\demo\svn\AppTest.java


rem Récupérer une ancienne révision
svn checkout workingcopy1 file:///c:/repository/hello@1

rem Création d'une autre copie de travail à partir de la révision 1
mkdir workingcopy3
svn checkout file:///c:/repository/hello workingcopy3 --revision 1

rem Checkout de l'autre copie de travail à partir de la dernière révision (HEAD)
svn checkout file:///c:/repository/hello workingcopy2 --revision HEAD
svn status workingcopy1


rem Ajout de propriétés
svn propset foo "bar" workingcopy1
svn propset tic "tac toe" workingcopy1
svn propedit foo workingcopy1
svn propedit svn:ignore workingcopy1
svn propdel tic workingcopy1

rem Edition d'un log
svn log workingcopy1 -r 1
svn propset svn:log 'initial import by Didier' -r1 --revprop file:///c:/repository/hello

echo initial import by Didier > log.r1.txt
svnadmin setlog c:\repository -r1 log.r1.txt --bypass-hooks
svn log workingcopy1 -r 1
del log.r1.txt

rem Ajout de svn:ignore
svn propedit svn:ignore workingcopy1
rem ajoutez target .project .classpath
svn propget svn:ignore workingcopy1
svn commit workingcopy1

cd workingcopy1
mvn clean install

rem Pose de verrou
svn lock workingcopy1\pom.xml -m "Editing file for tomorrow's release."
svn status workingcopy1
svn info workingcopy1\pom.xml

svn info file:///c:/repository/hello/pom.xml

rem Recherche et forcer les verrous
svnadmin lslocks c:\repository
svnadmin rmlocks c:\repository /hello/pom.xml
svn info file:///c:/repository/hello/pom.xml

rem Lock/Modify/Unlock (à la RCS)
svn lock workingcopy1\pom.xml -m "Editing file for tomorrow's release."
edit workingcopy1\pom.xml
svn unlock workingcopy1\pom.xml
svn commit workingcopy1
svn info file:///c:/repository/hello/pom.xml

rem Ajout de mots clé substituables (Keyword substitution)
echo $Id$ $HeadURL$ $Rev$ $Author$ $Date$ >> workingcopy1\README.txt
type workingcopy1\README.txt
rem Ajouter les appels aux mots clé  $Id$ $HeadURL$ $Rev$ $Author$ $Date$ dans les commentaires
svn propset svn:keywords "Id Rev HeadURL Date Author" workingcopy1\README.txt
svn commit workingcopy1
svn update workingcopy1
type workingcopy1\README.txt


rem Création du layout trunk/tags/branches
svn mkdir workingcopy1\trunk
svn mkdir workingcopy1\branches
svn mkdir workingcopy1\tags
svn move workingcopy1\src workingcopy1\trunk
svn move workingcopy1\target workingcopy1\trunk
svn move workingcopy1\pom.xml workingcopy1\trunk
svn commit workingcopy1

rem Création d'un tag 1.0 à partir de la revision HEAD
svn copy file:///c:/repository/hello/trunk file:///c:/repository/hello/tags/release-1.0 -m "Tagging the 1.0 release of the 'hello' project."
svn update workingcopy1

rem Création d'une branche java5 à partir de la revision HEAD
svn copy file:///c:/repository/hello/trunk file:///c:/repository/hello/branches/java5 -m "Branching the java5 implementation of the 'hello' project."
svn update workingcopy1
rem Modifiez le pom.xml selon http://java.developpez.com/faq/maven/?page=utilisation#compilation1
svn commit workingcopy1

rem switch

rem Inspection d'ancienne revision
svn cat workingcopy1\pom.xml -r 1
svn blame workingcopy1\pom.xml -r 1

rem Création de patch
svn diff workingcopy1 -r 1:2 > hello.r1-2.patch

rem Application d'un path
TODO sous Unix ou sous CygWin, la commande patch
TODO sous Windows, les commandes ExamDiff, KDiff3, WinMerge, Araxis compare

svn diff --diff-cmd /usr/bin/diff --extensions '-i' README.txt

rem Création d'un dump
svnadmin dump repository > repository.svndump

rem Création d'un nouveau dépot partiel (utilisant FSFS) à partir du dump
svndumpfilter include hello/trunk --drop-empty-revs --renumber-revs < repository.svndump > hello-trunk.svndump
svnadmin create hellorepo --fs-type fsfs
svnadmin load hellorepo < hello-trunk.svndump

rem Operations de maintenance
svnadmin crashtest repository
svnadmin recover repository


rem ========
rem svnserve
rem lire http://tortoisesvn.net/docs/release/TortoiseSVN_fr/tsvn-serversetup-svnserve.html
rem ========

rem Lancement svnserve comme un deamon
edit repository\conf\svnserve.conf
edit repository\conf\passwd
edit repository\conf\authz

svnserve --deamon --root repository
^C

rem Lancement de svnserve comme un service NT (http://tortoisesvn.net/docs/nightly/TortoiseSVN_fr/tsvn-serversetup-svnserve.html)
sc create svn binpath= "E:\devtools\svn-win32-1.4.4\bin\svnserve.exe --service --root G:\repository" displayname= "Subversion Server" depend= Tcpip start= auto
sc query svn

rem Création d'une autre copie de travail
mkdir workingcopy3
svn checkout svn://localhost/hello workingcopy3

rem Arrêt et Suppression du service NT svn
sc stop svn
sc delete svn


rem ========
rem svn via un tunnel SSH (svn+ssh)
rem ========
rem Download and install Putty.zip

set PATH=%PATH%;c:\putty
set PLINK_PROTOCOL=ssh
set SVN_SSH=plink.exe

svn checkout svn+ssh://username@svn.forge.objectweb.org/svnroot/ecom



rem =======================
rem Apache v2 + mod_dav-svn
rem =======================

TODO




rem Exporter un depot
svn copy file:///c:/repository/hello/trunk trunk.export




rem =======================
rem Statistiques
rem =======================

rem Telechargez et installez StatSVN http://wiki.statsvn.org/
rem Générez le rapport d'activité du projet

svn co svn://server/repo/trunk/modulename
svn log -v --xml > logfile.log
java -jar /path/to/statsvn.jar /path/to/module/logfile.log /path/to/module