Our development team has been using the GitFlow branching strategy and it has been great !
Recently we recruited a couple testers to improve our software quality. The idea is that every feature should be tested/QA by a tester.
In the past, developers work on features on separate feature branches and merge them back to the develop branch when done. The developer will test his work himself on that feature branch. Now with testers, we start asking this Question
On which branch should the tester test new features ?
Obviously, there are two options:
- on the individual feature branch
- on the
developbranch
Testing On Develop Branch
Initially, we believed this is the sure way to go because:
- The feature is tested with all other features merged to the
developbranch since it's development started. - Any conflicts can be detected earlier than later
- It makes the tester's job easy, he is only dealing with one branch (
develop) at all time. He doesn't need to ask the developer about which branch is for which feature ( feature branches are personal branches managed exclusively and freely by relevant developers )
The biggest problems with this is:
The
developbranch is polluted with bugs.When the tester finds bugs or conflicts, he reports them back to the developer, who fixes the issue on the develop branch (the feature branch were abandoned once merged ), and there could be more fixes required afterward. Multiple subsequence commits or merges (if a branch is recreated off
developbranch again for fixing the bugs) makes rolling back the feature from thedevelopbranch very difficult if possible. There are multiple features merging to and being fixed on thedevelopbranch at different times. This creates a big issue when we want to create a release with just some of the features in thedevelopbranch
Testing On Feature Branch
So we thought again and decided we should test features on the feature branches. Before we test, we merge the changes from the develop branch to the feature branch ( catch up with the develop branch ). This is good:
- You still test the feature with other features in the mainstream
- Further development ( e.g. bug fix, resolving conflict ) will not pollute the
developbranch; - You can easily decide not to release the feature until it is fully tested and approved;
However, there are some drawbacks
- The tester has to do the merging of the code, and if there's any conflict (very likely), he has to ask the developer for help. Our testers specialize in test and are not capable of coding.
- a feature could be tested without the existence of another new feature. e.g. Feature A and B are both under test at the same time, the two features are unaware of each other because neither of them has been merged to the
developbranch. These means you will have to test against thedevelopbranch again when both of the features are merged to the develop branch anyway. And you have to remember to test this in the future. - If Feature A and B are both tested and approved, but when merged a conflict is identified, both of the developers for both features believe it is not his own fault/job because his feature branch past the test. There is an extra overhead in communication, and sometimes whoever resolving the conflict is frustrated.
Above is our story. With limited resource, I would like to avoid testing everything everywhere. We are still looking for a better way to cope with this. I would love to hear how other teams handle this kind of situations.
