Cours Git

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 77

Introduction à la gestion de versions avec Git

Thibault Cholez
[email protected]

TELECOM Nancy, première année

28/09/17
Introduction aux SCM Git SCM et intégration continue Biblio

Outline

1 Introduction aux SCM

2 Git
Architecture
Commandes de base
Outils et pratique au quotidien

3 SCM et intégration continue

28/09/17 Introduction à la gestion de versions avec Git 2 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Outline

1 Introduction aux SCM

2 Git
Architecture
Commandes de base
Outils et pratique au quotidien

3 SCM et intégration continue

28/09/17 Introduction à la gestion de versions avec Git 3 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Définition

Définition

Système permettant le suivi (dans le temps) des différentes


modifications apportées à un ensemble de fichiers observés.
Précision : indifférent au langage utilisé et ne se limite pas au
code (fichiers de configuration, sources LaTeX, etc.).

Plusieurs accronymes

SCM : Source Code Management


VCS : Version Control System
RCS : Revision Control System

28/09/17 Introduction à la gestion de versions avec Git 4 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Pourquoi les SCM ?

Problème
Maı̂triser de code produit durant un développement logiciel
implique de savoir ce qui a été fait :
Par l’ensemble des développeurs (Qui ? )
Dans le temps (Quand ? )
Pour quel motif/fonctionnalité (Pourquoi ? )
Impliquant de nombreuses fonctions, dans de nombreux
fichiers (Où ? Comment ? )
→ Leur utilité ne se limite pas au travail à plusieurs.

28/09/17 Introduction à la gestion de versions avec Git 5 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Pourquoi les SCM ?

Utilité

Permettre la traçabilité d’un développement (historique des


changements)
Faciliter la collaboration, éviter les conflits ou aider à la leur
résolution
Garder une version du code source toujours fonctionnelle, tout
en travaillant sur plusieurs fonctionnalités (notion de branche)
Permettre des schémas organisationnels structurant les
développements (workflows)

28/09/17 Introduction à la gestion de versions avec Git 6 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Historique

Principaux SCM

cp -old (vieille blague, mais toujours utilisé)


CVS (1990) : centralisé, travaille sur des fichiers, limité
SVN (2000) : centralisé, travaille sur des fichiers, workflows
limités
Git (2005) : décentralisé, travaille sur des arborescences de
contenus
... et beaucoup d’autres, libres (Mercurial, Bazaar) ou
propriétaires (Microsoft, HP, IBM)
→ Quelque soit le SCM utilisé, il est important d’en utiliser un et
de maı̂triser les opérations de base.

28/09/17 Introduction à la gestion de versions avec Git 7 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Git

28/09/17 Introduction à la gestion de versions avec Git 8 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Un peu de vocabulaire
Principaux termes

Repository ou dépôt : répertoire versionné (peut être local ou


distant)
Commit : Enregistrement des dernières modifications dans le
dépôt
Version ou revision : état du code source arrêté par un commit
Branche : version alternative du code source liée à une
tentative de développement spécifique
Head : version la plus récente d’une branche (dernier commit)
Trunk ou tronc ou master : branche principale du code source
Merge : tentative d’unification de deux branches
Conflit : problème de merge nécessitant une prise de décision

28/09/17 Introduction à la gestion de versions avec Git 9 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Git
Pourquoi étudier Git ?

Créé par Linus Torwarld pour gérer les sources du noyau Linux
Très souple et puissant mais complexe et peu intuitif →
apprentissage ardu
SCM le plus utilisé actuellement, libre (GPL), communauté
très active
Devient un standard (l’est déjà dans le monde du libre)
SVN est trivial en comparaison

28/09/17 Introduction à la gestion de versions avec Git 10 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Git

Avantages par rapport à SVN

Pas de serveur central (élément critique)


Utilisable même si déconnecté
Organisation du travail plus souple

28/09/17 Introduction à la gestion de versions avec Git 11 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Git

Figure : Gestionnaire de version centralisé vs décentralisé [1]

28/09/17 Introduction à la gestion de versions avec Git 12 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Git

Figure : Gestionnaire de version centralisé vs décentralisé [1]


