Mengajukan bantuan¶
We're always grateful for contributions to Django's code. Indeed, bug reports with associated contributions will get fixed far more quickly than those without a solution.
Perbaikan kesalahan ketik dan perubahan dokumentasi sepele.¶
Jika anda sedang memperbaiki masalah sepele, sebagai contoh merubah sebuah kata di dokumentasi, cara dipilih untuk menyediakan tambalan adalah menggunakan menarik permintaan GitHub tanpa tiket Trac.
Lihat Bekerja dengan Git dan GitHub untuk rincian lebih bagaimana menggunakan pull request.
Tiket "Meminta"¶
Dalam sebuah proyek sumber-terbuka dengan ratusan penyumbang diseluruh dunia, adalah sangat penting untuk mengelola komunikasi secara efektif sehingga pekerjaan tidak ganda dan penyumbang dapat menjadi seefektif mungkin.
Oleh sebab itu, kebijakan kami untuk penyumbang dalam "menagih" tiket agar membiarkan pengembang lain mengetahui bahwa kesalahan atau fitur tertentu sedang dikerjakan.
Jika anda telah mencirikan bantuan anda ingin membuat dan anda mampu memperbaikinya (yang diukur dengan kemampuan pengkodean anda, pengetahuan dari internal Django dan ketersediaan waktu), tagih dia dengan mengikuti langkah-langkah berikut:
Login using your GitHub account atau create an account di sistem tiket kami. Jika anda mempunyai sebuah akun tetapi lupa sandi anda, anda dapat mengatur kembali menggunakan password reset page.
Jika sebuah tiket untuk masalah ini belum ada, buat satu di ticket tracker kami.
Jika tiket untuk masalah ini sudah ada, pastikan tidak seorangpun telah menagihnya. Untuk melakukan ini, lihat bagian "Owned by" dari tiket. Jika dia ditentukan ke "nobody", kemudian itu tersedia untuk ditagih. Jika tidak, seseorang lain mungkin bekerja pada tiket untuk menawarkan bantuan anda. Jika tiket diberikan selama mingguan atau bulanan tanpa aktivitas apapun, itu mungkin aman untuk ditetapkan untuk diri anda sendiri.
Log into your account, if you haven't already, by clicking "GitHub Login" or "DjangoProject Login" in the upper left of the ticket page. Once logged in, you can then click the "Modify Ticket" button near the bottom of the page.
Claim the ticket by clicking the "assign to" radio button in the "Action" section. Your username will be filled in the text box by default.
Finally click the "Submit changes" button at the bottom to save.
Catatan
The Django software foundation requests that anyone contributing more than a trivial change 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.
Tanggung jawab pengaku tiket¶
Sekali anda mengakui sebuah tiket, anda mempunyai tanggung jawab untuk bekerja pada tiket tepat waktu. Jika anda tidak mempunyai waktu untuk bekerja padanya, salah satu batalkan pengakuannya atau jangan mengakuinya di tempat pertama!
Jika tidak ada tanda kemajuan pada tiket tertentu yang diakui selama seminggu atau dua minggu, pengembang lain mungkin meminta anda melepaskan pengakuan tiket sehingga itu tidak lagi dikuasai dan seseorang lain dapat mengakuinya.
Jika anda telah mengakui tiket dan itu memakan waktu lama (harian atau mingguan) untuk membuat kode, jaga semua orang terperbaharui dengan menempatkan komentar pada tiket. Jika anda tidak menyediakan pembaharuan reguler, dan anda tidak menjawab pada permintaan untuk laporan kemajuan, pengakuan anda pada tiket mungkin ditarik.
Seperti biasa, komunikasi lebih lebih baik daripada komunikasi kurang!
Tiket mana harus diminta?¶
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. Submit your changes directly and you're done!
It is always acceptable, regardless whether someone has claimed it or not, to link proposals to a ticket if you happen to have the changes ready.
Contribution style¶
Pastikan bahwa tiap sumbangan anda lakukan memenuhi setidaknya persyaratan berikut:
The code required to fix a problem or add a feature is an essential part of a solution, but it is not the only part. A good fix 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 adds a new feature, or modifies the behavior of an existing feature, the change should also contain documentation.
When you think your work is ready to be reviewed, send a GitHub pull request. If you can't send a pull request for some reason, you can also use patches in Trac. When using this style, follow these guidelines.
Ajukan tambalan-tambalan dalam bentuk dikembalikan oleh perintah
git diff
.Lampirkan tambalan ke sebuah tiket dalam ticket tracker, menggunakan tombol "attach file". Tolong jangan taruh tambalan dalam gambaran tiket atau komentar meskipun dia hanya sebuah tambalan baris tunggal.
Nama berkas tambalan dengan perpanjangan
.diff
; ini akan membuat pelacak tiket memberlakukan penyorotan sintaksis benar, yang tentunya sangat membantu.
Tanpa memperhatikan cara anda mengajukan pekerjaan anda, ikuti langkah-langkah ini.
Make sure your code fulfills the requirements in our contribution checklist.
Centang kotak "Has patch" pada tiket dan pastikan kotak-kotak "Butuh dokumentasi", "Butuh percobaan", and "Tambalan butuh perbaikan" tidak dicentang. Ini membuat tiket muncul di antrian "Tambahan butuh ditinjau" pada Development dashboard.
Contributions which require community feedback¶
A wider community discussion is required when a patch introduces new Django functionality and makes some sort of design decision. This is especially important if the approach involves a deprecation or introduces breaking changes.
The following are different approaches for gaining feedback from the community.
The Django Forum¶
You can propose a change on the Django Forum. You should explain the need for the change, go into details of the approach and discuss alternatives.
Please include a link to such discussions in your contributions.
Third party package¶
Django does not accept experimental features. All features must follow our deprecation policy. Hence, it can take months or years for Django to iterate on an API design.
If you need user feedback on a public interface, it is better to create a third-party package first. You can iterate on the public API much faster, while also validating the need for the feature.
Once this package becomes stable and there are clear benefits of incorporating aspects into Django core, starting a discussion on the Django Forum would be the next step.
Django Enhancement Proposal (DEP)¶
Similar to Python’s PEPs, Django has Django Enhancement Proposals or DEPs. A DEP is a design document which provides information to the Django community, or describes a new feature or process for Django. They provide concise technical specifications of features, along with rationales. DEPs are also the primary mechanism for proposing and collecting community input on major new features.
Before considering writing a DEP, it is recommended to first open a discussion on the Django Forum. This allows the community to provide feedback and helps refine the proposal. Once the DEP is ready the Steering Council votes on whether to accept it.
Some examples of DEPs that have been approved and fully implemented:
Mengusangkan fitur¶
Ada sepasang alasan dimana dalam Django mungkin diusangkan:
Jika sebuah fitur telah ditingkatkan atau dirubah di cara ketidaksesuaian-kebelakang, fitur atau kebiasaan lama akan diusangkan.
Terkadang Django akan menyertakan backport dari pustaka Python yang tidak disertakan dalam versi dari Python yang Django saat ini dukung. Ketika Django tidak lagi butuh mendukung versi lama dari Python yang tidak menyertakan pustaka, pustakan akan diusangkan di Django.
Seperti deprecation policy gambarkan, terbitan pertama dari Django yang mengusangkan sebuah fitur (A.B
) harus memunculkan RemovedInDjangoXXWarning
(dimana XX adalah versi Django dimana fitur akan dipindahkan) ketika fitur diusangkan dipanggil. Menganggp kami mempunyai cakupan percobaan baik, peringatan ini dirubah ke kesalahan ketika running the test suite dengan peringatan diadakan: python -Wa runtests.py
. Dengan demikian, ketika menambahkan RemovedInDjangoXXWarning
anda butuh mengurangi atau mensenyapkan tiap peringatan yang dibangkitkan ketika menjalankan percobaan.
Langkah pertama adalah memindahkan tiap penggunaan dari kebiasaan diusangkan oleh Django itu sendiri. Selanjutnya anda dapat peringatan senyap di percobaan yang sebenarnya mencoba kebiasaan diusangkan dengan menggunakan penghias ignore_warnings
, antara pada tingkatan percobaan atau kelas:
Di percobaan khusus:
from django.test import ignore_warnings from django.utils.deprecation import RemovedInDjangoXXWarning @ignore_warnings(category=RemovedInDjangoXXWarning) def test_foo(self): ...
Untuk kasus percobaan keseluruhan:
from django.test import ignore_warnings from django.utils.deprecation import RemovedInDjangoXXWarning @ignore_warnings(category=RemovedInDjangoXXWarning) class MyDeprecatedTests(unittest.TestCase): ...
You should also add a test for the deprecation warning:
from django.utils.deprecation import RemovedInDjangoXXWarning
def test_foo_deprecation_warning(self):
msg = "Expected deprecation message"
with self.assertWarnsMessage(RemovedInDjangoXXWarning, msg) as ctx:
# invoke deprecated behavior
...
self.assertEqual(ctx.filename, __file__)
Sangat penting untuk menyertakan komentar RemovedInDjangoXXWarning
diatas kode yang tidak mempunyai acuan peringatan, tetapi akan butuh dirubah atau dihapus ketika pengusangan berakhir. Ini dapat menyertakan kaitan yang telah ditambahkan untuk menjaga perilaku sebelumnya, atau barang berdiri sendiri yang tidak butuh atau tidak digunakan ketika pengusangan berakhir. Sebagai contoh:
import warnings
from django.utils.deprecation import RemovedInDjangoXXWarning
# RemovedInDjangoXXWarning.
def old_private_helper():
# Helper function that is only used in foo().
pass
def foo():
warnings.warn(
"foo() is deprecated.",
category=RemovedInDjangoXXWarning,
stacklevel=2,
)
old_private_helper()
...
Akhirnya, ada sepasang pembaharuan ke dokumentasi Django untuk dibuat:
Jika fitur yang ada didokumentasikan, tandai dia diusangkan di dokumentasi menggunakan keterangan
.. deprecated:: A.B
. Termasuk gambaran pendek dan catatan tentang jalur peningkatan jika berlaku.Tambah gambaran dari kebiasaan pengusangan, dan tingkatkan jalur jika dapat diterapkan, pada catatan terbitaan saat ini (
docs/releases/A.B.txt
) dibawah kepala "Fitur-fitur diusangkan dalam A.B".Tambah sebuah masukan dalam linimasa pengusangan (
docs/internals/deprecation.txt
) dibawah versi yang sesuai menggambarkan kode apa akan dipindahkan.
Once you have completed these steps, you are finished with the deprecation.
In each feature release, all
RemovedInDjangoXXWarning
s matching the new version are removed.
JavaScript contributions¶
For information on JavaScript contributions, see the Tambalan JavaScript documentation.
Optimization patches¶
Patches aiming to deliver a performance improvement should provide benchmarks showing the before and after impact of the patch and sharing the commands for reviewers to reproduce.
django-asv
benchmarks¶
django-asv monitors the performance of Django code over time. These
benchmarks can be run on a pull request by labeling the pull request with
benchmark
. Adding to these benchmarks is highly encouraged.
Contribution 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, mergers do final reviews of "Ready for checkin" tickets and will either commit the changes or bump it back to "Accepted" if further work needs to be done. If you're looking to become a merger, doing thorough reviews of contributions 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 pull request reviewed? Ensure the Trac flags on the ticket are set so that the ticket appears in that queue.
Dokumentasi¶
Apakah dokumentasi dibangun tanpa kesalahan apapun (
make html
, ataumake.bat html
pada Windows, dari direktoridocs
)?Apakah dokumentasi mengikuti panduan gaya penulisan dalam Menulis dokumentasi?
Apakah ada kesalahan pengejaan?
Kesalahan¶
Apakah ada percobaan pemulihan yang sesuai (percobaan harus gagal sebelum perbaikan diberlakukan)?
If it's a bug that qualifies for a backport to the stable version of Django, is there a release note in
docs/releases/A.B.C.txt
? Bug fixes that will be applied only to the main branch don't need a release note.
Fitur Baru¶
Apakah ada percobaan untuk "latihan" semua kode baru?
Apakah ada sebuah catatan terbitan di
docs/releases/A.B.txt
?Apakah ada dokumentasi untuk fitur dan apakah dia dijelaskan dengan tepat dengan
.. versionadded:: A.B
atau.. versionchanged:: A.B
?
Mengusangkan fitur¶
Lihat panduan Mengusangkan fitur.
Semua kode perubahan¶
Does the coding style conform to our guidelines? Are there any
black
,blacken-docs
,flake8
, orisort
errors? You can install the pre-commit hooks to automatically catch these errors.Jika perubahan adalah kesesuaian kebelakang denganc ara apapun, apakah ada dalam catatan terbitan (
docs/releases/A.B.txt
)?Apakah rangkaian percobaan Django lewat?
Semua tiket¶
Apakah pull request perbaikan lumatan tunggal dengan pesan yang mengikuti commit message format kami?
Are you the patch author and a new contributor? Please add yourself to the AUTHORS file and submit a Contributor License Agreement.