参与贡献
感谢你对 Yuxi-Know 项目的兴趣!我们欢迎任何形式的贡献,包括但不限于代码提交、功能建议、问题反馈和文档改进。
贡献流程
1. Fork 项目
在 GitHub 上点击 Fork 按钮,将项目复制到你的账户。
2. 创建功能分支
bash
git checkout -b feature/amazing-feature3. 开发并提交
bash
git commit -m 'feat: 添加新功能'4. 推送代码
bash
git push origin feature/amazing-feature5. 创建 Pull Request
在 GitHub 上创建 PR,详细描述你的更改内容和动机。
代码规范
项目对代码质量有一定要求,提交前请确保:
- Python 代码使用
make format格式化 - 使用
make lint检查代码质量 - 添加必要的测试用例
- 更新相关文档
提交信息规范
使用清晰规范的提交信息:
feat: 添加新功能
fix: 修复 bug
docs: 更新文档
style: 代码格式调整
refactor: 代码重构
test: 添加测试
chore: 构建过程或辅助工具的变动Bug 修复发布流程
当发布后发现 bug 需要修复时:
情况 1:main 上没有未完成的新功能
直接在 main 修复并发布:
bash
git commit -m "fix: 解决配置解析器崩溃问题"
git tag -a v0.3.1 -m "Hotfix v0.3.1"
git push origin main --tags情况 2:main 上已有新功能未完成
从上一个 tag 建立 hotfix 分支:
bash
git checkout -b hotfix/0.3.1 v0.3.0
# 修复问题
git commit -m "fix: 解决配置解析器崩溃问题"
git push origin hotfix/0.3.1
# 测试后合并回 main 并打 tag
git checkout main
git merge --no-ff hotfix/0.3.1
git tag -a v0.3.1 -m "Hotfix v0.3.1"
git push origin main --tags
# 删除临时分支
git branch -d hotfix/0.3.1
git push origin --delete hotfix/0.3.1测试指南
运行测试
bash
# 全量路由测试
make router-tests
# 运行特定测试
make router-tests PYTEST_ARGS="-k knowledge_router"
# 直接运行 pytest
uv run --group test pytest test/api -vv测试配置
首次运行测试前,需要配置测试凭据:
bash
cp test/.env.test.example test/.env.test感谢每一位贡献者的付出!