This file is intended for developers and packagers of rsnapshot, not for regular users. If you want to contribute, it's a good idea to read this document. Although the file is called contributing, it describes the whole release and development process.
The bug tracker is hosted on Github. Please don't report any issues in the tracker on Sourceforge.
The rsnapshot source code is on Github.
Auto-generated files should not get tracked. If you need the configure-script, generate it with ./autogen.sh
. Keep in mind that you have to execute ./autoclean.sh
before you commit.
If you have found a bug, open an issue-report on Github. Before you open a report, please search if there are corresponding issues already opened or whether the bug has already been fixed on the master
branch. Please provide the rsnapshot-version, and describe how to reproduce the bug. It would be great if you could provide also a fix.
If you checked rsnapshot out of the git-repository, you have to generate the configure-script with:
$ ./autogen.sh
rsnapshot uses the common triple to build software:
$ ./configure
$ make
$ make install
The master
branch should be complete, by which we mean that there should be no half-completed features in it. Any development should be done in a separate branch, each of them containing only a single feature or bugfix.
Changes that do not conform to the coding standard will not be accepted. The current coding standard is primarily encapsulated in the code itself. However briefly:
- Use tabs not white space.
- There should be no trailing white space on any lines.
- The soft line length limited should be 80 characters.
Fork the repository and open a new branch prefixed with feature/
. Keep the name short and descriptive. Before opening a Pull-Request against the main repository, make sure that:
- you have written tests, which test the functionality
- all the tests pass
- your commits are logically ordered
- your commits are clean
If it is not the case, please rebase/revise your branch. When you're finished you can create a pull request. Your changes will then be reviewed by a team member, before they can get merged into master
.
Create a new branch, prefix it with issue/
and, if available, the github issue number. (e.g. issue/35-umount-lvm
).
Add your commits to the branch. They should be logically ordered and clean. Rebase them, if neccessary. Make sure that make test
passes. Finished? Open a pull-request! The code will get reviewed. If the review passes, a project-member will merge it onto master
and release-*
(see below), and will release new bugfix-versions.
We encourage you to write a test case for your pull-request. rsnapshot lacks of a proper testsuite, so please write tests whenever you create a Pull-request touching code at the program. We can verify your changes and intentions easier.
- Create a directory in the testsuite-folder (
t/
) with the desired test-name. And create in this also a subfolder namedconf
. - Copy the skelleton-file from
t/support/skel/testcase
into your testcase-folder and name it like your folder with the ending.t.in
. - Do the same with the conf-file
t/support/skel/testconf
, but copy it into your conf-folder. Give the file the same name and with the ending.conf.in
. - Write your tests and of course test them.
A few notes on the testsuite:
- Use the SysWrap-module actively.
- Any file commited in the testsuite-folder ending with
.conf
or.t
is commited or named wrong. - Let your files always end with
.in
and executeautogen.sh
before you run your testsuite. - Always place your configuration-files into the
conf
-subfolder. - If you have got multiple tests to check, which are quite similar, use one test-file, and multiple configuration-files located in your test-folder. (Look at the cmd-post_pre-exec testcase).
Releases should be done from branches, named for the release version,
e.g. release-1.4
. The first release of that version should be tagged 1.4.0
.
Subsequent releases of that version, which should contain no changes other
than bugfixes and security fixes, should also be tagged, e.g. 1.4.1
.
In the end, there should be for every minor release a branch like release-X.Y
. The sub-releases should only get tagged on their specific branches.
Here is a model presented for release 1.4.0. Make sure, that you start on the master-branch and have a clean working-directory!
-
You start branching out of the master-branch -
git checkout -b release-1-4
-
If there are necessary changes to do before release, make them and commit them now. Mind: Any auto-generated script should not get tracked. You should only merge the actual changes. The configure-scripts are generated later for the release. -
git add -A
-git commit -m "Finish Release v1.4.0"
-
tag the commit with git and push it to repo -
git tag 1.4.0
-git push --tags
-
Wait for Travis-CI to finish, the fully-built release is then available on the Github-releases page.
Travis will execute these commands to make a release:
- `./autogen.sh`
- `make`
- `make tar`
- upload generated file by make tar to Github releases-page
- make man: generate the man page from POD data in rsnapshot
- make html: generate a HTML page from POD data in rsnapshot
- make doc: man + html
- make test: run the testsuite
- make clean: clean up the mess from autoconf
- make dist: make the release-tarball