-
Notifications
You must be signed in to change notification settings - Fork 15
Modelo de ramificação (Branch)
Modelo baseado em http://nvie.com/posts/a-successful-git-branching-model/
Existem dois branchs principais que possuem ciclo de vida infinito e são paralelos entre si, origin/master
e origin/develop
- Consideramos
master
como o branch principal onde o código fonte sempre reflete um estado pronto para produção. - Consideramos
develop
como o branch principal onde o código fonte sempre reflete um estado com as últimas mudanças de desenvolvimento entregues para uma próximoa versão.
Quando o código fonte no develop
atinge um ponto estável e está pronto para ser liberado, todas as alterações devem ser mergeadas no master
de alguma forma, e em seguida, entiquetadas com o número da versão.
Ao lado dos branchs principais o nosso modelo de desenvolvimento utiliza alguns branchs de apoio que servem para auxiliar o desenvolvimento paralelo entre equipes, facilitar o rastreamento de recursos, preparar releases para produção e ajudar a corrigir rapidamente problemas em produção, ao contrário dos branchs principais esses branchs possuem um ciclo de vida finito, e deve ser removido eventualmente.
Os diferentes tipos de branch de apoio são:
- Feature branches
- Release branches
- Hotfix branches
- Deve se ramificar de: develop
- Deve fundir com: develop
- Nomenclatura padrão: Qualquer nome exceto, master, develop, hotfix-* e release-*
São utilizadas para desenvolvimento de novos recursos, para a próxima versão ou uma versão futura, ao iniciar o desenvolvimento de um recurso a versão em que este será incorporado pode ser desconhecida. A idéia do feature branch é que ele exista enquanto o recurso estiver em desevolvimento, ao fim ele é mesclado em develop
(para adicionar definitivamente o novo recurso a próxima versão) ou descartado (quando recurso não funciona).
-
Deve se ramificar de:
develop
-
Deve fundir com:
develop
emaster
-
Nomenclatura padrão:
release-*
São utilizados para a preparação de uma nova versão de produção, eles permitem pequenas correções de bugs e preparação de meta-dados para uma versão (número de versão, data de compilação, etc), ao fazer esse trabalho neste branch, o branch principal develop
é liberado para receber recursos de uma próxima grande versão.
O grande momento de criação deste branch é quando o desenvolvimento (quase) reflete o estado desejado da nova versão, pelo menos todos os recursos direcionados para nova versão devem está mesclados em develop
neste momento, todos os recursos direcionados para lançamentos futuros, devem esperar este branch ser criado para que possam ser mesclados em develop