Brancher ou ne pas brancher?

84

Jusqu'à récemment, mon flux de travail de développement était le suivant:

  1. Obtenir la fonctionnalité du propriétaire du produit
  2. Faire une branche (si la fonctionnalité est plus que 1 jour)
  3. Implémentez-le dans une branche
  4. Fusionner les modifications d'une branche principale à ma branche (pour réduire les conflits lors de la fusion en amont)
  5. Fusionner ma branche dans la branche principale

Parfois, il y avait des problèmes de fusion, mais en général, ça me plaisait.

Mais récemment, je vois de plus en plus d'adeptes de l'idée de ne pas créer de branche car il est plus difficile de pratiquer l'intégration continue, la livraison continue, etc. Et cela semble particulièrement amusant de la part des personnes disposant d'une expérience VCS distribuée qui parlaient tellement de la mise en œuvre Git, Mercurial, etc.

La question est donc de savoir si nous devons utiliser des branches de nos jours?

SibérienGuy
la source
2
Je suis tout à fait sûr que c'est la bonne plateforme pour cela, mais oui, j'aurais une branche. Mais peut-être devriez-vous songer à fusionner certains ensembles de caractéristiques dans Master avant qu'ils ne soient finis à 100% (pour donner des aperçus: P)
ZeissS
1
On dirait qu'ils ont besoin de meilleures stratégies pour fusionner.
b01
1
J'ai toujours vu tous les commits comme une fusion, même du plus local au plus distant. La fusion à partir de branches est la même chose, à savoir de plus grands ensembles de changements, donc je ne comprends pas quel est l’argument. Quelqu'un a-t-il déjà fait le profil de la performance de l'une de ces techniques, ou s'agit-il simplement d'une optimisation prématurée?
Tylermac
Je dirais que les succursales rendraient la CI plus facile ...
tdammers le
7
S'il vous plaît, ne postez pas le même message textuellement sur plusieurs sites Stack Exchange.
Adam Lear

Réponses:

64

À moins que vous travaillez tous sur le même arbre de travail, vous êtes en utilisant des branches, si vous les appelez ou non. Chaque fois qu'un développeur accède à son arbre de travail, il crée une branche de développement locale distincte et chaque fois qu'il s'enregistre, il effectue une fusion. Pour la plupart des équipes, la question n'est pas de savoir si vous utilisez des branches, mais combien et à quelle fin ?

La seule façon de réaliser une intégration réellement "continue" est que tout le monde travaille à partir du même arbre de travail. De cette façon, vous savez immédiatement si vos modifications ont un impact négatif sur celles de quelqu'un d'autre. De toute évidence, c'est intenable. Vous avez besoin d'un certain degré d'isolation dans une branche pour pouvoir accomplir quoi que ce soit, même si cette "branche" n'est que votre répertoire de travail local. Ce qu'il faut, c'est un juste équilibre entre intégration et isolement.

D'après mon expérience, utiliser davantage de branches améliore le degré d'intégration, car l'intégration se fait précisément avec les personnes concernées, et tout le monde peut plus facilement isoler les problèmes non liés, le cas échéant.

Par exemple, j'ai passé la dernière journée à rechercher trois bogues récemment introduits dans notre version liés à l'intégration, qui bloquaient mon "vrai" travail. Ayant fait preuve de diligence raisonnable en signalant ces bogues aux personnes qui doivent les réparer, suis-je maintenant censé attendre jusqu'à ce qu'elles aient terminé pour continuer mon travail? Bien sûr que non. J'ai créé une branche locale temporaire qui annule ces modifications afin de pouvoir utiliser une ligne de base stable tout en recevant les dernières modifications en amont.

Sans la possibilité de créer une nouvelle branche à cette fin, je serais réduit à l'une des trois options suivantes: soit annuler les modifications dans le référentiel central, gérer manuellement les correctifs qui les inversent dans mon arbre de travail et essayer de ne pas les archiver accidentellement. , ou revenez sur une version avant que ces bogues ne soient introduits. La première option est susceptible de briser une autre dépendance. La deuxième option représente beaucoup de travail, de sorte que la plupart des gens choisissent la troisième option, ce qui vous empêche essentiellement de faire plus de travail d'intégration jusqu'à ce que les bogues précédemment trouvés soient corrigés.

Mon exemple utilisait une branche locale privée, mais le même principe s’applique aux branches partagées. Si je partage ma branche, alors peut-être que 5 autres personnes peuvent continuer à exécuter leurs tâches principales au lieu d'effectuer un travail d'intégration redondant. Ainsi, dans l'ensemble, un travail d'intégration plus utile est effectué. Le problème des branches et de l'intégration continue n'est pas le nombre de branches que vous avez, mais leur fréquence de fusion.

Karl Bielefeldt
la source
1
Si vous annulez les commits non désirés dans votre nouvelle branche, ne les annulez-vous pas dans la branche principale lorsque vous y fusionnez? Personnellement, je passerais d'un point avant les modifications indésirables à une sélection des modifications dont je dépend dans la nouvelle branche.
Anthony
@anthony Très probablement, vous voudriez nettoyer votre historique (supprimer les retours) avant de fusionner. Quelqu'un contre la réécriture de l'histoire est probablement préférable de suivre votre méthode.
Idbrii
Si vous supprimez les branches et la réécriture de l'historique, pourquoi utiliser Git?
Everton
80

La question est: devrions-nous utiliser des branches de nos jours?

Il y a environ un an et demi, j'ai été chargé de mener une étude pour répondre à cette question. Voici le résumé, basé sur les références étudiées (listées ci-dessous)

  • il n'y a pas de "meilleure" stratégie de branchement convenue communément applicable à tout projet
    • la plupart des ressources semblent convenir que le choix d’une stratégie productive dépend des spécificités du projet
    • note de côté. Sur la base de ce qui précède, il semble que toute modification apportée à la stratégie de création de branche de projet doit être testée, mesurée et comparée à d'autres options testées.
  • l'opinion populaire est que la fusion avec Subversion demande beaucoup d'efforts. Tous ceux qui ont comparé SVN et Git notent que la fusion est extrêmement facile avec Git
  • Un facteur important semble être de savoir si les rejets de production proviennent du tronc ou des branches. Il est en substance interdit aux équipes effectuant des sorties de prod de trunk (qui ne semblent pas être un moyen assez populaire) d’utiliser une stratégie de trunk instable . Les équipes qui effectuent des lancements de prod à partir de branches ont plus d'options de branchement à choisir.
  • les stratégies populaires semblent être le tronc stable, le tronc instable et la branche de développement (intégration)

