40
Git Flow Igor Laborie Toulouse JUG - 21 Fév. 2013 mercredi 20 février 13

Git flow

Embed Size (px)

DESCRIPTION

Short Git Flow presentation for ToulouseJUG

Citation preview

Page 1: Git flow

Git Flow

Igor LaborieToulouse JUG - 21 Fév. 2013mercredi 20 février 13

Page 2: Git flow

Introduction

mercredi 20 février 13

Page 3: Git flow

Introduction

• Git et les branches c’est génial

mercredi 20 février 13

Page 4: Git flow

Introduction

• Git et les branches c’est génial

• Travail collaboratif => Workflow de branches

mercredi 20 février 13

Page 5: Git flow

Introduction

• Git et les branches c’est génial

• Travail collaboratif => Workflow de branches

• «Loi Entropique de l’Informatique»

mercredi 20 février 13

Page 6: Git flow

Introduction

• Git et les branches c’est génial

• Travail collaboratif => Workflow de branches

• «Loi Entropique de l’Informatique»

• => ça devient vite chaotique

mercredi 20 février 13

Page 8: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

mercredi 20 février 13

Page 9: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

mercredi 20 février 13

Page 10: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

mercredi 20 février 13

Page 11: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

mercredi 20 février 13

Page 12: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

mercredi 20 février 13

Page 13: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v0.2

mercredi 20 février 13

Page 14: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v0.2

mercredi 20 février 13

Page 15: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v0.2

mercredi 20 février 13

Page 16: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v0.2

mercredi 20 février 13

Page 17: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v0.2

mercredi 20 février 13

Page 18: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v0.2

mercredi 20 février 13

Page 19: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v0.2

mercredi 20 février 13

Page 20: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v0.2

mercredi 20 février 13

Page 21: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v0.2

mercredi 20 février 13

Page 22: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v1.0v0.2

mercredi 20 février 13

Page 23: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v1.0v0.2

mercredi 20 février 13

Page 24: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v1.0v0.2

mercredi 20 février 13

Page 25: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v1.0v0.2

mercredi 20 février 13

Page 26: Git flow

4

Time

v0.1

master

develop

hotfixe(s)

release(s)

feature/a

feature/b

v1.0v0.2 v1.1

mercredi 20 février 13

Page 27: Git flow

master

• Version que l’on peut mettre en production

• => avec un tag

mercredi 20 février 13

Page 28: Git flow

develop

• Développement de la prochaine version

• Nouvelles features

• Parfois appelée: next, pu (proposed update)

mercredi 20 février 13

Page 29: Git flow

feature/XXX

• Développement de la feature XXX

• Partent de develop

• Sont mergées dans develop

• Pas forcément visible dans origin

• Parfois appelée : topic

mercredi 20 février 13

Page 30: Git flow

release/XXX

• Préparation de la release XXX

• feature freeze

• => MAJ configuration / documentation

• validation / correction des bugs bloquants

• Partent de develop

• Sont mergées dans master et develop

mercredi 20 février 13

Page 31: Git flow

hotfix/XXX

• Correction du bug bloquant XXX de la production

• Partent de master

• Sont mergées dans master et develop

mercredi 20 février 13

Page 32: Git flow

support/XXX

• Maintenance des vielles versions

mercredi 20 février 13

Page 33: Git flow

Démo

mercredi 20 février 13

Page 34: Git flow

Bilan

mercredi 20 février 13

Page 35: Git flow

Bilan

• Evite l’inflation des branches

mercredi 20 février 13

Page 36: Git flow

Bilan

• Evite l’inflation des branches

• Simplification des opérations des branches

mercredi 20 février 13

Page 37: Git flow

Bilan

• Evite l’inflation des branches

• Simplification des opérations des branches

• Rend la branche master toujours propre

mercredi 20 février 13

Page 38: Git flow

Bilan

• Evite l’inflation des branches

• Simplification des opérations des branches

• Rend la branche master toujours propre

• Peut être activer/désactiver sans abimer le repository

mercredi 20 février 13

Page 39: Git flow

Tooling

• CLI: https://github.com/nvie/gitflow

• (OSX) Source Tree

• EGit ...

• Autre ?

mercredi 20 février 13