28/09/17 Introduction à la gestion de versions avec Git 12 / 71
Introduction aux SCM Git SCM et intégration continue Biblio

Git

Objectifs

A court terme (module GP/Prépa Info) : comprendre le


fonctionnement de git et maı̂triser les commandes de base
A moyen terme (diplôme) :
utiliser git dans tous vos projets à l’école (nouveau serveur
GitLab)
maı̂triser les commandes avancées
Vous AUREZ à utiliser un SCM tôt ou tard → profitez de votre
scolarité pour (faire des erreurs et) monter en compétence !

28/09/17 Introduction à la gestion de versions avec Git 13 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Git

Figure : xkcd 1597 : Git

28/09/17 Introduction à la gestion de versions avec Git 14 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Outline

1 Introduction aux SCM

2 Git
Architecture
Commandes de base
Outils et pratique au quotidien

3 SCM et intégration continue

28/09/17 Introduction à la gestion de versions avec Git 15 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Outline

1 Introduction aux SCM

2 Git
Architecture
Commandes de base
Outils et pratique au quotidien

3 SCM et intégration continue

28/09/17 Introduction à la gestion de versions avec Git 16 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

SCM décentralisé

Principes fondateurs

Chaque client git exécute son propre dépôt en local


Chaque utilisateur d’un dépôt partagé possède une copie de
tout l’historique des changements enregistrés (full mirroring)
Abandon d’une vision chronologique des changements (pas
d’ordre strict entre les commits) pour une vision structurelle
(graphe de commits)
But : faciliter les développements parallèles, permettre au
code de diverger/converger rapidement

28/09/17 Introduction à la gestion de versions avec Git 17 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Zones de stockage dans git


Découpage interne en trois zones

le répertoire de travail (working directory) local où sont


réalisés les changements
la ”staging area” (aussi appelé index) où sont pré-enregistrés
les changements (en attente de commit)
le dépôt git où sont enregistrés les changements

28/09/17 Introduction à la gestion de versions avec Git 18 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Staging area
Index intermédiaire

Sert à préparer les commits progressivement


git commit enregistre les modifications indexées
La staging area peut être bypassée : git commit -a

Figure : Différents états d’un fichier dans git [1]


28/09/17 Introduction à la gestion de versions avec Git 19 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Organisation des informations

Stockage par snapshots

CVS, SVN ne stockent que les deltas des fichiers modifiés par
un commit
Git stocke tout le contenu des fichiers modifiés par un commit
(mais utilise une compression intelligente basée sur la version
antérieure la plus proche)
Permet une grande souplesse

28/09/17 Introduction à la gestion de versions avec Git 20 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Stockage par snapshots

Figure : Delta vs Snapshot storage [1]

28/09/17 Introduction à la gestion de versions avec Git 21 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Stockage par snapshots

Figure : Delta vs Snapshot storage [1]

28/09/17 Introduction à la gestion de versions avec Git 21 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Organisation des informations


Types de données Git

Blob : contenu d’une version d’un fichier (Binary Large


Object)
Tree (structure récursive) : arborescence de références vers
d’autres Trees et Blobs
Commit (structure récursive) : pointe sur un Tree, sur le
Commit parent et contient des metadonnées (date, auteur,
etc.)
Tag : annotation manuelle d’un commit et créant une branche
statique
Identifiant unique pour tout objet : hash SHA1 (Secure Hash
Algorithm). Peut être tronqué si non ambigu.

28/09/17 Introduction à la gestion de versions avec Git 22 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Organisation des informations

Figure : Data structure d’un commit [1]

28/09/17 Introduction à la gestion de versions avec Git 23 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Organisation des informations

Figure : Data structure d’un commit [1]


28/09/17 Introduction à la gestion de versions avec Git 23 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Organisation des informations

Emplacement du dépôt local


Les données propres à git sont stockées dans un unique répertoire
.git à la racine du projet. C’est le dépôt local.

Références
L’historique du projet est un graphe de commit. Certaines
références sur ce graphe sont utiles :
master : référence la branche principale
HEAD : par défaut, référence le commit le plus récent de la
branche courante (sera le parent du prochain commit)
HEAD-2 : deux commits avant la HEAD

