跳到主要内容

Issue 须知

Issues 功能被用来追踪各种特性,Bug,功能等。项目维护者可以通过 Issues 来组织需要完成的任务。

Issue 是引出一个 Feature 或 Bug 等的重要步骤,在单个 Issue 中可以讨论的内容包括但不限于 Feature 的包含的功能,存在的 Bug 产生原因,前期方案的调研,以及其对应的实现设计和代码思路。

并且只有当 Issue 被 approve 之后才需要有对应的 Pull Request 去实现。

如果是一个 Issue 对应的是一个大 Feature,建议先将其按照功能模块等维度分成多个小的 Issue。

Issue 标题

标题格式:[Issue 类型][`模块名`] Issue 描述

其中Issue 类型如下:

Issue 类型描述样例
Feature包含所期望的新功能新特性 [Feature][admin] Add xxx admin in xxx controller
Bug程序中存在的Bug[Bug][admin] Throw exception when xxx
Improvement针对目前程序的一些改进,不限于代码格式程序性能[Improvement][executor] Improve xxx on executor
Test专门针对测试用例部分[Test][metadata-mysql] Add xxx metadata-mysql test
Sub-Task一般都是属于Feature 类的子任务,针对大 Feature,可以将其分成很多个小的子任务来一一完成[Sub-Task][executor] Implement xxx in xxx

其中模块名如下:

模块名描述
apiweb api模块
common公共模块
dao数据库模块
workerworker模块

Bug 类 Issue

当您发现一个 Bug 时,请提交一个 Issue 类的 Bug,提交前:

  • 请先在 issue 列表里查找一下是否该 Bug 已经提交,如果已经有此 Bug,请在此 Bug 下接着回复。
  • 如果该 Bug 是可以复现的。请尽量提供完整的重现步骤。

请在 Issues 页面中提交 Bug。

一个高质量的 Bug 通常有以下特征:

  • 使用一个清晰并有描述性的标题来定义 Bug。
  • 详细的描述复现 Bug 的步骤。包括您的配置情况,预计产生的结果,实际产生的结果。并附加详细的 TRACE 日志。
  • 如果程序抛出异常,请附加完整的堆栈日志。
  • 如有可能,请附上屏幕截图或动态的 GIF 图,这些图片能帮助演示整个问题的产生过程。
  • 哪个版本。
  • 需要修复的优先级(危急、重大、次要、细微)。

下面是 Bug 的 Markdown 内容模板,请按照该模板填写 issue。

**标题** 
标题格式: [BUG][Priority] bug标题
Priority分为四级: Critical、Major、Minor、Trivial

**问题描述**
[清晰准确描述遇到的问题]

**问题复现步骤:**
1. [第一步]
2. [第二步]
3. [...]

**期望的表现:**
[在这里描述期望的表现]

**观察到的表现:**
[在这里描述观察到的表现]

**屏幕截图和动态GIF图**
![复现步骤的屏幕截图和动态GIF图](图片的url)

**DataSophon 版本:(以1.0.1为例)**
-[1.0.1]

**补充的内容:**
[请描述补充的内容,比如]

**需求或者建议**
[请描述你的需求或者建议]

Feature 类 Issue

提交前:

  • 请确定这不是一个重复的功能增强建议。 查看 Issue Page 列表,搜索您要提交的功能增强建议是否已经被提交过。

请在 issues 页面中提交 Feature。

一个高质量的 Feature 通常有以下特征:

  • 一个清晰的标题来定义 Feature
  • 详细描述 Feature 的行为模式
  • 说明为什么该 Feature 对大多数用户是有用的。新功能应该具有广泛的适用性。
  • 尽量列出其他平台已经具备的类似功能。商用与开源软件均可。

以下是 Feature 的 Markdown 内容模板,请按照该模板填写 issue 内容。

**标题** 
标题格式: [Feature][Priority] feature标题
Priority分为四级: Critical、Major、Minor、Trivial

**Feature的描述**
[描述新Feature应实现的功能]

**为什么这个新功能是对大多数用户有用的**
[解释这个功能为什么对大多数用户是有用的]

**补充的内容**
[列出其他的调度是否包含该功能,是如何实现的]

Contributor

除一些特殊情况之外,在开始完成 Issue 之前,建议先在 Issue 下或者邮件列表中和大家讨论确定设计方案或者提供设计方案,以及代码实现思路。

如果存在多种不同的方案,建议通过邮件列表或者在 Issue 下进行投票决定,最终方案和代码实现思路被 approve 之后,再去实现,这样做的主要目的是避免在 Pull Request review 阶段针对实现思路的意见不同或需要重构而导致 waste time。

相关问题

  • 当出现提出 Issue 的用户不清楚该 Issue 对应的模块时的处理方式。

    确实存在大多数提出 Issue 用户不清楚这个 Issue 是属于哪个模块的,其实这在很多开源社区都是很常见的。在这种情况下,其实 committer/contributor 是知道这个 Issue 影响的模块的,如果之后这个 Issue 被 committer 和 contributor approve 确实有价值,那么 committer 就可以按照 Issue 涉及到的具体的模块去修改 Issue 标题,或者留言给提出 Issue 的用户去修改成对应的标题。