用go设计开发一个自己的轻量级登录库/框架吧(项目维护篇)
本篇将开始讲讲开发库/框架的最开始阶段,也就是搭建一个项目
源码:weloe/token-go: a light login library (github.com)
项目结构
项目结构,不是上一篇所说的代码架构,而是分包,明确的分包更有助于我们的开发。本框架分包如下
├─.github│ └─workflows GitHub工作流├─auth权限管理├─config配置├─constant常量├─ctxweb上下文│ └─go-http-context├─error├─examples使用示例├─log日志├─model模型├─persist持久层└─util 工具包
代码托管以及自动化测试
我们选择使用GitHub进行代码托管,同时也使用GitHub Actions进行代码自动化测试。运行测试代码以及使用lint检查代码规范。
token-go/go.yml at master · weloe/token-go · GitHub
name: Go-Build-Teston: [push, pull_request]jobs: test: runs-on: ubuntu-latest strategy: matrix: go: [ '1.18', '1.19', '1.20' ] steps: - uses: actions/checkout@v2 - name: Set up Go uses: actions/setup-go@v2 with: go-version: ${{ matrix.go }} - name: Run go test run: go test -v ./... benchmark: runs-on: ubuntu-latest strategy: matrix: go: [ '1.18' ] steps: - uses: actions/checkout@v2 - name: Set up Go uses: actions/setup-go@v2 with: go-version: ${{ matrix.go }} - name: Run go test bench run: go test -bench=. lint: runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 - name: Set up Go uses: actions/setup-go@v2 with: go-version: '1.20' - name: golangci-lint uses: golangci/golangci-lint-action@v3 with: version: v1.51
测试
在进行代码开发的同时,我们也应该进行代码测试用例的编写,提高代码测试覆盖率,确保我们的代码的健壮性。
文档
文档可以说是一个开源库/框架必不可少的东西,我们开始学习一个开源库/框架也往往是从文档开始。我们可以使用Docsify,Vuepress等来快速搭建一个文档网站。关于如何搭建文档可以看看这篇随笔https://www.cnblogs.com/weloe/p/17374287.html