28/09/17 Introduction à la gestion de versions avec Git 24 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Références sur l’arbre des commits

Figure : Références sur l’arbre des commits [1]

28/09/17 Introduction à la gestion de versions avec Git 25 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Bonnes pratiques

Ne pas versionner de fichiers générés automatiquement


(logs, pdf, exécutables, etc.) ou personnels
Faire de petits commits réguliers et facile à intégrer, leur
donner un nom explicite
Utiliser les branches pour :
les développements à plusieurs
chaque développement conséquent d’une nouvelle
fonctionnalité
Ne pas développer sur la branche master à plusieurs pour
éviter les conflits lors des pull
Faire de petits commits locaux, et pusher des commits plus
conséquents, toujours testés et fonctionnels !
Faire des pull régulièrement

28/09/17 Introduction à la gestion de versions avec Git 26 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Comment Git fusionne-t-il les versions ?


Principes

Structure des données git : DAG (Directed Acyclic Graph) de


commits
Comparaison réalisée grâce à diff3 : utilitaire a pour comparer
3 fichiers
Fusion réalisée par l’algorithme three-way merge

3-way merge

Pour fusionner A&B : A&B=A+B-C, C étant l’ancêtre


commun le plus récent à A et B
Revient à appliquer A-C à B et B-C à A
Fait intervenir le longest common subsequence problem
28/09/17 Introduction à la gestion de versions avec Git 27 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Comment Git fusionne-t-il les versions ?

Application du 3-way merge

Supposons A aligné avec C et B aligné avec C (application du


LCS)
On retient pour le merge tout contenu :
commun aux 3
présent dans A mais absent dans B et C
présent dans B mais absent dans A et C
présent dans A et B mais absent dans C
On supprime pour le merge tout contenu :
présent dans A et C mais absent dans B
présent dans B et C mais absent dans A
présent dans C mais absent dans A et B

28/09/17 Introduction à la gestion de versions avec Git 28 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Exemple de 3-way merge

A: C: B: -> merged:
milk milk milk milk
juice juice
flour flour flour flour
sausage sausage
eggs eggs eggs eggs
butter butter

28/09/17 Introduction à la gestion de versions avec Git 29 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Visualisation des conflits


Quand un même bloc de C est modifié différemment par A et B.
Git présente par exemple :
<<<<<<< A
I had one egg and three sausages for breakfast.
=======
I had two eggs and two sausages for breakfast.
>>>>>>> B
Marqueurs de conflits

<<<<<<< : Indique les début des lignes en conflit (version


locale)
======= : Sépare la version locale (au dessus) de l’autre
version (en dessous)
>>>>>>> : Indique la fin de l’autre version en conflit.
28/09/17 Introduction à la gestion de versions avec Git 30 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Architecture

Visualisation des conflits

Possibilité de visualiser la version antérieure :

<<<<<<< A
I had one egg and three sausages for breakfast.
||||||| C
I had one egg and two sausages for breakfast.
=======
I had two eggs and two sausages for breakfast.
>>>>>>> B

Marqueurs de conflits

||||||| : Indique la version de l’ancêtre commun

28/09/17 Introduction à la gestion de versions avec Git 31 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Outline

1 Introduction aux SCM

2 Git
Architecture
Commandes de base
Outils et pratique au quotidien

3 SCM et intégration continue

28/09/17 Introduction à la gestion de versions avec Git 32 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Configuration et aide
Aide

Manuel d’utilisation : man git


Aide générale : git help
Aide d’une commande : git help commande

Configuration globale

Configuration commune à tous les dépôts d’un utilisateur, voir


le fichier $HOME/.gitconfig
git config –global user.name ”Thibault Cholez”
git config –global user.email [email protected]
git config –global color.ui true

28/09/17 Introduction à la gestion de versions avec Git 33 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Premières commandes
Initialisation du dépôt

Versionner un répertoire courant : git init (créer un dépôt en


générant le répertoire .git à la racine)
Télécharger un dépôt existant : git clone url

Enregistrement des modifications

Ajouter un fichier à suivre pour le prochain commit :