références

  • http://msdn.microsoft.com/en-us/library/aa730834%28v=vs.80%29.aspx

    ... Choisir la meilleure stratégie de branchement est un exercice d'équilibre. Vous devez compenser les gains de productivité par un risque accru. Un moyen de valider la stratégie choisie consiste à envisager un scénario de changement. Par exemple, si vous décidez d'aligner les branches sur l'architecture système (par exemple, une branche représente un composant du système) et attendez-vous à des modifications architecturales importantes, vous devrez peut-être restructurer vos branches, processus et stratégies associés à chaque modification. Le choix d'une stratégie de branchement inadéquate peut entraîner des frais généraux de processus ainsi que de longs cycles d'intégration et de version qui s'avèrent frustrants pour toute l'équipe ...

  • http://www.cmcrossroads.com/bradapp/acme/branching/

    ... L'intégration fréquente et incrémentale est l'un des indicateurs du succès et son absence est souvent une caractéristique de l'échec. Les méthodes actuelles de gestion de projet tendent à éviter les modèles de cascade stricts et à adopter les modèles en spirale de développement itératif / incrémental et de prestation évolutive. Les stratégies d'intégration incrémentielles, telles que Fusionner tôt et souvent et ses variantes, constituent une forme de gestion des risques qui tente d'éliminer les risques plus tôt dans le cycle de vie quand il reste plus de temps pour y faire face. [Booch], [McCarthy] et [McConnell] voient la régularité du rythme entre les intégrations comme un indicateur avancé de la santé d'un projet (comme un "pouls" ou un "battement de coeur").  
     
    Une intégration précoce et fréquente permet non seulement de concrétiser les risques plus tôt et en plus petits morceaux, mais aussi de communiquer les changements entre coéquipiers ...

  • http://www.codinghorror.com/blog/2007/10/software-branching-and-parallel-universes.html

    ... Dans la plupart des systèmes de contrôle de source, vous pouvez créer des centaines de branches sans aucun problème de performances. c'est la surcharge mentale de garder une trace de toutes ces branches dont vous avez vraiment besoin de vous inquiéter ... La ramification est une bête complexe. Il existe des dizaines de façons de créer des branches, et personne ne peut vraiment vous dire si vous le faites bien ou mal…

  • http://www.lostechies.com/blogs/derickbailey/archive/2010/02/24/branching-strategies-when-to-branch-and-merge.aspx

    ... Il existe de nombreux aspects d'un système à prendre en compte lors de la création d'une branche de code ... Au final, l'objectif est de fournir un bac à sable pour le contexte dans lequel le code est écrit. Comprendre les options disponibles, lorsque chaque option est la mieux adaptée à la situation actuelle et que le coût de ces options vous aidera à décider quand et quand vous souhaitez créer une branche ...

  • http://www.snuffybear.com/ucm_branch.htm
    Remarque: compte tenu des autres références répertoriées ici, l'affirmation de l'auteur selon laquelle "Cet article décrit trois modèles de branchement clés utilisés dans les projets de génie logiciel" ne semble pas justifiée. La terminologie utilisée ne semble pas répandue ( EFIX , Model-1,2,3, etc.).

  • http://svn.haxx.se/users/archive-2007-10/att-0101/SCMBranchingModels-talkback.pdf La
    référence présente un exemple intéressant de difficulté à communiquer des stratégies de branchement.

  • http://simpleprogrammer.com/2010/06/04/simple-branching-strategy-part-1-back-to-basics/
    ... Restez simple. Travailler directement du coffre est de loin la meilleure approche à mon avis.  
     
    Cela ressemble presque à une hérésie lorsque je le tape réellement sur mon écran, mais si vous persistez un instant avec moi, je ne vous montrerai pas seulement pourquoi je pense que cela est essentiel pour un processus Agile, mais je vais vous montrer comment. pour que cela fonctionne ...  
     
    ... Si je devais fonder mon raisonnement sur un argument solide, ce serait la valeur de l'intégration continue. J'ai blogué sur la valeur de l'EC et les meilleures pratiques du passé. Je suis un assez grand défenseur de CI ...  
     
    ... Il faut vraiment vous poser une question ici: « Est -ce tous les frais généraux que vous encourons de faire votre stratégie et la fusion compliquée ramification résultant en une valeur réelle qui n'existe pas sur une stratégie plus simple? » ...  
     
    .. .Une stratégie que j’ai utilisée avec succès par le passé et que j’ai développée avec le temps. Je vais résumer brièvement ici.

  • http://www.codelathe.com/blog/index.php/2009/07/02/a-svn-branching-strategy-that-works/
    ... Enfin, rappelez-vous qu'il n'y a pas de stratégie idéale de création de branches et de fusions. Cela dépend beaucoup de votre environnement de développement unique ...

  • http://blog.perforce.com/blog/?cat=62
    ... Le pire des cas est que vous introduisez un problème de "fusion sémantique", dans lequel le résultat d'une fusion automatique est incorrect, mais compile bien et passe au-delà test, voire même survivre assez longtemps pour être un bogue visible par le client. Eek!  
     
    Ajoutant l'insulte à la blessure, car ils peuvent échapper plus longtemps à la détection, les problèmes de fusion sémantique sont plus difficiles à résoudre plus tard, car le changement n'est plus d'actualité pour le développeur à l'origine du changement. (Il est généralement préférable de fusionner les modifications peu de temps après, idéalement par le développeur à l'origine des modifications, si cela s'avère pratique) ...

  • https://stackoverflow.com/questions/34975/branching-strategies Les
    membres de la communauté partagent une expérience différente dans différents projets utilisant différentes stratégies de branchement. Pas de consensus sur le "meilleur" ou le "pire".

  • http://www.stickyminds.com/s.asp?F=S16454_COL_2
    Un résumé succinct des éléments présentés dans http://oreilly.com/catalog/practicalperforce/chapter/ch07.pdf.

    • http://www.stickyminds.com/s.asp?F=S16511_COL_2
      ... Il existe trois approches courantes pour décider quand et comment créer une branche:
      • Créez la branche de publication lorsque vous êtes "fonctionnalité complète" et prévoyez de résoudre les problèmes de dernière minute sur cette ligne de code. Dans ce cas, la branche de version est en réalité une "ligne de code de préparation de version", comme décrit dans Modèles de gestion de la configuration logicielle , car vous vous attendez à ce qu'il reste encore du travail à faire.
      • Changez votre style de travail pour éviter le travail d'intégration final, en dehors de la ligne de développement active.
      • Branchez le nouveau travail en créant une branche de tâche et en le fusionnant dans la ligne de développement active une fois la publication terminée.
        ... Une des raisons de la création de branches est d'isoler le code à la fin d'une publication afin qu'il puisse se stabiliser. L'isolement par branchement masque souvent un problème de qualité qui finira par se traduire par le coût supplémentaire de la maintenance des flux parallèles avant la sortie d'un produit. La ramification est facile. Il est plutôt difficile de choisir un processus qui minimise le coût de la création de branches et de la fusion ... Il est donc important de choisir un processus qui minimise le coût de la création de branches et de la fusion ...
  • http://nvie.com/posts/a-successful-git-branching-model/ Stratégie orientée Git.
    ... Nous considérons origine / maître comme la branche principale où le code source de HEAD reflète toujours un état prêt pour la production .  
     
    Nous considérons que origine / develop est la branche principale où le code source de HEAD reflète toujours un état avec les dernières modifications de développement livrées pour la prochaine version. Certains appellent cela la "branche d'intégration". C’est ici que sont construits tous les builds nocturnes automatiques ....

  • http://svnbook.red-bean.com/fr/1.5/svn.branchmerge.html
    ... les règles de projet varient énormément en ce qui concerne le moment propice pour créer une branche de fonctionnalité. Certains projets n'utilisent jamais de branches de fonctionnalités: les commits vers / trunk sont gratuits. L'avantage de ce système est qu'il est simple: personne n'a besoin de se renseigner sur la création de branches ou la fusion. L'inconvénient est que le code de la ligne de réseau est souvent instable ou inutilisable. D'autres projets utilisent les branches à l'extrême: aucun changement n'est jamais engagé directement dans le coffre. Même les changements les plus insignifiants sont créés sur une branche éphémère, soigneusement examinés et fusionnés dans le coffre. Ensuite, la branche est supprimée. Ce système garantit un coffre exceptionnellement stable et utilisable à tout moment, mais au prix d’ une énorme perte de temps.processus de traitement.  
     
    La plupart des projets adoptent une approche à mi-chemin. Ils insistent généralement pour que / trunk compile et passe des tests de régression à tout moment. Une branche de fonctionnalité est requise uniquement lorsqu'un changement nécessite un grand nombre de validations déstabilisantes. Une bonne règle à suivre est de poser cette question: si le développeur travaillait de manière isolée pendant plusieurs jours, puis engageait le grand changement en même temps (de manière à ce que / le tronc ne soit jamais déstabilisé), un changement trop important serait-il à réviser? Si la réponse à cette question est "oui", le changement doit être développé sur une branche. Au fur et à mesure que le développeur applique des modifications incrémentielles à la branche, elles peuvent être facilement examinées par les pairs.  
     
    Enfin, la meilleure solution consiste à "synchroniser" une branche de fonctionnalité au fur et à mesure de l'avancement des travaux. Comme nous l'avons mentionné précédemment, travailler dans une succursale pendant des semaines ou des mois est très risqué. les changements de tronc peuvent continuer à affluer, au point que les deux lignes de développement diffèrent tellement que cela peut devenir un cauchemar en essayant de fusionner la branche pour la ramener au tronc.  
     
    Il est préférable d’éviter cette situation en fusionnant régulièrement les modifications de la jonction avec la branche. Créez une politique: une fois par semaine, fusionnez les modifications apportées au tronc de la dernière semaine dans la branche ...

  • http://thedesignspace.net/MT2archives/000680.html
    ... Cette section du didacticiel Eclipse CVS est basée sur l'article de Paul Glezen sur le site Web Eclipse: Branching with Eclipse et CVS , et est utilisé avec son autorisation, conformément aux conditions de la licence EPL. Les modifications que je suis en train d'apporter à sa version sont principalement de l'étendre avec plus d'images étape par étape et d'explications, et de l'intégrer à mes propres tutoriels pour débutants afin de la rendre plus accessible aux débutants et aux concepteurs. Les développeurs expérimentés préféreront probablement travailler à partir de la version de Paul ...

  • http://learnsoftwareprocesses.com/2007/12/29/common-branching-strategies/
    ... Voici quelques modèles de branchement courants:  

    1. Modèle branche par publication: L’une des stratégies de création de branches la plus courante consiste à aligner les branches sur les versions de produits. Une branche contient tous les actifs de développement logiciel pour une seule version. Parfois, les mises à jour doivent être fusionnées d’une version à l’autre, mais elles ne fusionnent généralement jamais. Les branches seront interrompues lors du retrait d'une version.  
    2. Branche par promotion: une autre approche très courante consiste à aligner les branches sur les niveaux de promotion des actifs logiciels. Une version de développement spécifique est divisée en une branche Test, dans laquelle sont effectués tous les tests d'intégration et de système. Une fois les tests terminés, les ressources de développement logiciel sont connectées à la branche Production et sont finalement déployées.  
    3. Branche par tâche: pour éviter le chevauchement des tâches (ou activités) et une perte de productivité, vous pouvez les isoler sur une branche distincte. N'oubliez pas qu'il s'agit de branches à court terme qui doivent être fusionnées dès que la tâche est terminée, faute de quoi l'effort de fusion requis risque de dépasser les avantages de productivité liés à leur création.  
    4. Branche par composant: vous pouvez aligner chaque branche sur l’architecture du système. Dans cette stratégie, vous vous séparez de composants individuels (ou de sous-systèmes). Ensuite, chaque équipe développant un composant décide à quel moment fusionner son code dans la ligne de développement servant de branche d’intégration. Cette stratégie peut fonctionner correctement si l’architecture du système est en place et si les composants individuels ont des interfaces bien définies. Le fait de développer des composants sur des branches permet un contrôle plus fin des ressources de développement logiciel.  
    5. Branche par technologie: une autre stratégie de branchement alignée sur l'architecture du système. Dans ce cas, les branches sont alignées sur les plateformes technologiques. Le code commun est géré sur une branche distincte. En raison de la nature unique des ressources de développement logiciel gérées sur les succursales, elles ne fusionnent probablement jamais ...
  • http://msdn.microsoft.com/en-us/library/bb668955.aspx
    ... Reportez-vous aux instructions de branchement et de fusion dans "Instructions de contrôle de code source" de ce guide pour obtenir un résumé des instructions de branchement et de fusion. ... Lors de la création de branches, tenez compte des points suivants:

    • Ne branchez pas sauf si votre équipe de développement doit travailler simultanément sur le même ensemble de fichiers. En cas de doute, vous pouvez étiqueter une construction et créer une branche à partir de cette construction ultérieurement. La fusion de branches peut prendre beaucoup de temps et être complexe, surtout s’il ya des changements importants entre elles.
    • Structurez vos arbres de branche de sorte que vous n’ayez besoin de fusionner que dans la hiérarchie (haut et bas de l’arbre de branche) plutôt que dans la hiérarchie. Pour créer des branches dans la hiérarchie, vous devez utiliser une fusion sans base, ce qui nécessite une résolution plus manuelle des conflits.
    • La hiérarchie de branche est basée sur le parent et l'enfant de branche, qui peuvent être différents de la structure physique du code source sur le disque. Lors de la planification de vos fusions, gardez à l'esprit la structure de branche logique plutôt que la structure physique sur le disque.
    • Ne branchez pas trop profondément. Comme il faut du temps pour exécuter chaque fusion et résoudre les conflits, une structure de ramification profonde peut signifier que les modifications dans une branche enfant peuvent prendre beaucoup de temps pour se propager à la branche principale. Cela peut avoir un impact négatif sur les calendriers de projet et augmenter le temps nécessaire pour corriger les bogues.
    • Se branche à un niveau élevé et inclut les fichiers source et de configuration.
    • Faites évoluer votre structure de ramification au fil du temps.
    • La fusion nécessite qu'un ou plusieurs développeurs exécutent la fusion et résolvent les conflits. La source fusionnée doit être minutieusement testée car il n’est pas rare de prendre de mauvaises décisions de fusion susceptibles de déstabiliser la construction.
    • La fusion dans la hiérarchie des branches est particulièrement difficile et vous oblige à gérer manuellement de nombreux conflits qui pourraient autrement être traités automatiquement.  
      La décision de créer une succursale peut être réduite au point de savoir si le coût de la fusion des conflits en temps réel est supérieur aux coûts indirects de la fusion des conflits entre les succursales ...
  • http://kashfarooq.wordpress.com/2009/11/23/bazaar-branching-strategy-with-a-subversion-trunk/

    • http://kashfarooq.wordpress.com/2010/12/16/bazaar-branching-strategy-with-a-subversion-trunk-revised/
    • http://kashfarooq.wordpress.com/2009/11/02/using-bazaar-feature-branches-with-a-subversion-trunk/
    • http://kashfarooq.wordpress.com/2009/09/08/bazaar-or-git-moving-away-from-subversion/
      ... Est-ce que l'une de ces plaintes concernant Subversion vous semble familière?
      • Vous êtes informé au hasard que "vous devez exécuter la mise à jour". Vous effectuez ensuite une mise à jour - qui prend beaucoup de temps. Enfin, vous constaterez qu’aucun changement n’a dû être téléchargé.
      • Vous êtes informé au hasard que "vous devez exécuter le nettoyage".
      • Vous avez d'énormes problèmes de fusion. Par exemple, vous utilisez ReSharper pour renommer une classe, et d’autres ont mis à jour cette classe entre-temps. Vous voyez alors l'erreur de conflit d'arbre redouté (frisson). Ou pire encore, vous renommez un espace de noms complet et un dossier (double frémissement). Maintenant, vous êtes vraiment dans un monde de douleur.
      • Vos fusions ont tendance à être de plus en plus manuelles. Vous devez souvent utiliser WinMerge car Subversion n’a pas la moindre idée.
      • Vous attendez souvent que Tortoise mette à jour / vérifie les modifications / quoi que ce soit.  
         
        J'ai un référentiel de subversion sur ma clé USB. J'ai des conflits d'arbres et je fusionne des problèmes avec ça, et je suis le seul utilisateur!  
         
        Le problème principal est la fusion ...  
         
    • "Subversion est nul" semble familier. Il est temps d'écouter Joel et Linus ?
  • http://social.msdn.microsoft.com/Forums/en/tfsversioncontrol/thread/f127676c-8f05-410c-9a30-0eb43a26a9fa
    discussion sur les meilleures pratiques en matière de stratégie de séparation des libérations dans le cas de systèmes en évolution.

  • http://branchingguidance.codeplex.com/
    "Guide de branchement de Microsoft Team Foundation Server" - document volumineux et détaillé contenant des recommandations adaptées à différents projets: version HTML ici . Preuve que Microsoft ne croit pas en une approche unique pour les stratégies de branchement.

  • https://stackoverflow.com/questions/597707/best-branching-strategy-when-doing-continuous-integration
    Quelle est la meilleure stratégie de branchement à utiliser lorsque vous souhaitez effectuer une intégration continue? ... La réponse dépend de la taille de votre équipe et de la qualité de votre contrôle de source, ainsi que de votre capacité à fusionner correctement des ensembles de modifications complexes ...

  • http://codicesoftware.blogspot.com/2010/03/branching-strategies.html
    ... CVS et SVN décourageaient toute la stratégie de branchement / fusion car ils étaient totalement incapables de le faire ... ... Règle simple: créez une branche de tâche pour chaque nouvelle fonctionnalité ou correction de bug que vous devez implémenter ... Cela peut sembler excessif pour les utilisateurs de SVN / CVS, mais vous savez que tout GDS moderne vous permettra de créer des branches en une seconde, de sorte qu'il n'y a pas de surcharge.  
     
    Remarque importante: si vous l'examinez attentivement, vous constaterez que je parle d'utiliser des branches de tâches en tant que listes de modifications riches ...

  • http://publib.boulder.ibm.com/infocenter/cchelp/v7r0m1/index.jsp?topic=/com.ibm.rational.clearcase.cc_proj.doc/c_bntr_plnbrstrat.htm
    ... La politique de branchement est influencée par le développement objectifs du projet et fournit un mécanisme pour contrôler l’évolution de la base de code. Il existe autant de variantes de stratégie de création de branche que d'organisations utilisant le contrôle de version de Rational ClearCase. Mais il y a aussi des similitudes qui reflètent l'adhésion commune aux meilleures pratiques ...

  • http://blogs.open.collab.net/svn/2007/11/branching-strat.html
    ... Le modèle Subversion (ou le modèle open source général plus précisément) correspond à ce qui est présenté dans le modèle de coffre instable .. .

  • http://en.wikipedia.org/wiki/Trunk_%28software%29
    Dans le domaine du développement logiciel, trunk désigne la branche non nommée (version) d'une arborescence de fichiers sous contrôle de révision . Le tronc est généralement censé être la base d'un projet sur lequel le développement progresse. Si les développeurs travaillent exclusivement sur le coffre, celui-ci contient toujours la dernière version du projet, mais peut aussi être la version la plus instable. Une autre approche consiste à séparer une branche du tronc, à mettre en œuvre des modifications dans cette branche et à les fusionner dans le tronc lorsque la branche s'est avérée stable et opérationnelle. En fonction du mode de développement et du commitpolitique, le coffre peut contenir la version la plus stable, la moins stable ou une version intermédiaire.  
     
    Le travail principal du développeur a souvent lieu dans le coffre et les versions stables sont branchées, et des corrections de bugs occasionnelles sont fusionnées des branches au coffre. Lorsque le développement des versions futures est effectué dans des branches autres que le coffre, il le fait généralement pour des projets qui ne changent pas souvent ou pour lesquels un changement risque de prendre beaucoup de temps à se développer avant de pouvoir être intégré dans le coffre. .

  • http://www.mcqueeney.com/roller/page/tom/20060919
    ... Ce sont les notes d'un webinaire sur les meilleures pratiques de Subversion , mené le 30 août 2006 par CollabNet. ... Deux stratégies organisationnelles: coffre instable ou coffre stable ... ... PREFERER un coffre instable quand c'est possible ...

  • https://stackoverflow.com/questions/153812/subversion-is-trunk-really-the-best-place-for-the-main-development
    Dans SVN, le tronc est l'endroit recommandé pour le développement principal et j'utilise cette convention. pour tous mes projets. Cependant, cela signifie que le tronc est parfois instable, voire cassé ... ... ne serait-il pas préférable de faire le "développement sauvage" sur une branche telle que / branch / dev et de ne fusionner que si le build est raisonnable solide?

    • ... Le tronc est l'endroit où le développement en cours est censé se produire. Vous ne devriez vraiment pas avoir de problème avec le code "cassé", si tout le monde teste ses modifications avant de les valider. En règle générale, faites une mise à jour (obtenez tous les derniers codes des pensions) après avoir codé vos modifications. Ensuite, construisez et faites des tests unitaires. Si tout est construit et fonctionne, vous devriez être prêt à l'enregistrer ...
    • ... Nope trunk n'est pas le meilleur endroit. Au sein de notre organisation, nous suivons toujours cette approche: Trunk contient le code de version, il est donc toujours compilé. Avec chaque nouvelle version / jalon, nous ouvrons une nouvelle branche. Lorsqu'un développeur acquiert un élément, il crée une nouvelle branche dans cette branche de publication et le fusionne dans une branche de version uniquement après l'avoir testé. La branche Release est fusionnée dans le coffre après les tests du système ...
  • http://blog.yclian.com/2009/03/working-on-branches-and-stable-trunk.html
    ... J'avais l'habitude de travailler sur le coffre car pour tous les projets sur lesquels j'ai travaillé, c'est soit le développeur unique ou l'équipe s'est assurée que l'enregistrement de code par tous avait réussi les tests locaux. Sinon, nous avons créé (nous avons toujours) des branches pour la résolution de bugs, un code volumineux pour de nouvelles fonctionnalités, etc. Il y a  
     
    environ 2 mois, j'ai eu une courte session avec Kamal et il m'a partagé l'idée de story / branch . Et alors que mon équipe commençait à se développer avec plus de développeurs, je ressens le besoin d’encourager la création de nouvelles branches et c’est devenu une règle. Pour un projet avec des tests automatisés définis avec la configuration du CI, une jonction stable est garantie et cette pratique peut très bien s’y intégrer.  
     
    Nous n'utilisons pas git mais Subversion parce que c'est comme ça que nous avons commencé et nous sommes toujours à l'aise avec ça maintenant (la plupart du temps) ...

  • http://www.ericsink.com/scm/scm_branches.html
    Ceci fait partie d'un livre en ligne intitulé Source Control HOWTO , un guide des meilleures pratiques en matière de contrôle de code source, de contrôle de version et de gestion de la configuration ...  
     
    ... Eric's Preferred Branching Pratique ... Gardez une malle "fondamentalement instable". Faites votre développement actif dans le coffre dont la stabilité augmente à mesure que vous approchez de la libération. Après la livraison, créez une branche de maintenance et gardez-la toujours très stable ...  
     
    ... Dans le chapitre suivant, je vais aborder le sujet de la fusion de branches ...

  • http://marc.info/?l=forrest-dev&m=112504297928196&w=2
    Courrier de départ du fil de discussion traitant des stratégies de création de branches pour le projet Apache Forrest

    • note actuellement, le projet semble utiliser un modèle de réseau instable avec des branches de version:
    • "Le travail de développement est effectué sur le tronc de SVN ... Il existe des" branches de publication "de SVN, par exemple forrest_07_branch." ( directives du projet )
    • "Construire les packages de version candidate ... 17. Créer une branche de maintenance dans SVN ..." ( Comment publier )
  • Documents de branche CVS O'Reilly:
    http://commons.oreilly.com/wiki/index.php/Essential_CVS/Using_CVS/Tagging_and_Branching#Basically_stable

    • ... La philosophie de branchement fondamentalement stable stipule que le tronc doit contenir des données de projet toujours prêtes à être libérées ... ... Des variantes plus légères de cette philosophie permettent de fusionner tout ce qui passe les tests unitaires de développeur. tronc. Une telle approche assouplie nécessite la dissociation d'un candidat à la publication et son analyse QA complète avant publication ...
    • ... La philosophie, fondamentalement instable, stipule que le tronc doit contenir le code le plus récent, quelle que soit sa stabilité, et que les versions candidates doivent être dérivées pour l'assurance qualité.
       
       
      ... Des variantes plus souples permettent également la création de branches pour le code expérimental, le refactoring et d'autres codes de cas spéciaux. La fusion d'une branche dans le coffre est effectuée par les responsables de la branche. ...
      • Remarque la ressource ci-dessus n'apparaît dans aucune des recherches que j'ai effectuées (les instructions relatives à CVS ne sont plus populaires?)
  • Meilleures pratiques en matière de gestion de la chaîne logistique (article forcé) sur
    http://www.perforce.com/perforce/papers/bestpractices.html
    ... six domaines généraux du déploiement de la gestion de la chaîne logistique, ainsi que des meilleures pratiques générales dans chacun de ces domaines. Les chapitres suivants décrivent chaque élément ...
    Espaces de travail, Lignes de code, Branchement, Propagation des modifications, Générations, Processus ...

