mirror of
https://github.com/django/django.git
synced 2025-01-26 10:09:42 +00:00
[5.0.x] Replaced usage of "patch" with more precise terms in faq, howto, and intro docs.
Backport of 85240139ca1a6b369019ba657ad80c3249a9cb37 from main.
This commit is contained in:
parent
9f03c6d59b
commit
dc164bdb9f
@ -10,8 +10,8 @@ How can I get started contributing code to Django?
|
||||
Thanks for asking! We've written an entire document devoted to this question.
|
||||
It's titled :doc:`Contributing to Django </internals/contributing/index>`.
|
||||
|
||||
I submitted a bug fix in the ticket system several weeks ago. Why are you ignoring my patch?
|
||||
============================================================================================
|
||||
I submitted a bug fix several weeks ago. Why are you ignoring my contribution?
|
||||
==============================================================================
|
||||
|
||||
Don't worry: We're not ignoring you!
|
||||
|
||||
@ -34,21 +34,21 @@ that area of the code, to understand the problem and verify the fix:
|
||||
database, are those instructions clear enough even for someone not
|
||||
familiar with it?
|
||||
|
||||
* If there are several patches attached to the ticket, is it clear what
|
||||
each one does, which ones can be ignored and which matter?
|
||||
* If there are several branches linked to the ticket, is it clear what each one
|
||||
does, which ones can be ignored and which matter?
|
||||
|
||||
* Does the patch include a unit test? If not, is there a very clear
|
||||
* Does the change include a unit test? If not, is there a very clear
|
||||
explanation why not? A test expresses succinctly what the problem is,
|
||||
and shows that the patch actually fixes it.
|
||||
and shows that the branch actually fixes it.
|
||||
|
||||
If your patch stands no chance of inclusion in Django, we won't ignore it --
|
||||
we'll just close the ticket. So if your ticket is still open, it doesn't mean
|
||||
If your contribution is not suitable for inclusion in Django, we won't ignore
|
||||
it -- we'll close the ticket. So if your ticket is still open, it doesn't mean
|
||||
we're ignoring you; it just means we haven't had time to look at it yet.
|
||||
|
||||
When and how might I remind the team of a patch I care about?
|
||||
=============================================================
|
||||
When and how might I remind the team of a change I care about?
|
||||
==============================================================
|
||||
|
||||
A polite, well-timed message to the mailing list is one way to get attention.
|
||||
A polite, well-timed message in the forum/branch is one way to get attention.
|
||||
To determine the right time, you need to keep an eye on the schedule. If you
|
||||
post your message right before a release deadline, you're not likely to get the
|
||||
sort of attention you require.
|
||||
@ -68,11 +68,11 @@ issue over and over again. This sort of behavior will not gain you any
|
||||
additional attention -- certainly not the attention that you need in order to
|
||||
get your issue addressed.
|
||||
|
||||
But I've reminded you several times and you keep ignoring my patch!
|
||||
===================================================================
|
||||
But I've reminded you several times and you keep ignoring my contribution!
|
||||
==========================================================================
|
||||
|
||||
Seriously - we're not ignoring you. If your patch stands no chance of
|
||||
inclusion in Django, we'll close the ticket. For all the other tickets, we
|
||||
Seriously - we're not ignoring you. If your contribution is not suitable for
|
||||
inclusion in Django, we will close the ticket. For all the other tickets, we
|
||||
need to prioritize our efforts, which means that some tickets will be
|
||||
addressed before others.
|
||||
|
||||
@ -83,7 +83,7 @@ are edge cases.
|
||||
|
||||
Another reason that a bug might be ignored for a while is if the bug is a
|
||||
symptom of a larger problem. While we can spend time writing, testing and
|
||||
applying lots of little patches, sometimes the right solution is to rebuild. If
|
||||
applying lots of little changes, sometimes the right solution is to rebuild. If
|
||||
a rebuild or refactor of a particular component has been proposed or is
|
||||
underway, you may find that bugs affecting that component will not get as much
|
||||
attention. Again, this is a matter of prioritizing scarce resources. By
|
||||
|
@ -6,7 +6,7 @@ This document will guide you through installing Python 3.12 and Django on
|
||||
Windows. It also provides instructions for setting up a virtual environment,
|
||||
which makes it easier to work on Python projects. This is meant as a beginner's
|
||||
guide for users working on Django projects and does not reflect how Django
|
||||
should be installed when developing patches for Django itself.
|
||||
should be installed when developing changes for Django itself.
|
||||
|
||||
The steps in this guide have been tested with Windows 10. In other
|
||||
versions, the steps would be similar. You will need to be familiar with using
|
||||
|
@ -27,7 +27,7 @@ Are you new to Django or to programming? This is the place to start!
|
||||
|
||||
* **Advanced Tutorials:**
|
||||
:doc:`How to write reusable apps <intro/reusable-apps>` |
|
||||
:doc:`Writing your first patch for Django <intro/contributing>`
|
||||
:doc:`Writing your first contribution to Django <intro/contributing>`
|
||||
|
||||
Getting help
|
||||
============
|
||||
|
@ -1,6 +1,6 @@
|
||||
===================================
|
||||
Writing your first patch for Django
|
||||
===================================
|
||||
==========================================
|
||||
Writing your first contribution for Django
|
||||
==========================================
|
||||
|
||||
Introduction
|
||||
============
|
||||
@ -52,16 +52,16 @@ __ https://web.libera.chat/#django-dev
|
||||
What does this tutorial cover?
|
||||
------------------------------
|
||||
|
||||
We'll be walking you through contributing a patch to Django for the first time.
|
||||
We'll be walking you through contributing to Django for the first time.
|
||||
By the end of this tutorial, you should have a basic understanding of both the
|
||||
tools and the processes involved. Specifically, we'll be covering the following:
|
||||
|
||||
* Installing Git.
|
||||
* Downloading a copy of Django's development version.
|
||||
* Running Django's test suite.
|
||||
* Writing a test for your patch.
|
||||
* Writing the code for your patch.
|
||||
* Testing your patch.
|
||||
* Writing a test for your changes.
|
||||
* Writing the code for your changes.
|
||||
* Testing your changes.
|
||||
* Submitting a pull request.
|
||||
* Where to look for more information.
|
||||
|
||||
@ -91,7 +91,7 @@ Installing Git
|
||||
==============
|
||||
|
||||
For this tutorial, you'll need Git installed to download the current
|
||||
development version of Django and to generate patch files for the changes you
|
||||
development version of Django and to generate a branch for the changes you
|
||||
make.
|
||||
|
||||
To check whether or not you have Git installed, enter ``git`` into the command
|
||||
@ -178,7 +178,7 @@ Go ahead and install the previously cloned copy of Django:
|
||||
|
||||
The installed version of Django is now pointing at your local copy by installing
|
||||
in editable mode. You will immediately see any changes you make to it, which is
|
||||
of great help when writing your first patch.
|
||||
of great help when writing your first contribution.
|
||||
|
||||
Creating projects with a local copy of Django
|
||||
---------------------------------------------
|
||||
@ -188,8 +188,8 @@ have to create a new virtual environment, :ref:`install the previously cloned
|
||||
local copy of Django in editable mode <intro-contributing-install-local-copy>`,
|
||||
and create a new Django project outside of your local copy of Django. You will
|
||||
immediately see any changes you make to Django in your new project, which is
|
||||
of great help when writing your first patch, especially if testing any changes
|
||||
to the UI.
|
||||
of great help when writing your first contribution, especially if testing
|
||||
any changes to the UI.
|
||||
|
||||
You can follow the :doc:`tutorial</intro/tutorial01>` for help in creating a
|
||||
Django project.
|
||||
@ -279,8 +279,8 @@ imaginary details:
|
||||
|
||||
We'll now implement this feature and associated tests.
|
||||
|
||||
Creating a branch for your patch
|
||||
================================
|
||||
Creating a branch
|
||||
=================
|
||||
|
||||
Before making any changes, create a new branch for the ticket:
|
||||
|
||||
@ -295,19 +295,19 @@ won't affect the main copy of the code that we cloned earlier.
|
||||
Writing some tests for your ticket
|
||||
==================================
|
||||
|
||||
In most cases, for a patch to be accepted into Django it has to include tests.
|
||||
For bug fix patches, this means writing a regression test to ensure that the
|
||||
bug is never reintroduced into Django later on. A regression test should be
|
||||
written in such a way that it will fail while the bug still exists and pass
|
||||
once the bug has been fixed. For patches containing new features, you'll need
|
||||
to include tests which ensure that the new features are working correctly.
|
||||
They too should fail when the new feature is not present, and then pass once it
|
||||
has been implemented.
|
||||
In most cases, for a contribution to be accepted into Django it has to include
|
||||
tests. For bug fix contributions, this means writing a regression test to
|
||||
ensure that the bug is never reintroduced into Django later on. A regression
|
||||
test should be written in such a way that it will fail while the bug still
|
||||
exists and pass once the bug has been fixed. For contributions containing new
|
||||
features, you'll need to include tests which ensure that the new features are
|
||||
working correctly. They too should fail when the new feature is not present,
|
||||
and then pass once it has been implemented.
|
||||
|
||||
A good way to do this is to write your new tests first, before making any
|
||||
changes to the code. This style of development is called
|
||||
`test-driven development`__ and can be applied to both entire projects and
|
||||
single patches. After writing your tests, you then run them to make sure that
|
||||
single changes. After writing your tests, you then run them to make sure that
|
||||
they do indeed fail (since you haven't fixed that bug or added that feature
|
||||
yet). If your new tests don't fail, you'll need to fix them so that they do.
|
||||
After all, a regression test that passes regardless of whether a bug is present
|
||||
@ -398,7 +398,7 @@ function to the correct file.
|
||||
Running Django's test suite for the second time
|
||||
===============================================
|
||||
|
||||
Once you've verified that your patch and your test are working correctly, it's
|
||||
Once you've verified that your changes and test are working correctly, it's
|
||||
a good idea to run the entire Django test suite to verify that your change
|
||||
hasn't introduced any bugs into other areas of Django. While successfully
|
||||
passing the entire test suite doesn't guarantee your code is bug free, it does
|
||||
@ -450,7 +450,7 @@ preview the HTML that will be generated.
|
||||
Previewing your changes
|
||||
=======================
|
||||
|
||||
Now it's time to go through all the changes made in our patch. To stage all the
|
||||
Now it's time to review the changes made in the branch. To stage all the
|
||||
changes ready for commit, run:
|
||||
|
||||
.. console::
|
||||
@ -528,12 +528,11 @@ Use the arrow keys to move up and down.
|
||||
+ def test_make_toast(self):
|
||||
+ self.assertEqual(make_toast(), 'toast')
|
||||
|
||||
When you're done previewing the patch, hit the ``q`` key to return to the
|
||||
command line. If the patch's content looked okay, it's time to commit the
|
||||
changes.
|
||||
When you're done previewing the changes, hit the ``q`` key to return to the
|
||||
command line. If the diff looked okay, it's time to commit the changes.
|
||||
|
||||
Committing the changes in the patch
|
||||
===================================
|
||||
Committing the changes
|
||||
======================
|
||||
|
||||
To commit the changes:
|
||||
|
||||
@ -551,7 +550,7 @@ message guidelines <committing-guidelines>` and write a message like:
|
||||
Pushing the commit and making a pull request
|
||||
============================================
|
||||
|
||||
After committing the patch, send it to your fork on GitHub (substitute
|
||||
After committing the changes, send it to your fork on GitHub (substitute
|
||||
"ticket_99999" with the name of your branch if it's different):
|
||||
|
||||
.. console::
|
||||
@ -563,7 +562,7 @@ You can create a pull request by visiting the `Django GitHub page
|
||||
recently pushed branches". Click "Compare & pull request" next to it.
|
||||
|
||||
Please don't do it for this tutorial, but on the next page that displays a
|
||||
preview of the patch, you would click "Create pull request".
|
||||
preview of the changes, you would click "Create pull request".
|
||||
|
||||
Next steps
|
||||
==========
|
||||
@ -578,14 +577,14 @@ codebase.
|
||||
More information for new contributors
|
||||
-------------------------------------
|
||||
|
||||
Before you get too into writing patches for Django, there's a little more
|
||||
Before you get too into contributing to Django, there's a little more
|
||||
information on contributing that you should probably take a look at:
|
||||
|
||||
* You should make sure to read Django's documentation on
|
||||
:doc:`claiming tickets and submitting patches
|
||||
:doc:`claiming tickets and submitting pull requests
|
||||
</internals/contributing/writing-code/submitting-patches>`.
|
||||
It covers Trac etiquette, how to claim tickets for yourself, expected
|
||||
coding style for patches, and many other important details.
|
||||
coding style (both for code and docs), and many other important details.
|
||||
* First time contributors should also read Django's :doc:`documentation
|
||||
for first time contributors</internals/contributing/new-contributors/>`.
|
||||
It has lots of good advice for those of us who are new to helping out
|
||||
@ -600,19 +599,19 @@ Finding your first real ticket
|
||||
------------------------------
|
||||
|
||||
Once you've looked through some of that information, you'll be ready to go out
|
||||
and find a ticket of your own to write a patch for. Pay special attention to
|
||||
and find a ticket of your own to contribute to. Pay special attention to
|
||||
tickets with the "easy pickings" criterion. These tickets are often much
|
||||
simpler in nature and are great for first time contributors. Once you're
|
||||
familiar with contributing to Django, you can move on to writing patches for
|
||||
more difficult and complicated tickets.
|
||||
familiar with contributing to Django, you can start working on more difficult
|
||||
and complicated tickets.
|
||||
|
||||
If you just want to get started already (and nobody would blame you!), try
|
||||
taking a look at the list of `easy tickets that need patches`__ and the
|
||||
`easy tickets that have patches which need improvement`__. If you're familiar
|
||||
taking a look at the list of `easy tickets without a branch`__ and the
|
||||
`easy tickets that have branches which need improvement`__. If you're familiar
|
||||
with writing tests, you can also look at the list of
|
||||
`easy tickets that need tests`__. Remember to follow the guidelines about
|
||||
claiming tickets that were mentioned in the link to Django's documentation on
|
||||
:doc:`claiming tickets and submitting patches
|
||||
:doc:`claiming tickets and submitting branches
|
||||
</internals/contributing/writing-code/submitting-patches>`.
|
||||
|
||||
__ https://code.djangoproject.com/query?status=new&status=reopened&has_patch=0&easy=1&col=id&col=summary&col=status&col=owner&col=type&col=milestone&order=priority
|
||||
@ -622,9 +621,9 @@ __ https://code.djangoproject.com/query?status=new&status=reopened&needs_tests=1
|
||||
What's next after creating a pull request?
|
||||
------------------------------------------
|
||||
|
||||
After a ticket has a patch, it needs to be reviewed by a second set of eyes.
|
||||
After a ticket has a branch, it needs to be reviewed by a second set of eyes.
|
||||
After submitting a pull request, update the ticket metadata by setting the
|
||||
flags on the ticket to say "has patch", "doesn't need tests", etc, so others
|
||||
can find it for review. Contributing doesn't necessarily always mean writing a
|
||||
patch from scratch. Reviewing existing patches is also a very helpful
|
||||
can find it for review. Contributing doesn't necessarily always mean writing
|
||||
code from scratch. Reviewing open pull requests is also a very helpful
|
||||
contribution. See :doc:`/internals/contributing/triaging-tickets` for details.
|
||||
|
Loading…
x
Reference in New Issue
Block a user