git add fichier
Enregistrer les modifications dans le dépôt local :
git commit fichier
ou git commit -m ”Description du commit”
ou git commit -a (pour all, commit tous les fichiers modifiés
sans passer par la staging area)
28/09/17 Introduction à la gestion de versions avec Git 34 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Partage des versions


Propagation et récupération
Un dépôt distant est toujours accessible et permet de partager les
commits entre développeurs (ex : GitHub).
Si besoin, lier un dépôt local avec un dépôt distant :
git remote add nom serveur adresse depot
Envoyer les derniers enregistrements vers le dépôt distant :
git push (nom serveur
nom branche locale :nom branche distante)
Récupérer et intégrer les derniers enregistrements :
git pull (nom serveur nom branche distante)
Le nom par défaut d’un serveur est origin.
Récupérer les derniers enregistrements sans les intégrer :
git fetch nom serveur nom branche distante
28/09/17 Introduction à la gestion de versions avec Git 35 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Fichiers

Manipulation de fichiers
Attention : pour être enregistrés, les commandes manipulant le
système de fichiers doivent être réalisées par l’intermédiaire de git !
Renommer un fichier : git mv old name new name
Supprimer un fichier : git rm fichier

28/09/17 Introduction à la gestion de versions avec Git 36 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Consultation des méta-données

Consulter les modifications du working dir depuis le dernier


commit : git status
Consulter les modifications en cours du contenu des fichiers
suivis : git diff
Consulter les modifications du contenu des fichiers entre deux
commits : git diff sha1 autre sha1
Consulter l’historique des commits : git log
Consulter l’historique des manipulation du graphe
(déplacement de HEAD) : git reflog
Consulter qui a modifié quelles lignes d’un fichier : git blame
nom fichier
Consulter un objet git : git show sha1

28/09/17 Introduction à la gestion de versions avec Git 37 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Annuler des modifications

Sur un fichier

Retirer les modifications d’un fichier indexées dans la staging


area (inverse de git add) : git reset nom fichier
Annuler les modifications courantes d’un fichier ou répertoire
du working dir en rappelant celles :
de la staging area : git checkout nom fichier
d’un commit : git checkout SHA1 nom fichier

28/09/17 Introduction à la gestion de versions avec Git 38 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Annuler des modifications

Figure : Manipulations de fichiers entre zones de git 1

1. schéma de Thibault Jouannic :


https://www.miximum.fr/blog/enfin-comprendre-git/
28/09/17 Introduction à la gestion de versions avec Git 39 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Annuler des modifications


Sur un ensemble de modifications en cours

Changer la HEAD, équivalent à un ”go to” : git reset SHA1


–soft
Changer la HEAD et réinitialiser la staging area à cette
version : git reset SHA1 –mixed (option par défaut)
Changer la HEAD et réinitialiser la stating area et le working
dir à cette version : git reset SHA1 –hard

Sur un commit

Annuler un commit en créant un nouveau commit annulant


les modifications du premier : git revert SHA1
Modifier (corriger) un commit avec les modifications
courantes : git commit –amend
28/09/17 Introduction à la gestion de versions avec Git 40 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gestion des branches

Création et navigation
Les branches permettent de réaliser un développement en parallèle
la branche principale afin de limiter les impacts.
Lister les branches existantes : git branch
Créer une nouvelle branche : git branch nom branche
(nom racine ou SHA1 )
Changer la branche active : git checkout nom branche
(revient à déplacer la référence HEAD vers le commit le plus
récent de cette branche)
Revenir sur la branche principale : git checkout master
Placer HEAD sur un commit particulier : git checkout SHA1

28/09/17 Introduction à la gestion de versions avec Git 41 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gestion des branches

Regroupement et supression
Les branches ont vocation à être réintégrées à la branche
principale.
Fusion de la branche courante avec une autre : git merge
nom branche (génère un commit avec deux parents, un dans
chaque branche)
Supprimer une branche : git branch -d nom branche

28/09/17 Introduction à la gestion de versions avec Git 42 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gestion des branches

Figure : Branches divergentes avant fusion [1]

28/09/17 Introduction à la gestion de versions avec Git 43 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gestion des conflits

Dus à des modifications différentes au même endroit dans un


