123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262 |
- Development
- ===========
- Get the sources
- ---------------
- Anonymous:
- ::
- git clone https://pagure.io/pagure.git
- Contributors:
- ::
- git clone ssh://git@pagure.io:pagure.git
- Dependencies
- ------------
- The dependencies of pagure are listed in the file ``requirements.txt``
- at the top level of the sources.
- .. note:: working in a `virtualenv <http://www.virtualenv.org/en/latest/>`_
- is tricky due to the dependency on `pygit2 <http://www.pygit2.org/>`_
- and thus on `libgit2 <https://libgit2.github.com/>`_
- but the pygit2 `documentation has a solution for this
- <http://www.pygit2.org/install.html#libgit2-within-a-virtual-environment>`_.
- Run pagure for development
- --------------------------
- Adjust the configuration file (secret key, database URL, admin group...)
- See :doc:`configuration` for more detailed information about the
- configuration.
- Create the database scheme::
- ./createdb
- Create the folder that will receive the different git repositories:
- ::
- mkdir {repos,docs,forks,tickets,requests,remotes}
- Run the server:
- ::
- ./runserver
- If you want to change some configuration key you can create a file, place
- the configuration change in it and use it with
- ::
- ./runserver -c <config_file>
- For example, create the file ``config`` with in it:
- ::
- from datetime import timedelta
- # Makes the admin session longer
- ADMIN_SESSION_LIFETIME = timedelta(minutes=20000000)
- # Use a postgresql database instead of sqlite
- DB_URL = 'postgresql://user:pass@localhost/pagure'
- # Change the OpenID endpoint
- FAS_OPENID_ENDPOINT = 'https://id.stg.fedoraproject.org'
- APP_URL = '*'
- EVENTSOURCE_SOURCE = 'http://localhost:8080'
- EVENTSOURCE_PORT = '8080'
- DOC_APP_URL = '*'
- # Avoid sending email when developping
- EMAIL_SEND = False
- and run the server with:
- ::
- ./runserver -c config
- To get some profiling information you can also run it as:
- ::
- ./runserver.py --profile
- You should be able to access the server at http://localhost:5000
- Every time you save a file, the project will be automatically restarted
- so you can see your change immediatly.
- Create a pull-request for testing
- ----------------------------------
- When working on pagure, it is pretty often that one wanted to work on a
- feature or a bug related to pull-requests needs to create one.
- Making a pull-request for development purposes isn't hard, if you remember
- that since you're running a local instance, the git repos created in your
- pagure instance are also local.
- So here are in a few steps that one could perform to create a pull-request in a
- local pagure instance.
- * Create a project on your pagure instance, let's say it will be called ``test``
- * Create a folder ``clones`` somewhere in your system (you probably do not
- want it in the ``repos`` folder created above, next to it is fine though)::
- mkdir clones
- * Clone the repo of the ``test`` project into this ``clones`` folder::
- cd clones
- git clone ~/path/to/pagure/repos/test.git
- * Add and commit some files::
- echo "*~" > .gitignore
- git add .gitignore
- git commit -m "Add a .gitignore file"
- echo "BSD" > LICENSE
- git add LICENSE
- git commit -m "Add a LICENSE file"
- * Push these changes::
- git push -u origin master
- * Create a new branch and add a commit in it::
- git branch new_branch
- git checkout new_branch
- touch test
- git add test
- git commit -m "Add file: test"
- * Push this new branch::
- git push -u origin new_branch
- Then go back to your pagure instance running in your web-browser, check the
- ``test`` project. You should see two branches: ``master`` and ``new_branch``
- from there you should be able to open a new pull-request, either from the
- front page or via the ``File Pull Request`` button in the ``Pull Requests``
- page.
- Coding standards
- ----------------
- We are trying to make the code `PEP8-compliant
- <http://www.python.org/dev/peps/pep-0008/>`_. There is a `pep8 tool
- <http://pypi.python.org/pypi/pep8>`_ that can automatically check
- your source.
- We are also inspecting the code using `pylint
- <http://pypi.python.org/pypi/pylint>`_ and aim of course for a 10/10 code
- (but it is an assymptotic goal).
- .. note:: both pep8 and pylint are available in Fedora via yum:
- ::
- yum install python-pep8 pylint
- Send patch
- ----------
- The easiest way to work on pagure is to make your own branch in git, make
- your changes to this branch, commit whenever you want, rebase on master,
- whenever you need and when you are done, send the patch either by email,
- via the trac or a pull-request (using git or github).
- The workflow would therefore be something like:
- ::
- git branch <my_shiny_feature>
- git checkout <my_shiny_feature>
- <work>
- git commit file1 file2
- <more work>
- git commit file3 file4
- git checkout master
- git pull
- git checkout <my_shiny_feature>
- git rebase master
- git format-patch -2
- This will create two patch files that you can send by email to submit in a ticket
- on pagure, by email or after forking the project on pagure by submitting a
- pull-request (in which case the last step above ``git format-patch -2`` is not
- needed.
- Unit-tests
- ----------
- Pagure has a number of unit-tests.
- We aim at having a full (100%) coverage of the whole code (including the
- Flask application) and of course a smart coverage as in we want to check
- that the functions work the way we want but also that they fail when we
- expect it and the way we expect it.
- Tests checking that function are failing when/how we want are as important
- as tests checking they work the way they are intended to.
- ``runtests.sh``, located at the top of the sources, helps to run the
- unit-tests of the project with coverage information using `python-nose
- <https://nose.readthedocs.org/>`_.
- .. note:: You can specify additional arguments to the nose command used
- in this script by just passing arguments to the script.
- For example you can specify the ``-x`` / ``--stop`` argument:
- `Stop running tests after the first error or failure` by just doing
- ::
- ./runtests.sh --stop
- Each unit-tests files (located under ``tests/``) can be called
- by alone, allowing easier debugging of the tests. For example:
- ::
- python tests/test_pragure_lib.py
- .. note:: In order to have coverage information you might have to install
- ``python-coverage``
- ::
- yum install python-coverage
|