moucheron
la source
37
Je crois que c'est la réponse la plus longue que j'ai jamais vue dans une question sur stackexchange!
John Fisher le
2
@JohnFisher bien selon JIRA , à l'époque, j'ai passé 6 heures à compiler et à résumer ces références :)
gnat le
2
Il vous manque une sorte de résumé, qui devrait indiquer s'il faut ou non utiliser de nouvelles branches pour les nouvelles fonctionnalités. Votre réponse est simplement une somme de liens vers divers articles: certains disent une chose, d'autres le contraire. Votre réponse est assez longue, alors je me suis peut-être égaré.
Février
3
@ BЈовић récapitulatif est fourni au début de la réponse: «Il n’existe pas de stratégie de branchement« optimale »convenue d’un commun qui soit applicable à un projet quelconque. * la plupart des ressources semblent s'accorder pour dire que le choix d'une stratégie productive dépend des spécificités du projet »
Mardi
2
Lecture complémentaire: Développement basé sur le tronc de Google vs Facebook "Ils [Google et Facebook] ne sont pas pénalisés par la fusion car, en règle générale, les développeurs ne fusionnent pas vers / depuis des succursales. Au moins jusqu'au serveur du référentiel central, ils ne le sont pas. Sur les stations de travail , les développeurs peuvent être fusionner vers / depuis locales branches et rebasage lorsque quelque chose de poussée qui est « fait » retour au repo central ... »
moucheron
7