même fichier.
Deux choix
Git entre en mode résolution des conflits. Deux manières d’en
sortir :
Ne pas fusionner : git merge –abort
Résoudre les conflits :
Éditer les fichiers sources de conflits
Terminer la résolution par git commit

28/09/17 Introduction à la gestion de versions avec Git 44 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gestion des conflits

Commandes utiles pour visualiser les conflits

Afficher les conflits au format diff3 (permet de visualiser


l’ancêtre commun, ce qui aide à la résolution) : git config
–global merge.conflictstyle diff3
Si certains conflits récurrents, réutiliser résolution passée
(reuse recorded resolution) : git config –global rerere.enabled 1
Référence pratique : MERGE HEAD pointe sur la tête de la
branche distante à fusionner
Comparer les versions HEAD et MERGE HEAD : git diff

28/09/17 Introduction à la gestion de versions avec Git 45 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gestion des conflits

Commandes utiles pour visualiser les conflits

Trouver l’ancêtre commun : git merge-base


nom branche distante nom branche locale
Voir les différences : git diff SHA1 ancêtre
nom branche distante fichier
git log SHA1 ancêtre nom branche distante –follow -p –
fichier
git log SHA1 ancêtre HEAD –follow -p – fichier

28/09/17 Introduction à la gestion de versions avec Git 46 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gestion des conflits

Les stratégies automatiques de résolutinon

Résoudre automatiquement les conflits avec une stratégie


pré-définie : git merge -s stratégie
Toujours favoriser notre version : ours
Toujours favoriser l’autre version : theirs

28/09/17 Introduction à la gestion de versions avec Git 47 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gérer le graphe des commits


Transplantation de branches (rebase)
Permet de d’intégrer les modifications d’une branche dans une
autre afin d’éviter un merge par fusion : donne l’illusion d’un
développement linéaire a posteriori.
Intégreation progressive des commits précédents à la head :
git rebase -i SHA1 (du commit à partir duquel commencer)
Pour chaque commit parcouru, 3 options :
pick : commit directement appliqué à la head
edit : commit appliqué et modification possible avant
l’intégration du suivant
squash : commit appliqué et fusionné avec le précédent
Réécrit l’histoire du dépôt. A faire uniquement localement. En cas
de conflit git rebase –continue (après résolution) ou git rebase
–abort.
28/09/17 Introduction à la gestion de versions avec Git 48 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Transplantation de commits

État du graphe :

- A - B - C - D - remote HEAD
\
E - F - G - local HEAD

Après un merge :

- A - B - C - D - remote HEAD
\ \
E - F - G - local HEAD - new local HEAD

Après un rebase :

- A - B - C - D - remote HEAD - E’ - F’ - G’ - local HEAD’

28/09/17 Introduction à la gestion de versions avec Git 49 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gérer le graphe des commits

Pull and rebase

git pull est équivalent à git fetch + git merge


git pull –rebase est équivalent git fetch + git rebase
Réécrit les commits locaux intermédiaires de manière à
s’inscrire dans la continuité de l’autre branche (peut faciliter la
résolution des conflits) : git pull –rebase
(nom branche distante nom branche locale)

28/09/17 Introduction à la gestion de versions avec Git 50 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Gérer le graphe des commits

Squashing
Permet de regrouper plusieurs commits successifs d’une branche
avant un merge.
git merge –squash
git pull –squash
Squashing et Rebasing : simplifier le graphe de commits pour
laisser le dépôt principal propre et lisible (anyway, toujours suivre la
politique de l’entreprise si définie)

28/09/17 Introduction à la gestion de versions avec Git 51 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Autres commandes utiles

Stash (stash)

Sauvegarde puis annule les modifications du working dir et de


l’index pour les ré-appliquer plus tard : git stash
Lister les modifications sauvegardées : git stash list
Inspecter les modifications sauvegardées : git stash show
Restaurer : git stash apply

28/09/17 Introduction à la gestion de versions avec Git 52 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Autres commandes utiles

Et bien d’autres...

Étiqueter une version (copie l’arbre et interdit toute


modification) : git tag nom tag (SHA1 )
Intégrer à la branche courante les modifications d’un commit
précis : git cherry-pick sha1
Recherche dichotomique pour trouver l’origine d’un bug entre
un good et un bad commit : git bisect

