##// END OF EJS Templates
compare: workaround unexpected Mercurial behaviour when finding ancestor of null rev...
compare: workaround unexpected Mercurial behaviour when finding ancestor of null rev ancestor(id(0000000000000000000000000000000000000000),7) == 7 - that caused weird pull request diffs and lots of grief when (accidentally) creating a pull request from the null revision. Add special handling for the case of null revisions.

File last commit:

r4522:a9a1560d default
r4559:f4c60faf default
Show More
contributing.rst
51 lines | 1.9 KiB | text/x-rst | RstLexer

Contributing to Kallithea

If you would like to contribute to Kallithea, please contact us, any help is greatly appreciated!

Could I request that you make your source contributions by first forking the Kallithea repository on bitbucket https://bitbucket.org/conservancy/kallithea and then make your changes to your forked repository. Please post all fixes into dev bookmark since your change might be already fixed there and i try to merge all fixes from dev into stable, and not the other way. Finally, when you are finished with your changes, please send us a pull request.

To run Kallithea in a development version you always need to install the latest required libs. Simply clone Kallithea and switch to beta branch:

hg clone https://kallithea-scm.org/repos/kallithea

after downloading/pulling Kallithea make sure you run:

python setup.py develop

command to install/verify all required packages, and prepare development enviroment.

There are two files in the directory production.ini and developement.ini copy the development.ini file as rc.ini (which is excluded from version controll) and put all your changes like db connection or server port in there.

After finishing your changes make sure all tests passes ok. You can run the testsuite running nosetest from the project root, or if you use tox run tox for python2.6-2.7 with multiple database test. When using nosetests test.ini file is used and by default it uses sqlite for tests, edit this file to change your testing enviroment.

There's a special set of tests for push/pull operations, you can runn them using:

paster serve test.ini --pid-file=test.pid --daemon
KALLITHEA_WHOOSH_TEST_DISABLE=1 KALLITHEA_NO_TMP_PATH=1 nosetests -x kallithea/tests/other/test_vcs_operations.py
kill -9 $(cat test.pid)
Thank you for any contributions!