Django使用 Trac 来管理代码基本库上的工作。Trac 是一个由社区管理的花园,里面有人们发现的bug和人们希望看到的功能。就像在任何一个花园里一样,有时有杂草需要拔除,有时有些花和蔬菜需要采摘。我们需要你的帮助,把其中的一个从另一个中挑出,最终我们都能从中受益。
Like all gardens, we can aspire to perfection but in reality there's no such thing. Even in the most pristine garden there are still snails and insects. In a community garden there are also helpful people who -- with the best of intentions -- fertilize the weeds and poison the roses. It's the job of the community as a whole to self-manage, keep the problems to a minimum, and educate those coming into the community so that they can become valuable contributing members.
Similarly, while we aim for Trac to be a perfect representation of the state of Django's progress, we acknowledge that this will not happen. By distributing the load of Trac maintenance to the community, we accept that there will be mistakes. Trac is "mostly accurate", and we give allowances for the fact that sometimes it will be wrong. That's okay. We're perfectionists with deadlines.
We rely on the community to keep participating, keep tickets as accurate as possible, and raise issues for discussion on our mailing lists when there is confusion or disagreement.
Django是一个社区项目,每个贡献都有帮助。没有**你**我们不能这样做!
不幸的是,并不是工单跟踪程序中的所有bug报告和功能请求都提供 required details 。很多工单都有补丁,但这些补丁并不满足一个 good patch 的要求。
One way to help out is to triage tickets that have been created by other users.
大多数工作流都是基于工单的 :ref:`triage stages ` 。每个阶段都描述了在其生命周期中,给定的工单在任何时间的位置。除了一些标志,这个属性可以很容易地告诉我们每张工单在等待什么和谁。
既然一张图片胜过千言万语,那就从这里开始吧:
在这张图表中我们有两个角色:
举个例子,我们可以看到一张普通工单的生命周期:
有些工单需要的反馈比这少得多,但同样有些工单需要更多的反馈。
下面我们将更详细地描述工单在其生命周期中可能经历的各个阶段。
没有任何人对工单是否包含有效问题、可行功能或是否应因任何原因关闭而对工单进行审阅。
大灰色区域!“已接受”的绝对含义是,工单中描述的问题是有效的,并且正处于处理的某个阶段。除此之外,还有几个考虑因素:
已接受并且没有标识
工单是有效的,但是还没有人提交补丁。通常这意味着您可以安全地开始为它编写补丁。对于可接受的bug,这通常比接受的特性更真实。对于一个已经被接受的bug的工单意味着这个问题已经被至少一个trigger验证为合法的bug,并且如果可能的话应该被修复。一个被接受的新特性可能只意味着一个试验者认为该特性将是好的,但这本身并不代表一致的观点,也不意味着某个补丁将被接受。如果您有疑问,请在编写大量补丁之前寻求更多反馈。
已接受并且有补丁
工单正在等待人们查看提供的修补程序。这意味着下载并试用补丁,验证它是否包含测试和文档,使用包含的补丁运行测试套件,并在工单上留下反馈。
已接受并且有补丁,需要...
这意味着工单已经过审核,需要进一步的工作。“需求测试”和“需求文档”是不言而喻的,“补丁需要改进”通常会在工单上附上注释,解释需要改进的代码。
The ticket was reviewed by any member of the community other than the person who supplied the patch and found to meet all the requirements for a commit-ready patch. A committer now needs to give the patch a final review prior to being committed.
There are a lot of pull requests. It can take a while for your patch to get reviewed. See the contributing code FAQ for some ideas here.
图中未显示此阶段。它很少用于跟踪高层次的想法或长期特性请求。
这些工单并不常见,而且总体上没有多大用处,因为它们没有描述具体的可操作问题。如果提交了一个优秀的补丁,我们可能会考虑在框架中添加这些增强请求。它们不是优先考虑的问题。
A number of flags, appearing as checkboxes in Trac, can be set on a ticket:
此标志用于具有需要相关文档的修补程序的工单。完整的特性文档是我们将它们检入代码库之前的先决条件。
这会将补丁标记为需要相关联的单元测试。同样,这是有效补丁程序的必需部分。
需要小的,容易的补丁的工单。
工单应该被分类到*组件*中,指出它们属于Django代码库的哪个区域。这使得工单更有条理,更容易找到。
severity 属性用于标识阻止内容,即在发布下一个Django版本之前应该解决的问题。这些问题通常是导致回滚至早期版本的错误,或者可能导致严重的数据丢失。这个属性很少使用,而且绝大多数罚单的严重性都是“正常”。
可以使用*version*属性来指示在哪个版本中发现了报告的bug。
此标志用于与用户界面和用户体验问题相关的工单。例如,此标志适用于表单或管理后台接口界面中面向用户的功能。
您可以将您的用户名或电子邮件地址添加到该字段,以便在对工单进行新的投稿时收到通知。
使用此字段,您可以用多个关键字标记工单。例如,将同一主题的多张工单组合在一起是很有用的。关键字可以是逗号或空格分隔。关键字搜索在关键字中的任何位置查找关键字字符串。例如,单击关键字为“form”的工单将生成带有关键字标记的类似工单,这些关键字包含“formset”、“modelformset”和“ManagementForm”。
当一个工单已经完成了它的有用的生命周期,是时候关闭它了。不过,关闭工单是一个很大的责任。你必须确保这个问题真的得到了解决,而且你需要记住,工单的报告者可能不乐意关闭他们的工单(除非它被修复了!)。如果你不确定是否要关闭工单,请留下你的注释。
如果您确实关闭了工单,则应始终确保以下事项:
工单可以通过多种方式收尾:
如果您认为错误地关闭了工单——因为您仍然有问题,或者它在其他地方弹出,或者审阅人员出错——请重新打开工单并提供进一步的信息。同样,请不要重新打开标记为“wontfix”的工单,而是将问题提交给| django developers |。
分流过程主要由社区成员推动。真的,**任何人**都能帮上忙。
要想参与其中,首先要 “在Trac上创建一个账户”_ 。如果您有账户但忘记了密码,可以使用 “密码重置页”_ 重置它。
然后,你可这样帮忙:
但是,我们确实要求在工单数据库中工作的所有普通社区成员:
回归是一些较新版本的Django中存在,而较旧的版本中没有的错误。 引入回归的提交是非常有用的信息。了解导致行为改变的提交有助于识别改变是有意的还是无意的副作用。以下是您如何确定这个的。
Begin by writing a regression test for Django's test suite for the issue. For
example, we'll pretend we're debugging a regression in migrations. After you've
written the test and confirmed that it fails on the latest main branch, put it
in a separate file that you can run standalone. For our example, we'll pretend
we created tests/migrations/test_regression.py
, which can be run with:
$ ./runtests.py migrations.test_regression
接下来,由于测试失败,我们将历史记录中的当前点标记为“不良”:
$ git bisect bad
You need to start by "git bisect start"
Do you want me to do it for you [Y/n]? y
现在,我们需要在引入回归之前在git历史中找到一个点(即测试通过的点)。 使用 git checkout HEAD~100
之类的东西来检出一个较早的修订版(在这种情况下为100个较早提交) 检查测试是否失败。如果是这样,请将该点标记为“坏”(git bisect bad
),然后签出较早的修订并重新检查。 找到测试通过的修订后,将其标记为“好”:
$ git bisect good
Bisecting: X revisions left to test after this (roughly Y steps)
...
现在我们已经准备好了有趣的部分:使用 git bisect run
来自动化其余的过程:
$ git bisect run tests/runtests.py migrations.test_regression
您应该看到 git bisect
使用二分搜索来自动检查好提交和坏提交之间的修订,直到找到测试失败的第一个“坏”提交为止。
现在,在Trac工单上报告您的结果,并在附件中包含回归测试。当某人为该错误编写修复程序时,他们已经以您的测试为起点。
12月 13, 2021