github.com/google/syzkaller@v0.0.0-20251211124644-a066d2bc4b02/docs/translations/zh_CN/maintaining.md (about) 1 > [!WARNING] 2 > 3 > **请注意,这是社区驱动的官方 syzkaller 文档翻译。当前文档的最新版本(英文版)可在 [docs/maintaining.md](/docs/maintaining.md) 中找到。** 4 5 # 维护者指南 6 7 ## 线性历史 8 9 我们保持线性历史记录,并在仓库设置中禁用合并提交(merge commit)。 10 拉取请求(PR)仅有两个选项: 11 - **变基合并(Rebase and merge)**\ 12 若 PR 中的所有提交已妥善整理/修复,优先选择此方式, 13 因其保留 PR 中的提交记录(将 PR 中的所有提交直接添加至 master 分支的最新提交之上)。 14 - **压缩合并(Squash and merge)**\ 15 若 PR 包含分散的修正提交或提交组织混乱时优先选择此方式 16 (将 PR 中的所有提交压缩为单个提交并添加至 master 分支的最新提交之上,同时允许编辑提交主题/描述)。 17 18 ## PR 检查 (CI) 19 20 合并前需通过 `cla/google` 检查。 21 22 合并前通常需通过所有 CI 测试。\ 23 例外情况包括基础设施偶发问题(尤其是外部服务:`codecov`、`ci/fuzzit`) 24 以及偶现的超时/内存溢出(但若 PR 本身显著增加此类问题频率则不可豁免)。所有静态检查警告和测试错误均视为严重问题。 25 26 ## 测试 27 28 原则上鼓励为新代码和错误修复添加测试。应要求贡献者补充测试。 29 30 但不同代码的测试难度存在差异。 31 以下情况更易添加测试(建议补充):无外部依赖的抽象功能(如解析器、数据转换、计算逻辑);已有成熟测试基础设施的代码(添加新测试仅需遵循现有模式)。 32 以下情况测试难度较高(可不强制要求,但仍欢迎补充):存在难以模拟的外部依赖的代码(qemu、内核、镜像等);缺乏现成测试基础设施,需先构建整套框架才能添加测试的代码。 33 34 ## 善用判断力 35 36 当前暂无严格的审查/所有权规则,请灵活运用判断力。 37 38 若您负责项目的特定领域(如某操作系统的支持),可自行合并变更而无需额外审查(尤其小型变更且 CI 通过时)。 39 亦可审查并合并项目其他部分的变更。若信心不足或需要额外意见,请与其他维护者协同处理。