基于 python3.8 的新 api server
python 版本: 3.8
使用poetry进行依赖管理。
git clone https://github.com/bangumi/server bangumi-server
cd bangumi-server
进入虚拟环境
python -m venv .venv # MUST use python 3.8
source .venv/bin/activate # enable virtualenv
安装依赖
poetry install --remove-untracked
安装 git hook
pre-commit install
可设置的环境变量
MYSQL_HOST
默认127.0.0.1
MYSQL_PORT
默认3306
MYSQL_DB
默认bangumi
MYSQL_USER
无默认值MYSQL_PASS
无默认值REDIS_URI
默认redis://127.0.0.1:6379/0
你也可以把配置放在 ./env/dev
文件中,如果在环境变量中找不到对应的值,会在这个文件中查找
example:
MYSQL_HOST="127.0.0.1"
MYSQL_PORT="3306"
MYSQL_USER="username"
MYSQL_PASS="password"
MYSQL_DB="bangumi"
REDIS_URI="redis://:pass@127.0.0.1:6379/1"
相关项目整体说明 bangumi/dev-docs
Web 框架 fastapi
ORM 类定义在 pol/db/tables.py 文件。
路由位于 pol/api 文件夹。
redis 和 mysql 都在此 docker-compose 内。 https://github.com/bangumi/dev-env
如果你不是 docker 用户,请自行启动 mysql 和 redis 并导入bangumi/dev-env
仓库内的数据。
启动 web 服务器,默认为 3000
端口,在代码修改后会自动重启。
watchgod scripts.dev.main
如果你的 PR 是新功能,最好先发个 issue 讨论一下要不要实现,避免 PR 提交之后新功能本身被否决的问题。
如果已经存在相关的 issue,最好先在 issue 内回复一下自己的意向,或者创建一个 Draft PR 关联对应的 issue,避免撞车问题。
测试基于 pytest
pytest
参照 tests/app/test_base_router.py 文件。在测试函数中添加client
参数获取对应的 HTTP 测试客户端。client
是一个 requests.Session
的实例,可以使用 requests
的各种函数参数。
以 LF 为换行符
启用 pre-commit
pre-commit install
pre-commit 会在当前仓库安装一个 git hook,在每次 commit 前自动运行。
也可以手动运行
pre-commit run #only check changed files
pre-commit run --all-files # check all files
lint: flake8
非 python 文件(yaml, json, markdown 等)使用 prettier 进行格式化。
pol 来源于我的旧项目名,没有特殊含义。
BSD 3-Clause License