Go with the Git flow

9 minutes
Share the link to this page
Copied
  Completed
You need to have access to the item to view this lesson.
One-time Fee
$49.99
List Price:  $69.99
You save:  $20
€46.40
List Price:  €64.96
You save:  €18.56
£39.83
List Price:  £55.77
You save:  £15.93
CA$68.34
List Price:  CA$95.68
You save:  CA$27.34
A$75.73
List Price:  A$106.02
You save:  A$30.29
S$67.43
List Price:  S$94.41
You save:  S$26.98
HK$390.55
List Price:  HK$546.80
You save:  HK$156.25
CHF 45.24
List Price:  CHF 63.34
You save:  CHF 18.10
NOK kr543.62
List Price:  NOK kr761.11
You save:  NOK kr217.49
DKK kr346.42
List Price:  DKK kr485.02
You save:  DKK kr138.59
NZ$83.15
List Price:  NZ$116.42
You save:  NZ$33.26
د.إ183.60
List Price:  د.إ257.06
You save:  د.إ73.45
৳5,471.12
List Price:  ৳7,660.01
You save:  ৳2,188.88
₹4,168.17
List Price:  ₹5,835.78
You save:  ₹1,667.60
RM236.95
List Price:  RM331.75
You save:  RM94.80
₦61,737.65
List Price:  ₦86,437.65
You save:  ₦24,700
₨13,868
List Price:  ₨19,416.31
You save:  ₨5,548.31
฿1,837.56
List Price:  ฿2,572.74
You save:  ฿735.17
₺1,617.36
List Price:  ₺2,264.43
You save:  ₺647.07
B$254.77
List Price:  B$356.70
You save:  B$101.93
R925.26
List Price:  R1,295.44
You save:  R370.18
Лв90.75
List Price:  Лв127.05
You save:  Лв36.30
₩67,788.68
List Price:  ₩94,909.58
You save:  ₩27,120.90
₪185.35
List Price:  ₪259.50
You save:  ₪74.15
₱2,852.60
List Price:  ₱3,993.87
You save:  ₱1,141.27
¥7,651.21
List Price:  ¥10,712.31
You save:  ¥3,061.10
MX$848.45
List Price:  MX$1,187.89
You save:  MX$339.44
QR181.83
List Price:  QR254.57
You save:  QR72.74
P679.12
List Price:  P950.82
You save:  P271.70
KSh6,605.16
List Price:  KSh9,247.76
You save:  KSh2,642.59
E£2,394.23
List Price:  E£3,352.12
You save:  E£957.88
ብር2,861.57
List Price:  ብር4,006.43
You save:  ብር1,144.85
Kz41,791.64
List Price:  Kz58,511.64
You save:  Kz16,720
CLP$47,104.79
List Price:  CLP$65,950.47
You save:  CLP$18,845.68
CN¥361.78
List Price:  CN¥506.53
You save:  CN¥144.74
RD$2,896.80
List Price:  RD$4,055.76
You save:  RD$1,158.95
DA6,728.30
List Price:  DA9,420.16
You save:  DA2,691.86
FJ$112.64
List Price:  FJ$157.70
You save:  FJ$45.06
Q387.49
List Price:  Q542.52
You save:  Q155.02
GY$10,429.06
List Price:  GY$14,601.52
You save:  GY$4,172.46
ISK kr6,974.05
List Price:  ISK kr9,764.23
You save:  ISK kr2,790.17
DH502.81
List Price:  DH703.98
You save:  DH201.16
L883.05
List Price:  L1,236.34
You save:  L353.29
ден2,855.97
List Price:  ден3,998.59
You save:  ден1,142.61
MOP$401.24
List Price:  MOP$561.77
You save:  MOP$160.53
N$922.79
List Price:  N$1,291.99
You save:  N$369.19
C$1,835.15
List Price:  C$2,569.36
You save:  C$734.20
रु6,656.11
List Price:  रु9,319.09
You save:  रु2,662.97
S/186.09
List Price:  S/260.54
You save:  S/74.45
K192.70
List Price:  K269.79
You save:  K77.09
SAR187.49
List Price:  SAR262.50
You save:  SAR75.01
ZK1,344.69
List Price:  ZK1,882.68
You save:  ZK537.98
L230.99
List Price:  L323.40
You save:  L92.41
Kč1,163.34
List Price:  Kč1,628.77
You save:  Kč465.43
Ft18,074.53
List Price:  Ft25,305.79
You save:  Ft7,231.25
SEK kr539.27
List Price:  SEK kr755.02
You save:  SEK kr215.75
ARS$43,903.33
List Price:  ARS$61,468.17
You save:  ARS$17,564.84
Bs345.22
List Price:  Bs483.33
You save:  Bs138.11
COP$194,164.52
List Price:  COP$271,845.87
You save:  COP$77,681.34
₡25,478.72
List Price:  ₡35,672.25
You save:  ₡10,193.53
L1,231.47
List Price:  L1,724.16
You save:  L492.69
₲373,200.63
List Price:  ₲522,510.75
You save:  ₲149,310.11
$U1,910.59
List Price:  $U2,674.97
You save:  $U764.38
zł200.97
List Price:  zł281.37
You save:  zł80.40
Already have an account? Log In

Transcript