Si plusieurs équipes travaillent simultanément sur différentes fonctionnalités, vous ne pouvez pas omettre de créer des branches. Vous devez partager le code (partiellement implémenté) avec les membres de l’équipe, afin d’empêcher les autres équipes d’obtenir vos fonctionnalités non terminées.

Les branches sont le moyen le plus simple d'y parvenir.

Bien qu'il soit bon de raccourcir le cycle de vie des branches et d'éviter de travailler sur le même module dans deux branches en même temps, vous n'aurez alors aucun conflit ni aucun problème de fusion.

Shaddix
la source
5

Mais récemment, je vois de plus en plus d'adeptes de l'idée de ne pas créer de branche car il est plus difficile de pratiquer l'intégration continue, la livraison continue, etc.

Eh bien , il ne fait plus difficile à pratiquer l' intégration continue, la livraison continue, etc pour vous concrètement?

Sinon, je ne vois aucune raison de changer votre façon de travailler.

Bien sûr, il est de bonne pratique de suivre ce qui se passe et comment évoluent les meilleures pratiques actuelles. Mais je ne pense pas que nous devions abandonner nos processus / outils / autres, simplement parce que X (et / ou Y et / ou Z) ont déclaré ne plus être à la mode :-)

Péter Török
la source
Bien sûr que si! C'est la question des priorités: branchement (isolation des fonctionnalités) vs intégration facile, livraison, etc.
SiberianGuy le
1
c'est juste une question d'outil de CI que vous utilisez. Qu'est-ce qui vous empêche de construire et de "livrer en continu" depuis une branche?
Shaddix
@Shaddix, il est généralement difficile de livrer depuis une succursale. Par exemple, comment livriez-vous à partir d'une branche de fonctionnalité?
SibérieGuy
1
Quel est le problème, si vous avez tout le code source ramifié (comme dans DVCS)?
Shaddix
1
@Shaddix, plus vous avez de branches, plus vous aurez de conflits lors de la fusion
SiberianGuy le
4

