基于Docker构建CI/CD工具链(八)用nginx收集测试报告

当前,我们已经介绍了如何使用 Apifox 和 JMeter 进行测试,尽管控制台已经输出了测试结果,但在实际工作中,我们通常需要更详细的测试报告。

测试报告在测试过程中已经生成,只需将其托管起来以便查阅。如果你有现成的 CMS 系统,将这些报告发布到 CMS 系统中是一个不错的选择。今天,我们将使用 Nginx 搭建一个静态资源服务器,并将测试报告推送到该服务器上,然后通过浏览器访问测试报告。

运行nginx

我们依旧通过Docker的方式运行nginx,当然你可以根据自己需要手动构建自己的镜像。

  1. 创建映射目录

我们在宿主机创建静态资源目录,映射到ngixn容器内/usr/share/nginx/html

bash 复制代码
mkdir -p /home/copier/cicd
  1. 创建nginx的配置文件
    在刚才的目录下创建nginx.conf文件,后续会把该文件映射为nginx的/etc/nginx/conf.d/default.conf文件。

    server {
    listen 80;
    server_name localhost;

    复制代码
     location / {
         root /usr/share/nginx/html;
         autoindex on;
     }

    }

  • root /usr/share/nginx/html; 指定了要列出文件的根目录路径。
  • autoindex on; 启用了自动索引功能,这允许浏览器显示目录中的文件列表。
  1. 启动nginx容器

nginx容器启动非常简单,使用如下命令就可,启动后通过"http://xx.xx.xx.xx:8080"便可以访问。

bash 复制代码
docker run --name nginx -p 8080:80 \
 -v /home/copier/cicd:/usr/share/nginx/html:ro \
 -v /home/copier/cicd/nginx.conf:/etc/nginx/conf.d/default.conf:ro \
 -d nginx

修改测试用例的脚本

修改上篇文章提到的test.sh,其内容如下,注意修改的密码。

bash 复制代码
#!/bin/bash
# 获取当前目录路径,用于后续挂载到 Docker 容器中
APP_ROOT=$(pwd)
mkdir -p report/${CI_JOB_ID}/
Host_Password="你的密码"

# 通过CI_JOB_ID 把所有的报告关联起来,所有报告放在静态资源服务器同一级目录
APIFOX_REPORT="/app/report/${CI_JOB_ID}/apifox"
JMETER_REPORT="/app/report/${CI_JOB_ID}/jmeter"
# 使用 Docker 容器运行 APIFox 测试
docker run --rm \
    -v /home/copier/.m2/:/root/.m2/ \
    -v $APP_ROOT:/app \
    -w /app \
    docker.mvcode.cn:8083/apifox:1.0.0 apifox run -k \
    --out-dir ${APIFOX_REPORT} --out-file apitest -r html,cli \
    --env-var "serverURL=http://192.168.3.52:9999" \
    ./testcases/usertest.apifox-cli

# 新增满足测试需求的数据
docker run --rm \
docker.mvcode.cn:8083/devtools:1.0.0 \
curl -X POST -H "Content-Type: application/json" \
  -d '{"name": "John", "age": 30}' \
   http://192.168.3.52:9999/users

# 使用 Docker 容器运行 JMeter 测试
docker run --rm -v ${APP_ROOT}:/app -w /app \
   docker.mvcode.cn:8083/jmeter:5.6.3 jmeter \
   -n -j ${JMETER_REPORT}/test_jmeter.log \
   -l ${JMETER_REPORT}/replort_jmeter.log \
   -o ${JMETER_REPORT} \
   -JServerHost=192.168.3.52 \
   -JServerPort=9999 \
   -JThreadCount=20 \
   -JThreadCount=5 \
   -t ./testcases/jmeter.jmx -e -f

# 打包测试报告
tar -czf report.tar.gz -C ./report ${CI_JOB_ID}

# 将测试报告传输到远程服务器
docker run --rm  -v $APP_ROOT:/app \
     -w /app \
      docker.mvcode.cn:8083/devtools:1.0.0 \
      sshpass -p $Host_Password scp -o StrictHostKeyChecking=no \
      ./report.tar.gz  [email protected]:/home/copier/cicd/

# 解压并删除远程服务器上的测试报告
docker run --rm  -v $APP_ROOT:/app \
     -w /app \
      docker.mvcode.cn:8083/devtools:1.0.0 \
      sshpass -p $Host_Password  ssh -o StrictHostKeyChecking=no  \
      [email protected] \
      "tar -xzf /home/copier/cicd/report.tar.gz -C /home/copier/cicd/ && rm -f /home/copier/cicd/report.tar.gz"

# 输出测试报告地址
echo "测试报告地址如下: http://192.168.3.52:8080/${CI_JOB_ID}/"

运行CI/CD JOB

测试JOB完成后可以看到,输出结果。

访问提示的中地址,nginx可以把目录列举出来

查看 Apifox报告

查看Jmeter报告

相关推荐
专注VB编程开发20年12 分钟前
VB.NET Asp.Net Core模板WebAPI应用-宝塔面板Linux系统通过Docker部署
linux·docker·.net
backRoads40 分钟前
docker部署rabbitmq
docker·容器·rabbitmq
三天不学习2 小时前
NginxWebUI:可视化 Nginx 配置管理工具,告别繁琐命令行!
运维·nginx
穷儒公羊3 小时前
第一部分——Docker篇 第六章 容器监控
运维·后端·学习·docker·云原生·容器
CAE虚拟与现实3 小时前
记录一下学习docker的命令(不断补充中)
学习·docker·容器·容器化·docker部署·docker命令
西柚啊6 小时前
从零到一:前端CI/CD工作流搭建实践
ci/cd
全镇人的希望6 小时前
[特殊字符] 企业级Docker私有仓库实战:3步搭建Harbor安全仓库,镜像管理从此高效无忧
docker·运维开发·私有化
穷儒公羊7 小时前
第一部分——Docker篇 第三章 构建自定义镜像
java·运维·后端·学习·docker·云原生·容器
weixin_428498498 小时前
Docker 容器内运行程序的性能开销
docker·容器
ak啊8 小时前
Nginx 动态模块配置指南(以 Brotli 模块为例)
nginx