Outils pour utilisateurs

Outils du site


workshop_git

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Prochaine révision
Révision précédente
workshop_git [2024/03/20 12:47] – créée bigMaxworkshop_git [2024/04/03 07:49] (Version actuelle) bigMax
Ligne 1: Ligne 1:
 <markdown> <markdown>
  
-# Workshop git : initiation+# Workshop Git : initiation 
 +[git sur wikipedia](https://fr.wikipedia.org/wiki/Git)
  
 ## Presentation ## Presentation
 +L' [outil de gestion de versions](https://fr.wikipedia.org/wiki/Gestion_de_versions) le plus populaire au monde.
 +
 +Il est décentralisé : on a pas besoin d'un serveur pour l'utiliser.
  
 ## Usages ## Usages
 +
 +- Historiser des modifications de fichiers
 +- Comparer des versions (principallement des fichiers textes)
 +- Collaborer
 +
  
 ## Disclaimer ## Disclaimer
 +- Plusieurs manières différentes de faire certaines actions
 +- On montre beaucoup de commandes différentes dans cet atelier. L'objectif n'est pas de toute les apprendre, mais de sentir la philosophie et être capable de les retrouver au quotiden.
 +- Lire les indication donnés par git qui sont très très très très utiles
 +- Votre moteur de recherche préféré + stackoverflow sont vos amis pour trouver quoi faire en toute situation
  
-    Plusieurs de manières différentes de faire plein de choses 
-    Votre moteur de recherche préféré + stackoverflow sont vos amis pour trouver les commandes 
  
 +## help
 +- git help
 +- man git
 +- tldr git ?
  
-## Tuto 1 cloner un repo (double window CLI / FS_Browser) 
  
-    git clone SOME_REPO +## Tuto 1 : débuter en clonant un dépôt git existant (double window CLI / FS_Browser) 
-    git switch develop +``` bash 
-    git log +git clone git@github.com:mxbossard/mass.git 
-    git log pretty+git clone https://github.com/mxbossard/mass.git 
 +cd mass 
 +git branch 
 +git branch -r 
 +git switch develop 
 +git branch 
 +git log 
 +git log --pretty=oneline --abbrev-commit --graph --decorate 
 +git hist ORIG_HEAD.. --stat --no-merges 
 +```
  
 +## Mot clés
 +- repo : repository ou dépôt en français : structure conservant toute nos opérations git (peut être local ou distant) (un espace de stockage, une base de donnée)
 +- tree : (arbre en français) structure de donnée interne représentant d'un dossier et tout son contenu
 +- blob : structure de donnée intern représentant un fichier
 +- commit : collections de fichiers & dossiers représentés par un hash (sha1)
 +- HEAD : On peut voir ça comme une "tête de lecture" qui lit un commit et l'affiche dans notre repertoire de travail.
 +- pathspec : expression representant un ou plusieurs chemins de fichier dans un dépôt
 +- tree-ish : expression représentant un tree (ex: HEAD:README.md) (ex: HEAD) (les commits et tags sont déréférencés pour l'arbre vers lequel ils pointent)
 +- commit-ish : expression représentant un commit (ex: HEAD) (ex: f8f3f58)
 +- worktree / working tree / working directory : repertoire de travail qui reflete le contenu d'un commit
 +- index / staging area : zone tampon qui stoque un tree contenant les modification en attente de commit
 +- tag: pointeur vers un commit
 +- branch :  pointeur vers un commit "mouvant" auquel on attache son working tree
 +
 +## Tuto 2 : modifier des fichiers comparer et commit les modifications
 +``` bash
 +git status
 +git diff
 +git diff HEAD
 +git diff HEAD^
 +echo foo > bar
 +echo baz >> README.md
 +mkdir pif
 +git status
 +git diff
 +git add .
 +git status
 +git diff
 +git diff --staged
 +git commit -m "ma modif"
 +touch pif/paf
 +git commit -a --amend
 +git log
 +git diff
 +git diff HEAD
 +git diff HEAD^
 +```
  
 ## Fonctionnement ## Fonctionnement
 +### Interne
 +</markdown>
 +{{ :media_12:git_index_tree_blob.png?direct&800 |}}
 +<markdown>
 +[Documentation Git Internals - Git Objects](https://git-scm.com/book/en/v2/Git-Internals-Git-Objects)
  
-    decentralisé +### Décentralisé 
-    pas besoin de repo central+- Pas besoin de repo central 
 +- Tout l'historique en local 
 +- On peut commit dans son repo local 
 +- La réconciliation peut être compliqué si plusieurs personnes modifie le même fichier simultanément (classique, ce n'est pas magique)
  
 +</markdown>
 +{{ :media_12:git_layers_and_commands.jpg?direct&600 |}}
 +<markdown>
  
-## Tuto 2 travailler avec git+### Commit Hash (sha1) 
 +Hash des données et méta-données contenu dans le commit. Une représentation du commit réputé unique dans un repo. 
 +- exemple de hash :       f8f3f58c67b5be45cc4595d0dace0728f5c9c9bf 
 +- exemple de short hash : f8f3f58
  
-    git init myrepo +### Branch 
-    touch myFile +Une branche pointe vers un commit, mais à la différence du tag, on "travail sur une branche"Cela veut dire que notre espace de travail (working dir) est en général accroché sur une brancheLorsque l'on effectue un commit, ce commit est attaché à la branche, et devient le dernier commit de la branche.
-    git add . +
-    git stash +
-    git apply +
-    git commit -m "new file" +
-    echo foo > myFile +
-    git diff +
-    git commit  +
-    git push +
-    git tag 0.0.+
-    git checkout HEAD^ +
-    git checkout HEAD^^ +
-    git checkout 0.0.1 +
-    git clean +
-    git reset+
  
 +</markdown>
 +{{ :media_12:git_commits_tree_branches_tags.png?direct&600 |}}
 +<markdown>
 +
 +### diff comme patch
 +Les git diff permettent de produire des fichiers patch qui peuvent être appliqués à la main.
 +
 +</markdown>
 +{{ :media_12:git_diff_sample_2.png?direct&600 |}}
 +<markdown>
 +
 +## Tuto 3 : Initialiser son propre dépôt git et travailler dessus
 +``` bash
 +git init myrepo
 +cd myrepo
 +touch myfile
 +git commit -a -m message
 +echo foo > myfile
 +git commit -a -m foo
 +echo bar > baz
 +git checkout -b develop
 +git commit -a -m baz
 +echo bar >> baz
 +git status
 +git stash
 +git status
 +git stash list
 +git switch master
 +git status
 +git switch develop
 +git stash apply
 +git commit -m -a "baz2"
 +git tag 0.0.1
 +git tag
 +git checkout HEAD^
 +git checkout HEAD^^
 +git checkout 0.0.1
 +git switch develop
 +```
  
 ## Forges git ## Forges git
  
-    framagit +### Exemples de forges git "Public" 
-    gitlab +- [framagit](framagit.org) 
-    github+- [gitlab](gitlab.com) 
 +- [github](github.com)
  
 +### Intérêts
 +- Des outils graphiques en plus (diff, ...)
 +- Un repo central souvent plus pratique pour callaborer
 +- Fork & Pull Request organisé
 +- Pipelines
 +- Pages
 +- ...
  
-## Git flows+### Exemples de solutions déployable 
 +Il existe des outils pour déployer dans une forge git privé. 
 +- gitlab : complet et lourd 
 +- gitea ? 
 +TODO
  
-    Pour travailler seul et surtout a plusieurs nécéssaire de se mettre d'accord sur un procéssus 
-    Expliqué une propal de git flow 
-    Linker d'autres git flows 
  
 +## Tuto 4 : Creer et suivre (track) un remote repo (dépôt distant) sur une forge git
 +Demo en live sur framagit.
 +
 +``` bash
 +git remote
 +git remote add origin git@framagit.org:labomedia/foo.git
 +git remote
 +git remote -v
 +git branch -M main
 +git push -uf origin main
 +```
 +
 +Visit URL: https://framagit.org/labomedia/foo.git
 +
 +## Quoi commit ?
 +.gitignore file permet de configurer des fichiers à ne pas commit
 +
 +Attention, si vous avez commit un secret sur un dépôt distant, il faut considérer que le secret n'est plus secret.
 +
 +### Fichiers à commit
 +- des sources
 +- des test
 +- des configurations applicatives
 +
 +### Fichiers à ne pas commit
 +- des secrets (compliqué à retirer correctement)
 +- des binaires (prend beaucoup trop de place)
 +- des fichiers temporaires
 +- la configuration de son IDE
 +
 +## Travail collaboratif
 +- Lorsqu'on travail à plusieurs, Il est important de synchroniser sont repo local le plus souvent possible pour éviter de trop grosses divergences.
 +- A plusieurs, il est toujours compliqué de travailler simultanément sur les même fichiers. Lorsque c'est possible, il vaut mieux s'attribuer à chacun une compétence sur des fichiers différents.
 +- Il faut éviter de modifier les commits partagés cela équivaut à changer l'historique partagé par tous et ne vient pas sans problème sur les travaux en cours.
 +
 +## Reset, Restore, Revert
 +Il est parfois nécessaire de faire des opérations de "retour en arrière" :
 +* Néttoyer son index (retirer des fichiers stagged) => git restore .
 +* Néttoyer son working tree (on perd tous ses changements en cours) = > git checkout .
 +* Annuler un commit => git revert (cela ne supprime pas le commit, mais créé un nouveau commit qui annule les modifications du commit annulé)
 +* Modifier le dernier commit => git --amend (Il est relativement aisé de modifier des commits tant qu'ils ne sont pas partagés)
 +* Supprimer le dernier commit => git reset HEAD^ (Il est relativement aisé de supprimer des commits tant qu'ils ne sont pas partagés)
 +* Modifier un ancien commit => cela revient à modifier l'historique, c'est compliqué, il faut l'éviter le plus possible
 +
 +Il est facile de modifier des commit dans son repo local tant qu'ils n'ont pas été partagés dans un autre repo. Toutefois, il est toujours dangereux de modifier l'historique des commit, surtout lorsqu'on travail à plusieurs.
 +
 +Attention, si vous avez commit un secret sur un dépôt distant, il faut considérer que le secret n'est plus secret.
 +
 +### git restore
 +Manipule le "working tree" ou le "staging area". Ne change pas l'historique.
 +
 +### git revert
 +Annule les modifications d'un ou plusieurs commit. Ne change pas l'historique
 +
 +### git reset
 +Permet de modifier l'historique (à faire avec précaution).
 +
 +## Merge vs Rebase ?
 +Débat d'ordre philosophique non tranchable. Cela dépend des pratiques de chacun, de l'équipe et du workflow de travail.
 +
 +Les 2 opérations permettent de fusionner 2 branches en une. Typiquement on va fusionner la branch develop dans la branch main lorsque l'on a terminé ses modifications sur la branch develop.
 +
 +Les 2 opérations different dans la manière de réaliser cette fusion dans l'historique.
 +
 +</markdown>
 +{{ :media_12:git_merge_vs_rebase.jpeg?direct&600 |}}
 +<markdown>
 +
 +### Merge
 +Ne modifie pas l'historique et ajoute un nouveau commit dans la branch accueillant la fusion.
 +
 +### Rebase
 +Modifie l'historique afin de faire démarrer la branch fusionné à la fin de la branche accuillant la fusion.
 +
 +### squash
 +
 +## Git workflows
 +Si on est nombreux sur un repo, il faut synchro son repo local souvent.
 +
 +### Minimal flow : quand on travail essentiellement seul (mon mien)
 +- Au départ je ne m'encombre pas des branches et je travail sur la branche main (anciennement master)
 +- Puis quand ma production est mature et que je veus faire de nouvelles modifications, je créé une branche develop
 +- Lorsque je me lance dans un gros truc je créé une nouvelle branch nommé d'apres les travaux
 +- Je tag avec une version semantic (0.0.1-rc2) chaque commit que je veux publier
 +- J'essaye de remonter les tag commités dans la branch main autant que possible
 +
 +### Git flow : exemple de workflow pour travailler à plusieurs sans se marcher sur les pieds
 +- Pour travailler seul et surtout a plusieurs nécéssaire de se mettre d'accord sur un procéssus
 +</markdown>
 +{{ :media_12:gitflow_1.webp |}}
 +<markdown>
 +[Une doc en français](https://mindsers.blog/fr/post/gitflow-la-methodologie-et-la-pratique/)
 +[Une doc fr du plugin git-flow](https://danielkummer.github.io/git-flow-cheatsheet/index.fr_FR.html)
 +
 +### Autres
 +TODO: Linker d'autres git flows
 +
 +
 +## Pull requests
 +TODO
  
 ## Trucs utiles ## Trucs utiles
  
-    git alias tiptop +### git config 
-    git config + 
-    authent+### Alias tiptop 
 +``` bash 
 +git config --global alias.s "status" 
 +git config --global alias.who "shortlog -sne" 
 +git config --global alias.changes "diff --name-status" 
 +git config --global alias.dic "diff --cached" 
 +git config --global alias.d "diff --stat" 
 +git config --global alias.hist "log --pretty=oneline --abbrev-commit --graph --decorate" 
 +git config --global alias.lc \!"git hist ORIG_HEAD.. --stat --no-merges" 
 +git config --global alias.amend "commit --amend" 
 +git config --global alias.undo "git reset --soft HEAD^" 
 +git config --global alias.spull \!"__git_spull() { git pull "$@" && git submodule sync --recursive && git submodule update --init --recursive --remote; }; __git_spull" 
 +git config --global alias.spush "push --recurse-submodules=on-demand" 
 +``` 
 + 
 +### authent avec ssh 
     ssh keygen ?     ssh keygen ?
  
  
 +## git init --bare
 +TODO
 +
 +
 +## Feedback 1er atelier
 +- need git config user.email & user.name for fresh install
 +- clone ssh repo may not works out of the box.
 +- Montrer les schéma avant les definitions
 +- Atelier de bout en bout git clone to pull
 +- Atelier de bout en bout fork un repo faire une modif et proposer une PR.
 +- Demander si on manip en premier ou si on fait les definitions en premier.
 +- Si peu de manip, definition en premier peut etre bien.
  
 </markdown> </markdown>
workshop_git.1710938855.txt.gz · Dernière modification : 2024/03/20 12:47 de bigMax