Submitting patches¶
Weâre always grateful for patches to Djangoâs code. Indeed, bug reports with associated patches will get fixed far more quickly than those without patches.
Typo fixes and trivial documentation changes¶
If you are fixing a really trivial issue, for example changing a word in the documentation, the preferred way to provide the patch is using GitHub pull requests without a Trac ticket. Trac tickets are still acceptable.
See the Working with Git and GitHub for more details on how to use pull requests.
âClaimingâ tickets¶
In an open-source project with hundreds of contributors around the world, itâs important to manage communication efficiently so that work doesnât get duplicated and contributors can be as effective as possible.
Hence, our policy is for contributors to âclaimâ tickets in order to let other developers know that a particular bug or feature is being worked on.
If you have identified a contribution you want to make and youâre capable of fixing it (as measured by your coding ability, knowledge of Django internals and time availability), claim it by following these steps:
- Create an account to use in our ticket system. If you have an account but have forgotten your password, you can reset it using the password reset page.
- If a ticket for this issue doesnât exist yet, create one in our ticket tracker.
- If a ticket for this issue already exists, make sure nobody else has claimed it. To do this, look at the âOwned byâ section of the ticket. If itâs assigned to ânobody,â then itâs available to be claimed. Otherwise, somebody else is working on this ticket, and you either find another bug/feature to work on, or contact the developer working on the ticket to offer your help.
- Log into your account, if you havenât already, by clicking âLoginâ in the upper right of the ticket page.
- Claim the ticket:
- click the âassign to myselfâ radio button under âActionâ near the bottom of the page,
- then click âSubmit changes.â
Note
The Django software foundation requests that anyone contributing more than a trivial patch to Django sign and submit a Contributor License Agreement, this ensures that the Django Software Foundation has clear license to all contributions allowing for a clear license for all users.
Ticket claimersâ responsibility¶
Once youâve claimed a ticket, you have a responsibility to work on that ticket in a reasonably timely fashion. If you donât have time to work on it, either unclaim it or donât claim it in the first place!
If thereâs no sign of progress on a particular claimed ticket for a week or two, another developer may ask you to relinquish the ticket claim so that itâs no longer monopolized and somebody else can claim it.
If youâve claimed a ticket and itâs taking a long time (days or weeks) to code, keep everybody updated by posting comments on the ticket. If you donât provide regular updates, and you donât respond to a request for a progress report, your claim on the ticket may be revoked.
As always, more communication is better than less communication!
Which tickets should be claimed?¶
Of course, going through the steps of claiming tickets is overkill in some cases.
In the case of small changes, such as typos in the documentation or small bugs that will only take a few minutes to fix, you donât need to jump through the hoops of claiming tickets. Just submit your patch and be done with it.
Of course, it is always acceptable, regardless whether someone has claimed it or not, to submit patches to a ticket if you happen to have a patch ready.
Patch style¶
Make sure that any contribution you do fulfills at least the following requirements:
- The code required to fix a problem or add a feature is an essential part of a patch, but it is not the only part. A good patch should also include a regression test to validate the behavior that has been fixed and to prevent the problem from arising again. Also, if some tickets are relevant to the code that youâve written, mention the ticket numbers in some comments in the test so that one can easily trace back the relevant discussions after your patch gets committed, and the tickets get closed.
- If the code associated with a patch adds a new feature, or modifies behavior of an existing feature, the patch should also contain documentation.
You can use either GitHub branches and pull requests or direct patches to publish your work. If you use the Git workflow, then you should announce your branch in the ticket by including a link to your branch. When you think your work is ready to be merged in create a pull request.
See the Working with Git and GitHub documentation for more details.
You can also use patches in Trac. When using this style, follow these guidelines.
- Submit patches in the format returned by the
git diffcommand. An exception is for code changes that are described more clearly in plain English than in code. Indentation is the most common example; itâs hard to read patches when the only difference in code is that itâs indented. - Attach patches to a ticket in the ticket tracker, using the âattach fileâ button. Please donât put the patch in the ticket description or comment unless itâs a single line patch.
- Name the patch file with a
.diffextension; this will let the ticket tracker apply correct syntax highlighting, which is quite helpful.
Regardless of the way you submit your work, follow these steps.
- Make sure your code matches our Coding style.
- Check the âHas patchâ box on the ticket details. This will make it obvious that the ticket includes a patch, and it will add the ticket to the list of tickets with patches.
Non-trivial patches¶
A ânon-trivialâ patch is one that is more than a simple bug fix. Itâs a patch that introduces Django functionality and makes some sort of design decision.
If you provide a non-trivial patch, include evidence that alternatives have been discussed on django-developers.
If youâre not sure whether your patch should be considered non-trivial, just ask.
Deprecating a feature¶
There are a couple reasons that code in Django might be deprecated:
- If a feature has been improved or modified in a backwards-incompatible way, the old feature or behavior will be deprecated.
- Sometimes Django will include a backport of a Python library thatâs not included in a version of Python that Django currently supports. When Django no longer needs to support the older version of Python that doesnât include the library, the library will be deprecated in Django.
As the deprecation policy describes,
the first release of Django that deprecates a feature (A.B) should raise a
RemovedInDjangoXXWarning (where XX is the Django version where the feature
will be removed) when the deprecated feature is invoked. Assuming we have good
test coverage, these warnings are converted to errors when running the
test suite with warnings enabled:
python -Wall runtests.py. Thus, when adding a RemovedInDjangoXXWarning
you need to eliminate or silence any warnings generated when running the tests.
The first step is to remove any use of the deprecated behavior by Django itself.
Next you can silence warnings in tests that actually test the deprecated
behavior by using the ignore_warnings decorator, either at the test or class
level:
In a particular test:
from django.test import ignore_warnings from django.utils.deprecation import RemovedInDjangoXXWarning @ignore_warnings(category=RemovedInDjangoXXWarning) def test_foo(self): ...
For an entire test case:
from django.test import ignore_warnings from django.utils.deprecation import RemovedInDjangoXXWarning @ignore_warnings(category=RemovedInDjangoXXWarning) class MyDeprecatedTests(unittest.TestCase): ...
Previous versions of Django had some Ignore*DeprecationWarningsMixin
classes to prevent warnings from appearing. These have been replaced by the
ignore_warnings decorator.
You can also add a test for the deprecation warning. Youâll have to disable the âwarning as errorâ behavior in your test by doing:
import warnings
def test_foo_deprecation_warning(self):
with warnings.catch_warnings(record=True) as warns:
warnings.simplefilter('always') # prevent warnings from appearing as errors
# invoke deprecated behavior
self.assertEqual(len(warns), 1)
msg = str(warns[0].message)
self.assertEqual(msg, 'Expected deprecation message')
Finally, there are a couple of updates to Djangoâs documentation to make:
- If the existing feature is documented, mark it deprecated in documentation
using the
.. deprecated:: A.Bannotation. Include a short description and a note about the upgrade path if applicable. - Add a description of the deprecated behavior, and the upgrade path if
applicable, to the current release notes (
docs/releases/A.B.txt) under the âFeatures deprecated in A.Bâ heading. - Add an entry in the deprecation timeline (
docs/internals/deprecation.txt) under theA.B+2version describing what code will be removed.
Once you have completed these steps, you are finished with the deprecation.
In each major release, all RemovedInDjangoXXWarnings matching the new
version are removed.
JavaScript patches¶
Djangoâs admin system leverages the jQuery framework to increase the capabilities of the admin interface. In conjunction, there is an emphasis on admin JavaScript performance and minimizing overall admin media file size. Serving compressed or âminifiedâ versions of JavaScript files is considered best practice in this regard.
To that end, patches for JavaScript files should include both the original
code for future development (e.g. foo.js), and a compressed version for
production use (e.g. foo.min.js). Any links to the file in the codebase
should point to the compressed version.
Compressing JavaScript¶
To simplify the process of providing optimized JavaScript code, Django includes a handy Python script which should be used to create a âminifiedâ version. To run it:
python django/contrib/admin/bin/compress.py
Behind the scenes, compress.py is a front-end for Googleâs
Closure Compiler which is written in Java. However, the Closure Compiler
library is not bundled with Django directly, so those wishing to contribute
complete JavaScript patches will need to download and install the library
independently. The Closure Compiler library requires Java 7 or higher.
Please donât forget to run compress.py and include the diff of the
minified scripts when submitting patches for Djangoâs JavaScript.
Patch review checklist¶
Use this checklist to review a pull request. If you are reviewing a pull request that is not your own and it passes all the criteria below, please set the âTriage Stageâ on the corresponding Trac ticket to âReady for checkinâ. If youâve left comments for improvement on the pull request, please tick the appropriate flags on the Trac ticket based on the results of your review: âPatch needs improvementâ, âNeeds documentationâ, and/or âNeeds testsâ. As time and interest permits, core developers do final reviews of âReady for checkinâ tickets and will either commit the patch or bump it back to âAcceptedâ if further works need to be done. If youâre looking to become a core developer, doing thorough reviews of patches is a great way to earn trust.
Looking for a patch to review? Check out the âPatches needing reviewâ section of the Django Development Dashboard. Looking to get your patch reviewed? Ensure the Trac flags on the ticket are set so that the ticket appears in that queue.
Documentation¶
- Does the documentation build without any errors (
make html, ormake.bat htmlon Windows, from thedocsdirectory)? - Does the documentation follow the writing style guidelines in Writing documentation?
- Are there any spelling errors?
Bugs¶
- Is there a proper regression test (the test should fail before the fix is applied)?
New Features¶
- Are there tests to âexerciseâ all of the new code?
- Is there a release note in
docs/releases/A.B.txt? - Is there documentation for the feature and is it annotated
appropriately with
.. versionadded:: A.Bor.. versionchanged:: A.B?
Deprecating a feature¶
See the Deprecating a feature guide.
All code changes¶
- Does the coding style conform to our
guidelines? Are there any
flake8errors? - If the change is backwards incompatible in any way, is there a note
in the release notes (
docs/releases/A.B.txt)? - Is Djangoâs test suite passing? Ask in
#django-devfor a core dev to build the pull request against our continuous integration server.
All tickets¶
- Is the pull request a single squashed commit with a message that follows our commit message format?
- Are you the patch author and a new contributor? Please add yourself to the
AUTHORSfile and submit a Contributor License Agreement.