2015-01-20 16:23:16 +01:00
# Contributing to Compose
2014-03-06 11:57:24 +01:00
2014-10-23 19:28:17 +02:00
## TL;DR
Pull requests will need:
- Tests
- Documentation
- [To be signed off ](#sign-your-work )
- A logical series of [well written commits ](https://github.com/alphagov/styleguides/blob/master/git.md )
2014-05-28 12:08:46 +02:00
## Development environment
2015-01-20 16:23:16 +01:00
If you're looking contribute to Compose
2014-03-06 11:57:24 +01:00
but you're new to the project or maybe even to Python, here are the steps
that should get you started.
2015-01-20 16:23:16 +01:00
1. Fork [https://github.com/docker/compose ](https://github.com/docker/compose ) to your username.
1. Clone your forked repository locally `git clone git@github.com:yourusername/compose.git` .
1. Enter the local directory `cd compose` .
1. Set up a development environment by running `python setup.py develop` . This will install the dependencies and set up a symlink from your `docker-compose` executable to the checkout of the repository. When you now run `docker-compose` from anywhere on your machine, it will run your development version of Compose.
2014-03-06 11:57:24 +01:00
## Running the test suite
$ script/test
2014-05-28 12:08:46 +02:00
## Sign your work
The sign-off is a simple line at the end of the explanation for the
patch, which certifies that you wrote it or otherwise have the right to
pass it on as an open-source patch. The rules are pretty simple: if you
can certify the below (from [developercertificate.org ](http://developercertificate.org/ )):
Developer's Certificate of Origin 1.1
By making a contribution to this project, I certify that:
(a) The contribution was created in whole or in part by me and I
have the right to submit it under the open source license
indicated in the file; or
(b) The contribution is based upon previous work that, to the best
of my knowledge, is covered under an appropriate open source
license and I have the right under that license to submit that
work with modifications, whether created in whole or in part
by me, under the same open source license (unless I am
permitted to submit under a different license), as indicated
in the file; or
(c) The contribution was provided directly to me by some other
person who certified (a), (b) or (c) and I have not modified
it.
(d) I understand and agree that this project and the contribution
are public and that a record of the contribution (including all
personal information I submit with it, including my sign-off) is
maintained indefinitely and may be redistributed consistent with
this project or the open source license(s) involved.
then you just add a line saying
Signed-off-by: Random J Developer < random @ developer . example . org >
using your real name (sorry, no pseudonyms or anonymous contributions.)
The easiest way to do this is to use the `--signoff` flag when committing. E.g.:
$ git commit --signoff
2014-03-06 11:57:24 +01:00
2014-10-23 19:31:28 +02:00
## Building binaries
Linux:
$ script/build-linux
OS X:
$ script/build-osx
Note that this only works on Mountain Lion, not Mavericks, due to a [bug in PyInstaller ](http://www.pyinstaller.org/ticket/807 ).
2014-07-11 23:15:46 +02:00
## Release process
1. Open pull request that:
2015-01-20 16:23:16 +01:00
- Updates version in `compose/__init__.py`
2014-07-11 23:15:46 +02:00
- Updates version in `docs/install.md`
- Adds release notes to `CHANGES.md`
2. Create unpublished GitHub release with release notes
3. Build Linux version on any Docker host with `script/build-linux` and attach to release
2015-01-20 16:23:16 +01:00
4. Build OS X version on Mountain Lion with `script/build-osx` and attach to release as `docker-compose-Darwin-x86_64` and `docker-compose-Linux-x86_64` .
2014-07-11 23:15:46 +02:00
5. Publish GitHub release, creating tag
2014-07-28 22:27:22 +02:00
6. Update website with `script/deploy-docs`
2014-08-07 23:36:49 +02:00
7. Upload PyPi package
$ git checkout $VERSION
$ python setup.py sdist upload