-
Notifications
You must be signed in to change notification settings - Fork 0
Git workflow
Contents of this page:
- Quick Summary
- Notes on writing good commit messages
- Submitting Pull Requests
- Working with issues
- Branching Strategy
- Release Procedure
- Database Changes
Full details Forking Workflow
Other interesting reading:
Each developer should fork the private core Ghost repo into a private repo of their own and clone this as their local repo. Remember to add the main repo as a remote:
git remote add upstream [email protected]:TryGhost/Ghost.git
The main repository's master branch always contains the latest changes. For more info on branches, see the branching strategy notes.
Changes should adhere to our coding standards, commit messages should follow our notes below, and pull requests should be submitted as per the guidelines
- The first line of your commit message should be a short (80 chars) public description of what you have achieved with the commit. This is what appears in the change log.
- Leave a blank line after the first line
- The 3rd line should reference the issue with
issue #000
if you just want to mention an issue orcloses #000
if your commit closes an issue. If you don't have an issue to reference or close, think carefully about whether you need to raise one before opening a PR. - Use bullet points on the following lines to explain what your changes achieve and in particular why you've used your approach
E.g.
Show message and don't start on unsupported node versions
closes #292
- added engines and enginestrict properties to package.json
- these provide warnings / errors when installing through npm
- added our own check using this info on start, throws a useful error and stops the app if the node version is not supported
- also switched sqlite3 to the latest version and checked it works with various node versions
The easier it is for us to merge a PR, the faster we'll be able to do it. Please take steps to make merging easy and keep the history clean and useful.
always work on a branch, it will make your life much easier - honest. Not touching the master branch will also simplify keeping your fork up-to-date.
use issues properly, we have a whole set of guidelines on how to raise an issue. Bugs, changes and features are all different and should be treated differently. Use your commit message to close or reference issues. The more information you provide, the more likely it is your PR will get merged.
Note: If you are not comfortable with git & using rebase, make a special 'merge' branch of your branch to do these things on, then if something goes awry you can always go back to your working branch and try again.
Whilst you're working on your branch on your own, you can do all the commits you like - lots of little commits are highly recommended. However, when you come to submit a PR, you should clean your history ready for public consumption.
- Run
git log master..your-branch-name
to see how many commits there are on your branch - Run
git rebase -i HEAD~#
where # is the number of commits you have done on your branch
Use the interactive rebase to edit your history. Unless you have good reason to keep more than one commit, I recommend marking the first commit with 'r' and the others with 's'. This lets you keep the first commit only, but change the message. Your commit message(s) should follow the pattern described in the notes above. The first line of your commit message will appear in the change log which goes out to our VIPs with each pre-release, so please keep that in mind.
Run grunt validate
to check that your work passes JSLint and the server-side mocha unit tests. If this fails, your PR will throw an error when submitted.
Our functional tests are not yet hooked up to grunt validate, but details on how to run them can be found in core/test/functional/base.js
if you're making changes to the UI it's worth running these.
Now that your history is nice and clean, fetch the latest updates from upstream. Assuming you haven't changed the master branch, do:
> git checkout master
> git pull upstream master
Then rebase your branch/changes on top of master:
> git checkout my-branch-name
> git rebase master
And finally push your work to your fork:
> git push -u origin my-branch-name
GitHub will offer to create a pull-request from newly created branches automatically.
Now submit your PR with all the latest changes from master and a nice clean history with useful commit messages. Finish up by adding a description to the PR which details any interesting changes, any tools or libraries you've added and warnings for any breaking changes.
If your PR has fallen behind and can't be merge cleanly, just re-do the steps above (pull from master, rebase your branch), then force push to your branch using git push -f origin my-feature-branch
. This will update the PR commits. Of course, never force push to any branch you have shared with others & be very careful about what you force push.
Thanks!
Note: - this is my way of getting everything neat and tidy, you may have another, as long as the result is nice easy-to-merge PRs.
Firstly, we will give your code a read through. Small changes usually get merged as soon as we've had chance to read through them. For more involved changes one of us will checkout your PR, rebase with master if required and then run basic sanity / regression tests on the code, run the casper tests and re-run grunt validate. If your PR has fallen behind master and can no longer be merged, we will in most cases rebase / merge master. In some cases with lots of small changes we will ask you to do this as you are more familiar with your changes than we will be.
Feel free to pick up any issue which is not assigned. Please leave a comment on the issue to say you wish to pick it up, and it will get assigned to you.
master
on the main repository always contains the latest changes. This means that it is WIP for the next minor version and should NOT be considered stable.
Stable versions are tagged using semantic versioning.
Along with the master branch, there is always a branch open for bug fixes that might need to go into a patch release. For example if the current released version is 0.3.3, you'll find a branch called 0.3.4-wip.
There may be several patch releases in between minor versions. A patch release does not contain master, it contains the previous release + specific fixes that may have been applied directly, or cherry-picked from master.
On your local repository, you should always work on a branch to make keeping up-to-date and submitting pull requests easier, but in most cases you should submit your pull requests to master
. Where necessary, for example if multiple people are contributing on a large feature, or if a feature requires a database change, we make use of feature branches. If you are working on something which you feel needs to go into a feature branch, let Hannah know and she will create this for you.
The roadmap outlines the basic features that we want to get into a minor version release (i.e. 0.4, 0.5, 0.6).
Each release has an associated milestone in GitHub, against which issues are assigned. There are usually issues for each milestone feature, plus other bug fixes and enhancements that we would like to get done.
Each Milestone has a due date. This date is usually a Monday, for example for 0.4 this is Monday 9th December. The due date is the last day on which PRs can be submitted for the milestone. Once we get to the end of the due date, any new PRs will not be considered.
The following Tuesday and Wednesday will be used to merge all PRs which made it into the release and are ready, and for testing the whole package.
On the Thursday, the release .zip will be generated and made available. We will ask that it be tested by as many people as possible! There will be 4 days (inc weekend) for testing.
Finally, on the following Tuesday, if all has gone well, we will provide the release zip as the new download on Ghost.org, and add it to the releases on GitHub.
Database changes require quite a bit of work around migration, exports and imports. As it stands, we currently always deliver database changes along with a minor version bump. Therefore it is important that all database changes are made on a branch so that they can be merged at a time when version bumping is convenient.