28/09/17 Introduction à la gestion de versions avec Git 53 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Commandes de base

Attention

Git est très puissant mais un grand pouvoir implique...


Certaines commandes dangereuses
ex : git push –force
Ne pas utiliser de commande sans s’être documenté

28/09/17 Introduction à la gestion de versions avec Git 54 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Outline

1 Introduction aux SCM

2 Git
Architecture
Commandes de base
Outils et pratique au quotidien

3 SCM et intégration continue

28/09/17 Introduction à la gestion de versions avec Git 55 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Outils graphiques

Gérer les arbres à l’aide des commandes peut se révéler délicat.


Certains outils graphiques peuvent aider mais sont toujours plus
limités que la console :
gitk ou gitg : simple interface graphique qui permet de
visualiser l’historique (branches et commits). Chaque commit
peut être visualisé (liste des fichiers modifiés, changements,
etc.).
git-gui : client complet permettant de préparer ses commits
git-cola : client git graphique (pull, push, commit, diff-viewer,
etc.)
Smart Git : client git complet, nombreuses fonctionnalités,
cross-platform
Giggle : interface de visualisation, équivalent à gitk

28/09/17 Introduction à la gestion de versions avec Git 56 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Outils graphiques

28/09/17 Introduction à la gestion de versions avec Git 57 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Outils graphiques

28/09/17 Introduction à la gestion de versions avec Git 57 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Outils en ligne

Services de dépôts en ligne


GitHub, BitBucket, Gitorious, GitLab, etc.

Plateformes d’hébergement
GitLab, FusionForge, etc.
Offre souvent beaucoup d’autres services : sites web, wiki, mailing
lists, forums, bugtrackers, gestion des releases etc.

28/09/17 Introduction à la gestion de versions avec Git 58 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Organisation du travail

Plusieurs workflow possibles

Force de git : souplesse dans l’organisation des workflow


Avec/sans dépôt commun distant
Avec/sans intégrateur (notion de pull request)

28/09/17 Introduction à la gestion de versions avec Git 59 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Organisation du travail

Figure : Workflow possibles [1]

28/09/17 Introduction à la gestion de versions avec Git 60 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Organisation du travail

Figure : Workflow possibles [1]

28/09/17 Introduction à la gestion de versions avec Git 60 / 71


Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Organisation du travail

28/09/17 Figure : àWorkflow


Introduction possibles
la gestion de versions avec Git[1] 60 / 71
Introduction aux SCM Git SCM et intégration continue Biblio
Outils et pratique au quotidien

Organisation du travail

Github Workflow

Anything in the master branch is deployable


To work on something new, create a descriptively named
branch off of master
Commit to that branch locally and regularly push your work
to the same named branch on the server
When you need feedback or help, or you think the branch is
ready for merging, open a pull request
After someone else has reviewed and signed off on the feature,
you can merge it into master
Once it is merged and pushed to master, you can and should
deploy immediately

28/09/17 Introduction à la gestion de versions avec Git 61 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Outline

1 Introduction aux SCM

2 Git
Architecture
Commandes de base
Outils et pratique au quotidien

3 SCM et intégration continue

28/09/17 Introduction à la gestion de versions avec Git 62 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Besoins

Étapes d’un projet de développement logiciel

1 Offre (proposition, budgétisation, présentation),


2 Spécifications fonctionnelles et planification (chef de projet)
3 Gestion des ressources humaines (chef de projet, RH),
4 Spécifications techniques (architecte logiciel), gestion des
ressources matérielles
5 Mise en place des environnements (devops)
6 Écriture du code source, tests unitaires, tests d’intégration
(développeurs)
7 Tests fonctionnels (équipe dédiée)
8 Corrections des erreurs (développeurs)
9 Livraison, mise en production (ingénieurs système)
28/09/17 Introduction à la gestion de versions avec Git 63 / 71
Introduction aux SCM Git SCM et intégration continue Biblio

Besoins

Production logicielle
Besoin d’automatisation :
Raccourcir les cycles de développement (points 6,7,8, voire 9)
(SDLC automation ”Software Development Life Cycle”)
Éviter les fautes, pouvoir corriger rapidement
Dégager du temps utile
Procédés actuels : intégration continue ”CI” (voire même livraison
continue ”CD”). Similaire à la production industrielle en flux tendu.