It is by far the most popular version control system out there. In this chapter we will be looking at a plugin for gate called get flow, which proposes a branching model for software projects. This branching model doesn't offer much help when it comes to small projects, but medium size and large projects have a lot to benefit from it. We will be looking at a variation of the get flow plugin called lead flow avh which adds extra functionality like get hooks. To install it, we will follow the instructions on the GitHub page. We are on Ubuntu so we will follow the installation instructions for Linux.

We can see that it can be directly installed from a with the apt command but usually apt does not contain the latest version of the software. So today we will do a manual installation. We want to pick the stable version and use the one line command Let's create an empty directory and initialize it as a get repository. Basic get use it is not the purpose of this course, we are assuming that you understand the basics. A good way to get started with good flow is to read the excellent cheat sheet created by Daniel Kumar. This provides the basic tips and tricks to get you started quickly with a program.

So the first thing that he suggests is to run get flow in it. To configure it, we actually answer a bunch of questions about what names the branches should have in each flow. And what is the version tag prefix and hooks directory. Let's just leave the defaults in. All right, if we run get branch We can see that we are now on the developer side. So no more developing on the master branch.

This helps us have a stable master. While not so stable features are kept on the development branch. If we go back to the cheat sheet, we can look at the first item which is feature branch. feature branches are useful when developing a specific part of functionality, or doing refactoring. But you don't want to break the existing functionality on the develop branch. To create a feature branch, just run, get flow feature start feature one.

Now this is not the most intuitive description of the feature, but it's good for demonstration purposes. Good flow will also show us a summary of actions once the feature branch is finished. This has created a new branch called feature slash feature one based on this Develop branch and has switched us to that branch. We can also see this from our handy virtual prompt. Let's open up a file, edit and save it. It status.

This command will tell us that we have an uncommitted file. Let's go ahead and commit it. Now get committed using the nano editor for editing the commit message. Since we prefer vim, let's go ahead and change the default editor to be all we need to do is to add the sign in our shell config file and reload it. export the return equal view. Now when we do a git commit, vim opens up shows us a summary of the commit and closes.

Now let's assume that we are we finished adding feature it's time to merge the feature branch back to develop with get flow feature finish feature one. Again, to get the summary of actions, the feature branch was merged back to develop, then the feature branch has been deleted that the current branch will be switched back to develop. If we do a LS we see the file from our branch present on the develop branch. Looking at the cheat sheet, we see a graphical representation of this process. Next up is starting release. Release branches are good for stopping the incoming features and bugs bug fixes from the development and testing the current version, submitting bug fixes on it and releasing it to the general public.

As we can see, the syntax is similar the process is similar the Develop is branched to our list branch. And when it comes to finishing the branch, the features are also merged to the master branch and the tag is cut from this branch. Time to see it in action. Oh, okay, this switches us over to release slash 1.0 point oh branch. Let's add our release notes dot txt to show what has changed in this release. I added more bugs, hopefully not to let's commit the file.

This is usually the case when you start to run your integration and stress testing to see if all is good and no bugs were found. After the testing is finished, we go ahead and finish our release branch. is good will prompt us for a series of release messages where we will Go with the default. Checking out the summary we can see that the release branch was merged into Master, a tag was cut from Master with the release version. That tag has also been merged into develop, the release branch has been deleted. And we're back on the develop branch.

If we do a get branch, we see the only two available branches are master and develop. Get tag tells us that there is a 1.0 point oh tag cut. We can see that the branch now contains two files from the merge of the feature and release branch. And if you also switch to the master branch, we can see that at this point master is an exact replica of develop, get flow. One has more workflows than the ones presented. We won't go through all of them today.

You can get extra information by visiting the cheat sheet page or by reading the instructions on the GitHub page. Get flow also comes with an enhanced hooks functionality. If you read the documentation, we can see all the possible hooks in the hooks folder. Let's add a gate hook that will be executed before every hotfix branch. For this, we just opened the template, copy the content and paste it to a file with the name pre flow hotfix. Start in our hooks directory.

Let's just simply echo a message with the version and origin. If we look at the hotfix flow, we can see they are created from the master branch and merge back to master and develop with the tag on master. Let's try and see how it works. Apparently not something went wrong or script was not executed and we need to delete our branch. Then we just do our get flow hotfix delete branch analyzing the get hooks directory, we see that our hook does not have execute permission. After adding execute permissions and running the get hook command again we can see our message on the top of the hotfix output.

Let's finish this hotfix with get flow hotfix finished 101 Okay, as you can see the commands are pretty straightforward. There is also an Omi is a shell plugin that you can activate to have command line completion. As we said in the beginning, this is a plugin suitable for teams of developers working on multiple features fixing bugs, releasing hot fixes, all of these in the same time. Get flow is really simple to learn and helps teams have a correct To workflow where they can easily prepare patches for production code without worrying about the extra functionalities developed on the master branch. You can tweak the config as you like. Some people prefer to place the hooks folder in a different place so that it is committed on the heat rebel and they don't have to worry about copying the files over.

Others continue to develop on the master branch and use a separate branch like customer for the production code.

Sign Up

Share

Share with friends, get 20% off
Invite your friends to LearnDesk learning marketplace. For each purchase they make, you get 20% off (upto $10) on your next purchase.