Quel ensemble de réponses intéressant. En plus de 20 ans, je n'ai jamais travaillé dans une entreprise qui utilisait plus qu'un simple usage de succursale (généralement juste pour les versions de succursale).

La plupart des endroits où j'ai travaillé comptent sur des enregistrements assez rapides et sur une détection / résolution rapide des collisions - la méthodologie Agile enseigne que vous pouvez résoudre les problèmes plus rapidement si vous les remarquez pendant que les deux parties réfléchissent activement à cet élément de code.

D'un autre côté, je n'ai pas beaucoup utilisé git et c'est peut-être l'inclusion de la balise git qui a influencé ces réponses - je comprends que branche / fusion est une donnée avec git parce que c'est tellement facile.

Bill K
la source
2
+1, Ces dunns git'er sont de plus en plus fanatiques de la supériorité discutable de git par rapport aux autres configurations de contrôle de version / CI.
maple_shaft
3

Oui, vous devriez utiliser des branches pour isoler tout effort de développement (au moins moyen). Voir " Quand devriez-vous créer une branche? ".

Le problème consiste davantage à utiliser des fusions à avance rapide (qui incluent un historique de branche dans un autre), à ​​condition que vous supprimiez d’abord tous les "validations de points de contrôle intermédiaires" (ce qui peut poser problème en cas de retour en arrière ou git bisect).
Voir " Présentation du flux de travail Git ", afin de distinguer les branches privées (non poussées) des branches publiques, qui seront complétées par des fusions ff (fusions rapides) à condition que vous effectuiez le nettoyage nécessaire dans la branche que vous fusionnez. .
Voir aussi " Pourquoi git utilise-t-il la fusion rapide par défaut? ".

