在源码解析过程中,我们已经讲解了 Httprunner(hrp)的核心功能。如果您发现有部分内容不够清楚,或者希望更深入了解特定功能的源代码,欢迎随时联系作者。
对于 Go 语言,很多测试从业者可能对安装第三方库、编译和交叉编译不太熟悉,这可能增加了学习成本。在本文中,我们将详细介绍如何进行编译,而在后续文章中,我们将进一步探讨一些简单的修改,例如跳过逻辑、修改请求和响应的头部状态、使用模拟数据、添加断言等。如果您有二次开发的需求,也可以随时联系作者。
虽然不强制要求修改版本号,但为了更好地区分不同版本,建议您修改版本号,并可以在版本号前或后添加前缀,例如:"yangfan.v4.4.0" 或 "v4.4.0.yangfan"。版本号的存放路径应为:"/httprunner/hrp/internal/version/VERSION",它应该是一个字符串格式的文本文件。
# 首先,将 fork 的项目克隆到本地
git clone git@github.com:taylor9158/httprunner.git
cd httprunner
# 此步骤可以跳过,一般情况下都会出现timeout的错误
go mod tidy
请注意,更新依赖库时可能会因网络问题而出现超时错误。您可以通过设置 Go 代码模块来解决此问题:
go env -w GOPROXY=https://goproxy.cn,direct
go mod tidy
shell
# 此步骤可以跳过,一般情况下都会出现timeout的错误
go mod tidy
#### 错误处理
PS: 当使用 IDE 更新依赖库时,也可能会因网络问题而出现超时错误。您可以通过设置代码模块来解决这个问题在「go 模块」中启用「启用 Go 模块集成」,并在输入框中填入「GOPROXY=https://goproxy.cn,direct」
重新执行「go mod tidy」(这一步骤可选)
如果设置后执行仍然有问题,尝试重启 Goland,然后再次执行「go mod tidy」
在完成依赖安装后,您可以直接执行脚本进行编译,脚本的路径是「scripts/build.sh」,可以通过执行 make 或 bash 来进行编译。
提示:如果在添加了标签后无法成功编译,目前还不清楚问题出在哪里。这是当前系统下的构建文件。如果您想构建适用于其他系统的可执行文件,就需要进行交叉编译。
# Usage:
# $ make build
# $ make build tags=opencv
# or
# $ bash scripts/build.sh
# $ bash scripts/build.sh opencv
这是构建当前系统下用的文件,如果你想构建其他系统的可执行文件,就要用到交叉编译
shell
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 bash scripts/build.sh
## 编译 windows 可执行文件出现错误build.sh
文件中使用编译的命令为go build -ldflags '-s -w' -o "output/hrp" hrp/cmd/cli/main.go
output/hrp
,所以生成的文件无法执行,下面是正确的执行:
shell
CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -ldflags '-s -w' -o "output/hrp.exe" hrp/cmd/cli/main.go