28/09/17 Introduction à la gestion de versions avec Git 64 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

L’intégration continue

Procédure automatique

Les développeurs enregistrent les modifications stables sur une


branche du SCM
Le serveur d’intégration continue réalise alors :
1 récupération du code source depuis le SCM et compilation
2 récupération des configurations des environnements depuis le
SCM
3 exécution des tests unitaires
4 exécution des tests d’intégration
5 création d’un build
6 déploiement
report automatique de tout problème dans le processus
le SCM est un élément essentiel de la chaı̂ne de CI

28/09/17 Introduction à la gestion de versions avec Git 65 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Exemples d’outils de CI

Maven : gestion et automatisation de production de logiciels


Java (description du projet et configuration en XML, gestion
des dépendances avec téléchargement automatique, etc.)
Jenkins : build et tests automatiques de projets
Docker : automatise le déploiement d’applications dans des
conteneurs logiciels dont la construction est paramétrable.
Permet de déployer dans un environnement isolé et facilement
partageable.
Ansible : déploiement de logiciels sur clusters et gestion des
configurations
Puppet : gestion de la configuration de serveurs, déploiement
de VM et d’applications

28/09/17 Introduction à la gestion de versions avec Git 66 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Git à TELECOM Nancy

GitLab

GitLab : logiciel libre de forge (GitLab Community Edition)


Déployé à l’école :
https://gitlab.telecomnancy.univ-lorraine.fr/
Login : [email protected], Mdp : LDAP
Ne pas confondre avec GitLab.com : le service de forge en
ligne, basé sur GitLab Enterprise Edition (similaire à GitHub
ou BitBucket)
Utilisé en entreprise (IBM, Sony, CERN, SpaceX, etc.)

28/09/17 Introduction à la gestion de versions avec Git 67 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Git à TELECOM Nancy

Fonctionnalités de GitLab

Dépôt git (of course) avec inferface web, mais pas que
Outils collaboratif : gestion des membres, Mattermost
(slack-like), revue de code, etc.
Outils de suivi : gestion des tickets, des versions, des releases,
bug tracker, statistiques, etc.
Outils de CI : recettes Docker, routines et tests automatiques,
etc.
Outils pour la communauté : pages web, wiki
Voir https://about.gitlab.com/features/

28/09/17 Introduction à la gestion de versions avec Git 68 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Quelques liens

Généraux :
http://git-scm.com/
http://git-lectures.github.io/
https://guides.github.com/introduction/flow/
https://git.wiki.kernel.org/
https://www.miximum.fr/blog/enfin-comprendre-git/
Questions spécifiques :
https://www.quora.com/How-does-Git-merge-work
https://www.miximum.fr/blog/git-rebase/
http://clubmate.fi/
git-dealing-with-branches-merging-and-rebasing/
https://www.atlassian.com/git/tutorials/
resetting-checking-out-and-reverting/

28/09/17 Introduction à la gestion de versions avec Git 69 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

Encore des liens

Mémos :
http://ndpsoftware.com/git-cheatsheet.html
http://gitref.org/
Tutos :
http://try.github.io/levels/1/challenges/1
https:
//blog.udemy.com/git-tutorial-a-comprehensive-guide/
http://gitimmersion.com/
gittutorial et gittutorial-2(man page)

28/09/17 Introduction à la gestion de versions avec Git 70 / 71


Introduction aux SCM Git SCM et intégration continue Biblio

References

[1] S. Chacon and B. Straub, “Pro git.”


http ://git-scm.com/book/fr/, 2014.
[2] L. Nussbaum, “Gestion de versions avec git.”
https ://members.loria.fr/LNussbaum/asrall/o5-git.pdf, 2013.
[3] B. Lynn, “Git magic.”
http ://www-cs-students.stanford.edu/ blynn/gitmagic/, 2010.
[4] N. Villa, “Introduction à git.”
http ://nathalievilla.org/spip.php ?article91, 2013.

28/09/17 Introduction à la gestion de versions avec Git 71 / 71

Vous aimerez peut-être aussi