VonC
la source
2

Vous devez absolument utiliser des branches. Cela comporte un certain nombre de points forts.

  • Vous pouvez enregistrer votre travail au fur et à mesure si vous craignez de perdre du travail en raison d'une défaillance de la HD, d'une perte d'ordinateur portable, etc., sans que cela ne casse le CI principal.
  • Vous pouvez toujours faire un CI, il vous suffit de configurer votre propre CI local pour surveiller votre branche.
  • Si la fonctionnalité est soudainement mise en attente (cela ne se produit jamais), vous pouvez simplement la garer.

Trop dur n'est jamais une excuse. Il faut toujours plus d'efforts pour bien faire les choses.

Bill Leeper
la source
2
Je ne veux pas que cela découle du fait que je suis contre le branchement, mais parce que vous suggérez qu’ils doivent être utilisés TOUT LE TEMPS.
maple_shaft
Où l'a-t-il dit, l'a-t-il édité ou quelque chose d'autre?
b01
configurez votre propre CI local pour surveiller votre agence pour les agences de courte durée (2 à 5 jours), ce qui peut être assez fastidieux. Là fait que
moucheron
1
Je répondais à la question d'utiliser des branches en général ou de ne jamais utiliser de branches. Comme pour toute règle ou politique, un bon jugement doit entrer en jeu. Je ne collabore pas à beaucoup de mes projets, mais je continue à utiliser les branches de manière libérale, principalement pour la troisième puce que j'ai mentionnée. De même que pour la première puce, combien de fois avez-vous reçu une demande urgente pour obtenir une fonctionnalité / un correctif en direct, mais ensuite vous entrez et vous avez environ 3 fonctionnalités à moitié finies dans master.
Bill Leeper
Cela ne fait pas CI. I in CI est synonyme d'intégration - intégrant le travail de tous les développeurs, c'est-à-dire la fusion. Rien de mal à exécuter des tests localement pour chaque commit, mais c'est la même chose.
bdsl
2

