diff options
| author | Ciro Santilli <ciro.santilli@gmail.com> | 2014-12-27 21:43:43 +0100 | 
|---|---|---|
| committer | Ciro Santilli <ciro.santilli@gmail.com> | 2014-12-27 21:43:43 +0100 | 
| commit | 05a6115bc8f9ae3e3b41a155334adb6f73d5a0cc (patch) | |
| tree | 2b22328c8327de8167911bce899bb1707b62a319 /doc/workflow | |
| parent | c8bb171664de94778d4e6eba7773596b265f9efb (diff) | |
| download | gitlab-ce-05a6115bc8f9ae3e3b41a155334adb6f73d5a0cc.tar.gz | |
doc workflow markdown style
- add h1 to README
- move h1 in workflow.md to h2 since the top image acts as h1
- typos
Diffstat (limited to 'doc/workflow')
| -rw-r--r-- | doc/workflow/README.md | 2 | ||||
| -rw-r--r-- | doc/workflow/gitlab_flow.md | 42 | 
2 files changed, 23 insertions, 21 deletions
| diff --git a/doc/workflow/README.md b/doc/workflow/README.md index c26d85e9955..f0e0f51b1ac 100644 --- a/doc/workflow/README.md +++ b/doc/workflow/README.md @@ -1,3 +1,5 @@ +# Workflow +  - [Workflow](workflow.md)  - [Project Features](project_features.md)  - [Authorization for merge requests](authorization_for_merge_requests.md) diff --git a/doc/workflow/gitlab_flow.md b/doc/workflow/gitlab_flow.md index f8fd7c97e2a..1dbff60cbfd 100644 --- a/doc/workflow/gitlab_flow.md +++ b/doc/workflow/gitlab_flow.md @@ -1,6 +1,6 @@   -# Introduction +## Introduction  Version management with git makes branching and merging much easier than older versioning systems such as SVN.  This allows a wide variety of branching strategies and workflows. @@ -29,9 +29,9 @@ People have a hard time figuring out which branch they should develop on or depl  Frequently the reaction to this problem is to adopt a standardized pattern such as [git flow](http://nvie.com/posts/a-successful-git-branching-model/) and [GitHub flow](http://scottchacon.com/2011/08/31/github-flow.html)  We think there is still room for improvement and will detail a set of practices we call GitLab flow. -# Git flow and its problems +## Git flow and its problems -[ +[  Git flow was one of the first proposals to use git branches and it has gotten a lot of attention.  It advocates a master branch and a separate develop branch as well as supporting branches for features, releases and hotfixes. @@ -50,7 +50,7 @@ Frequently developers make a mistake and for example changes are only merged int  The root cause of these errors is that git flow is too complex for most of the use cases.  And doing releases doesn't automatically mean also doing hotfixes. -# GitHub flow as a simpler alternative +## GitHub flow as a simpler alternative   @@ -62,13 +62,13 @@ Merging everything into the master branch and deploying often means you minimize  But this flow still leaves a lot of questions unanswered regarding deployments, environments, releases and integrations with issues.  With GitLab flow we offer additional guidance for these questions. -# Production branch with GitLab flow +## Production branch with GitLab flow    GitHub flow does assume you are able to deploy to production every time you merge a feature branch.  This is possible for SaaS applications but are many cases where this is not possible. -One would be a situation where you are not in control of the exact release moment, for example an iOS application that needs to pass AppStore validation. +One would be a situation where you are not in control of the exact release moment, for example an iOS application that needs to pass App Store validation.  Another example is when you have deployment windows (workdays from 10am to 4pm when the operations team is at full capacity) but you also merge code at other times.  In these cases you can make a production branch that reflects the deployed code.  You can deploy a new version by merging in master to the production branch. @@ -78,7 +78,7 @@ This time is pretty accurate if you automatically deploy your production branch.  If you need a more exact time you can have your deployment script create a tag on each deployment.  This flow prevents the overhead of releasing, tagging and merging that is common to git flow. -# Environment branches with GitLab flow +## Environment branches with GitLab flow   @@ -93,7 +93,7 @@ If master is good to go (it should be if you a practicing [continuous delivery](  If this is not possible because more manual testing is required you can send merge requests from the feature branch to the downstream branches.  An 'extreme' version of environment branches are setting up an environment for each feature branch as done by [Teatro](http://teatro.io/). -# Release branches with GitLab flow +## Release branches with GitLab flow   @@ -109,7 +109,7 @@ Every time a bug-fix is included in a release branch the patch version is raised  Some projects also have a stable branch that points to the same commit as the latest released branch.  In this flow it is not common to have a production branch (or git flow master branch). -# Merge/pull requests with GitLab flow +## Merge/pull requests with GitLab flow   @@ -134,7 +134,7 @@ If the assigned person does not feel comfortable they can close the merge reques  In GitLab it is common to protect the long-lived branches (e.g. the master branch) so that normal developers [can't modify these protected branches](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/doc/permissions/permissions.md).  So if you want to merge it into a protected branch you assign it to someone with master authorizations. -# Issues with GitLab flow +## Issues with GitLab flow   @@ -168,7 +168,7 @@ In this case it is no problem to reuse the same branch name since it was deleted  At any time there is at most one branch for every issue.  It is possible that one feature branch solves more than one issue. -# Linking and closing issues from merge requests +## Linking and closing issues from merge requests   @@ -181,7 +181,7 @@ If you only want to make the reference without closing the issue you can also ju  If you have an issue that spans across multiple repositories, the best thing is to create an issue for each repository and link all issues to a parent issue. -# Squashing commits with rebase +## Squashing commits with rebase   @@ -189,7 +189,7 @@ With git you can use an interactive rebase (rebase -i) to squash multiple commit  This functionality is useful if you made a couple of commits for small changes during development and want to replace them with a single commit or if you want to make the order more logical.  However you should never rebase commits you have pushed to a remote server.  Somebody can have referred to the commits or cherry-picked them. -When you rebase you change the identifier (SHA1) of the commit and this is confusing. +When you rebase you change the identifier (SHA-1) of the commit and this is confusing.  If you do that the same change will be known under multiple identifiers and this can cause much confusion.  If people already reviewed your code it will be hard for them to review only the improvements you made since then if you have rebased everything into one commit. @@ -207,7 +207,7 @@ If you revert a merge and you change your mind, revert the revert instead of mer  Being able to revert a merge is a good reason always to create a merge commit when you merge manually with the `--no-ff` option.  Git management software will always create a merge commit when you accept a merge request. -# Do not order commits with rebase +## Do not order commits with rebase   @@ -231,8 +231,8 @@ The last reason for creating merge commits is having long lived branches that yo  Martin Fowler, in [his article about feature branches](http://martinfowler.com/bliki/FeatureBranch.html) talks about this Continuous Integration (CI).  At GitLab we are guilty of confusing CI with branch testing. Quoting Martin Fowler: "I've heard people say they are doing CI because they are running builds, perhaps using a CI server, on every branch with every commit.  That's continuous building, and a Good Thing, but there's no integration, so it's not CI.". -The solution to prevent many merge commits is to keep your feature branches shortlived, the vast majority should take less than one day of work. -If your feature branches commenly take more than a day of work, look into ways to create smaller units of work and/or use [feature toggles](http://martinfowler.com/bliki/FeatureToggle.html). +The solution to prevent many merge commits is to keep your feature branches short-lived, the vast majority should take less than one day of work. +If your feature branches commonly take more than a day of work, look into ways to create smaller units of work and/or use [feature toggles](http://martinfowler.com/bliki/FeatureToggle.html).  As for the long running branches that take more than one day there are two strategies.  In a CI strategy you can merge in master at the start of the day to prevent painful merges at a later time.  In a synchronization point strategy you only merge in from well defined points in time, for example a tagged release. @@ -244,7 +244,7 @@ Developing software happen in small messy steps and it is OK to have your histor  You can use tools to view the network graphs of commits and understand the messy history that created your code.  If you rebase code the history is incorrect, and there is no way for tools to remedy this because they can't deal with changing commit identifiers. -# Voting on merge requests +## Voting on merge requests   @@ -252,7 +252,7 @@ It is common to voice approval or disapproval by using +1 or -1 emoticons.  In GitLab the +1 and -1 are aggregated and shown at the top of the merge request.  As a rule of thumb anything that doesn't have two times more +1's than -1's is suspect and should not be merged yet. -# Pushing and removing branches +## Pushing and removing branches   @@ -266,7 +266,7 @@ This ensures that the branch overview in the repository management software show  This also ensures that when someone reopens the issue a new branch with the same name can be used without problem.  When you reopen an issue you need to create a new merge request. -# Committing often and with the right message +## Committing often and with the right message   @@ -282,7 +282,7 @@ Some words that are bad commit messages because they don't contain munch informa  The word fix or fixes is also a red flag, unless it comes after the commit sentence and references an issue number.  To see more information about the formatting of commit messages please see this great [blog post by Tim Pope](http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html). -# Testing before merging +## Testing before merging   @@ -299,7 +299,7 @@ If there are no merge conflicts and the feature branches are short lived the ris  If there are merge conflicts you merge the master branch into the feature branch and the CI server will rerun the tests.  If you have long lived feature branches that last for more than a few days you should make your issues smaller. -# Merging in other code +## Merging in other code   | 