Si deux équipes travaillent sur leur propre branche, elles ne verront pas les changements de l’autre équipe, même si les deux équipes intègrent la masterbranche. Cela signifierait que leurs branches de développement se sépareraient et si l'une des équipes se confondait master, l'autre équipe devait rebaser beaucoup de changements.

Ainsi, même si vous avez des branches pour les fonctionnalités, je vous exhorte à effectuer des "backports" de tous les refactorisations vers la branche principale et à ne conserver la branche que pour les nouvelles fonctionnalités.

  • Refactorings de backport

Je pense que parfois, il peut être plus facile d’utiliser des commutateurs de fonctionnalités pour désactiver de nouvelles fonctionnalités non testées qui ne devraient pas encore être mises en production. De cette façon, toutes les autres équipes verront les changements et aucune fusion majeure ne doit avoir lieu.

  • Utiliser les commutateurs
flob
la source
2

Nous venons de traverser (encore une fois). Tout d’abord, nous avons eu l’ensemble du débat GIT / SVN, qui nous a conduits à adopter des stratégies de ramification en général.

Les grandes entreprises utilisent toutes une stratégie basée sur le tronc, dans laquelle tout le monde travaille dans la même branche, et où l’intégration et la construction se font à partir de cette branche. On évite les conflits en utilisant la modularisation du code, la commutation des fonctionnalités et un outillage intelligent. Cela semble difficile .. parce que c'est. Mais si vous tenez ce débat, c'est parce que vous êtes victime des fantasmes des gens sur la création de branches. Certains affirment utiliser l’ outil Insert SCM avec un mécanisme de branchement de promotion entièrement conforme à sarbanes-oxley, et c’est génial. Ils sont soit en train de mentir, de se leurrer, soit de ne pas travailler sur la même échelle de système que vous.

La ramification et la fusion est difficile. Surtout si vous avez une entreprise qui change régulièrement d'avis, qui exige des retours en arrière, etc.

Cette phrase peut vous sauver la vie: Ce qui est dans le SCM n’est pas le même que ce qui est dans vos artefacts construits!

Si vous rencontrez des problèmes avec la création de branches, c’est parce que vous utilisez mal votre SCM. Nous le faisons tous depuis des années. Vous avez un système en place où le SMC est utilisé pour déterminer ce qui va dans votre version finale.

Ce n'est pas le travail du SMC. Le SCM est un serveur de fichiers glorifié. La tâche de déterminer quels fichiers de votre GDS vont dans votre construction appartient à vos outils de construction.

Le module A est en cours d’élaboration et entre dans votre publication hebdomadaire. Le module B est le module A mais contient le projet X et fait actuellement l'objet de travaux dans la même branche, mais n'est pas intégré à votre version. À un moment donné, vous souhaitez publier le projet X. Vous devez donc indiquer à votre outil de construction de cesser d'installer le module A et de commencer à installer le module B.

Il y aura beaucoup de pleurs et de se tordre les mains à ce sujet. Quelle histoire, et hurlement général. Tel est le niveau d'émotion qui entoure quelque chose d'aussi simple qu'un référentiel de fichiers, aussi intelligent qu'il soit.

Mais voici ta réponse.

Richard
la source
1

Le principal problème de la création de branches est la difficulté de réintégrer la branche principale une fois le développement terminé. La fusion peut être un processus manuel et sujet aux erreurs, elle doit donc être évitée la plupart du temps.

Certaines exceptions notables où je préfère créer des branches sont une refactorisation massive, des fonctionnalités géantes dont le développement prend plus de temps qu'un sprint, ou des fonctionnalités perturbatrices qui interrompraient le développement d'autres fonctionnalités pendant la majeure partie de ce sprint.

arbre_érable
la source
4
On dirait que vous avez besoin d’une meilleure pratique pour développer de nouvelles fonctionnalités. Personnellement, j'aime bien construire mes projets dans le sens où il est facile d'isoler les fonctionnalités, généralement dans un fichier / classe / ou un autre fichier. De cette façon, l'ajout ou la suppression de code n'entraîne aucune perturbation majeure dans la livraison ni lors de la fusion de nouveau code ou de l'extraction de l'ancien code. Cela fonctionne également bien lors du développement avec plusieurs développeurs. Mais je peux comprendre si vous travaillez sur un projet que vous n'avez peut-être pas démarré, ou que vous n'avez pas de mot à dire, donc sur la façon dont le projet se poursuit.
b01
1
@ B01, c'est à peu près parfait. Personne ne peut proposer un design parfait lorsque les exigences vont et viennent et changent plus rapidement qu'un enfant TDAH sur crack. D'autres fois, vous essayez de modifier le code hérité pour améliorer la conception et cette situation se reproduit de temps en temps. Ce n’est pas le pire problème qu’une équipe puisse avoir, et c’est un cri bien meilleur que certains endroits dans lesquels j’ai travaillé, où même suggérer de refactoriser une réunion vous fera battre à mort avec une batte de baseball comme une scène de The Untouchables.
maple_shaft
Totalement en désaccord. Si vous vous séparez par branches de qualité et que vous effectuez des fusions fréquemment (quotidiennement, c'est bien), vous éviterez ainsi presque toutes les fusions "manuelles et sujettes aux erreurs".
Paul Nathan
@ Paul, faites-moi confiance, cela ne fonctionne pas pour tous les projets ou toutes les technologies. Pensez à un fichier de configuration XML commun, comme dans Struts, où tout le monde y trempe ses mains tous les jours. Mais non, votre chemin fonctionne tout le temps et j'ai totalement mérité le vote négatif. Merci.
maple_shaft
1
@maple_shaft meta-hint, si vous considérez les balises (git) et postez quelque chose que l'utilisateur type de ces balises considérerait comme négatif, attendez-vous à des votes négatifs infimes. Les flybys sont presque toujours une réaction injustifiée à se faire mal au cœur par certains commentaires que vous prenez personnellement. Considérez que c'est bon parce que cela augmente votre réputation à travers le toit.
Bill K
1

Je recommande ce type de schéma de branche:

release - test - développement

Puis du développement, branche par développeur et / ou par fonctionnalité.

Les développeurs ont chacun une branche avec laquelle jouer et fusionner, puis entrer dans la branche de développement de manière routinière - idéalement chaque jour (à condition de la compiler).

Ce type de schéma fonctionne très bien avec beaucoup de développeurs et plusieurs projets sur la même base de code.

Paul Nathan
la source
0

Nous faisons utiliser des branches, mais pas au niveau granulaire de fonction. Nous utilisons des branches pour chaque sprint. La création de branches en substance n’est pas une mauvaise chose pour IMO, car elle simule le concept de SOC dans l’entité, ou couche de sprint. Vous pouvez facilement reconnaître et gérer quelle branche appartient à quelle fonctionnalité ou à quel sprint.

IMHO, alors la réponse est OUI . Nous devrions toujours utiliser les branches.

Saeed Neamati
la source
0

Le processus de mon organisation utilise beaucoup de branches et (processus qui ressemble un peu) une intégration continue.

Dans une vue globale, les développeurs ne s'inquiètent pas trop de la fusion avec Mainline, ils s'engagent simplement dans la branche. un processus (semi-) automatisé vérifie quelles fonctionnalités sont programmées pour être intégrées à Mainline, fusionne ces branches et construit le produit. Le processus fonctionne, car nous intégrons ce processus de fusion à partir du suivi des problèmes, de sorte que l'outil de génération sache quelles branches fusionner.

SingleNegationElimination
la source
Ce processus semble se rompre si un développeur a restructuré du code préexistant sur une branche et qu'un développeur d'une branche distincte a écrit quelque chose qui s'appuie sur l'ancienne version du code.
bdsl
@bdsl: c'est un problème qui peut survenir dans n'importe quelle stratégie de branchement (y compris le non-branchement), chaque fois que plusieurs développeurs se trouvent dans la même base de code. dans cette organisation (je suis passé depuis), nous formions une équipe assez petite pour que nous puissions tous avoir une assez bonne idée de ce que le reste d'entre nous préparait. en conflit. En tout état de cause, l'intégration continue a beaucoup aidé à résoudre ce type de problèmes quelques minutes ou quelques heures après le début du conflit.
SingleNegationElimination
Oui, mais cela semble beaucoup moins probable si la refactorisation est fusionnée dans Mainline le jour même, plutôt que d’attendre qu’une nouvelle fonctionnalité soit prête.
bdsl
@bdsl ce n'est pas toujours une option; vous aurez peut-être besoin d’une "branche en bon état de marche" à tout moment, par exemple pour envoyer des corrections de bugs d’urgence. La technique alternative, qui fusionne régulièrement la ligne principale dans la fonction, est généralement OK, et constitue une recommandation forte, quelle que soit votre stratégie de création de branche.
SingleNegationElimination