前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >.NETCore下CI/CD之自动化测试

.NETCore下CI/CD之自动化测试

作者头像
梁规晓
发布2019-10-31 21:43:14
8910
发布2019-10-31 21:43:14
举报

前言

为了呼应《中国.NET开发者峰会2019上海站》,作为演讲嘉宾,我希望和各位同行建立更多的互动,为此,我特地将部分演讲内容,整理成文章先行发布。本文从零开始,一步一步的引导,从安装JDK/Tomcat/jenkins 到建立第一个 CI/CD 项目,确保按照本文指引,能快速的在 CentOS 下,将 .NET Core 通过 jenkins 进行持续集成/持续部署,通过 jenkins,实现集成测试自动化,最终达到,快速构建项目,执行单元测试,生成测试报告,发送测试报告等工作,让测试工作伴随着 CI/CD 的持续进行而不断的对输出进行测试和校正,真正实现让本地单元测试在 CI/CD 中发挥其巨大的威力。

安装JDK

首先安装Java环境,在Centos7上,搜索仓库内的包包

yum search java | grep --color OpenJDK

可以看到一堆颜色鲜艳的Java包包,接下来执行安装openjdk

yum install java-1.8.0-openjdk java-1.8.0-openjdk-devel

安装完成后,执行命令

java -version
# 输出 OpenJDK 64-Bit Server VM (build 25.222-b10, mixed mode) 表示安装成功

安装 Tomcat

安装Tomcat的话,直接下载Tomcat的zip包,下载地址:http://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-9/v9.0.27/bin/apache-tomcat-9.0.27.tar.gz 到官网下载是个好习惯,认准这只猫;然后上传到服务器,解压 比如我目前上传到目录:/usr/local/,执行解压命令,然后删除压缩包

tar -zxf apache-tomcat-9.0.27.tar.gz tomcat
rm -f apache-tomcat-9.0.27.tar.gz

实际上,按照一般情况下,直接执行下面的命令可以直接运行 Tomcat

/usr/local/tomcat/bin/startup.sh

但是作为测试要尽量贴近实际环境的极客追求来说,我们要把 Tomcat 作为系统服务,在系统开关机的时候随系统启动,那么就需要多做点小工作,不需要担心,下面的工作一共就花了2分钟左右

首先,我们需要指定 Tomcat.PID 进程文件,进入 /usr/local/tomcat/bin,编辑文件

vi /usr/local/tomcat/bin/setenv.sh
// 输入
CATALINA_PID="$CATALINA_BASE/tomcat.pid"JAVA_OPTS="-server -XX:MetaspaceSize=256M -XX:MaxMetaspaceSize=1024m -Xms512M -Xmx1024M -XX:MaxNewSize=256m"
// 保存,退出编辑

增加 tomcat 账户并赋予权限

getent group tomcat || groupadd -r tomcat
getent passwd tomcat || useradd -r -d /opt -s /bin/nologin -g tomcat tomcat
chown -R tomcat:tomcat /usr/local/tomcat

防止Jeknins报错,先打个预防针,创建 .jenkins 目录

mkdir /opt/.jenkins
chown -R tomcat:tomcat /opt/.jenkins

编写系统服务文件

进入目录 cd /usr/lib/systemd/system,执行 ls -l,可以看到很多服务文件,然后我们直接执行下面的命令新建并编辑文件 tomcat.service

vi tomcat.service

tomcat.service 输入以下内容

[Unit]
Description=tomcat
After=syslog.target network.target remote-fs.target nss-lookup.target

[Service]
Type=forking
Environment="JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.222.b10-1.el7_7.x86_64"
PIDFile=/usr/local/tomcat/tomcat.pid
ExecStart=/usr/local/tomcat/bin/startup.sh
ExecStop=/usr/local/tomcat/bin/shutdown.sh
ExecReload=/bin/kill -s HUP $MAINPID
PrivateTmp=true
User=tomcat
Group=tomcat

[Install]
WantedBy=multi-user.target

// 保存,退出

系统服务文件创建完成,输入命令3连

systemctl enable tomcat.service
systemctl start tomcat.service
system status tomcat.service

如果以上的命令没有报错,那么恭喜你,你已经成功部署了 Tomcat 服务,接下来就是部署 jenkins 到 Tomcat

部署并运行jenkins

下载 jenkins 的war 包包,地址:https://jenkins.io/zh/download/ ,由于我们使用 Tomcat 托管,直接选择 Generic Java package(.war)下载即可

下载完成,直接将该 jenkins.war 包上传到 Tomcat 服务器目录 /usr/local/tomcat/webapps/ 下,这个时候你应该喝杯咖啡;稍等一会,Tomcat 马上就把 jenkins 做好了,大概在1分钟后,访问 jenkins 站点的地址

http://172.16.1.202:8080/jenkins

在 CentOS上,正常情况下,你是无法访问该地址的,需要打开 Tomcat 这只猫猫的侦听端口:8080,执行下面的命令,完成防火墙的设置

firewall-cmd --zone=public --add-port=8080/tcp --permanentfirewall-cmd reload

再次访问 jenkins 的地址,你应该看到下面这个界面:

首次访问,按照提示,直接复制密码 cat /opt/.jenkins/secrets/initialAdminPassword 到输入框中进入 jenkins,稍后还需要创建用户,一并设置完成即可

等待 jenkins 初始化完成,可选择安装推荐的插件

请耐心等待插件安装完成....

设置账号密码

Jenkins已就绪

安装 .NET Core 环境

相信来到这个环节,大家都松了一口气,毕竟安装 sdk/runtime 这种事情,微软已经帮我们把脚本写好了,直接 copy 使用即可。访问 https://dotnet.microsoft.com/download/linux-package-manager/centos7/sdk-current

sudo rpm -Uvh https://packages.microsoft.com/config/centos/7/packages-microsoft-prod.rpm
// 本文演示还是使用 2.2
sudo yum install dotnet-sdk-2.2

安装完成,按照国际惯例,输入 dotnet --version,输出版本号即为安装成功

创建一个.NET Core 的解决方案,包含单元测试

一个相对标准的解决方案结构如下,解决方案中必须包含 src/test 两个基础项目,表示该项目有单元测试,没有单元测试的项目是不完整的,这应当成为一种良好的编程规范。项目建立完成,我们本地执行单元测试看看结果。

dotnet test

其中,Ron.XUnitTest 项目使用了托管测试主机的方式运行单元测试,默认的测试结果文件是 .trx 格式,在 jenkins 上执行发送测试报告的时候, jenkins 将无法解析,为了使用测试结果文件,我们还必须引用另外一个 nuget 包:XunitXml.TestLogger,该组件赋予我们将 dotnet test 的结果文件转换为 xUnitXml 文件的能力。

控制台输出结果如下:

一共有12项测试,其中全部通过。本地测试已经通过。接下来我们就开始使用 jenkins 构建 .NET Core 程序。

jenkins配置邮件通知

为了实现发送测试报告的功能,我们需要在 jenkins 中配置邮件服务器,点击 Manage Jenkins -> Configure System -> Email notification

配置系统管理员邮件地址

配置 Smtp 服务器

创建第一个 CI/CD 项目

创建任务

点击 “开始创建一个新任务”,输入任务名称,选择自由风格的项目,点击确定,然后马上就进入了任务详细配置的界面。

源码管理,选择 git

由于我的测试项目托管在 GitHub 上,所以我填入 GitHub 的项目地址:https://github.com/lianggx/RonTest.git,身份验证,我选择添加一个认证信息。

编写构建脚本

接下来,直接拉到底部,在构建选项这里选择“增加构建步骤”,选择 “执行 shell”。输入构建脚本。

echo '==============准备开始构建=================='
pwd

cd src/Ron.Blogs
sudo dotnet restore
sudo dotnet build
sudo dotnet publish --framework netcoreapp2.2 -o /data/sites/RonTest

echo '==============构建完成=================='

编写测试脚本

再次增加一个构建步骤,“执行 shell”。输入脚本

sudo dotnet test test/Ron.XUnitTest/Ron.XUnitTest.csproj --logger:"xunit;LogFileName=TestResult.xml"

这里有一个细节,就是在执行命令的时候带了一个参数 --logger:"xunit;LogFileName=TestResult.xml",表示输出测试结果为 xunit 格式的 xml 文件,该文件将在下面的测试报告环节使用。

演示到了这里,有点走不下去,因为我们要解析测试报告,但是这个时候我们需要去安装一个插件,否则无法解析

安装 jenkins 必须插件

返回 jenkins 首页,依次点击 Manage Jenkins -> Manage Plugins -> Available(可选插件),搜索 TestComplete xUnit ,勾选,选择直接安装即可。

发送测试报告配置

安装完成后,再次进入任务配置页,添加构建后操作,选择:Publish xUnit test result report,Report Type 选择 xUnit.NET-v2(default),Pattern 输入测试报告生成的路径:

test/Ron.XUnitTest/TestResults/TestResults.xml

配置邮件接收人

继续添加构建后操作步骤 E-mail notification

保存配置,立即构建!

构建成功,获得报表

收到邮件通知

一个小细节

由于我是从安装 CentOS 开始做起,在开始构建的时候还有一个错误,就是报:sudo: no tty present and no askpass program specified,如果有碰到的同学,请勿惊慌,编辑下面的文件可解决问题

vi /etc/sudoers
// 定位到文件末尾,增加两个用户的配置,保存即可
jenkins ALL = NOPASSWD:ALL
tomcat ALL = NOPASSWD:ALL

结束语

本文详细介绍了从零开始,如何利用 jenkins 对 .NET Core 项目进行 CI/CD 下的集成自动化测试,对于即将开展或者已经开展 CI/CD 化的项目具有一定的参考意义,篇幅较长,由于篇幅较长,难免有所疏漏,欢迎指正。文章参考:https://www.cnblogs.com/ieinstein/p/7096650.html

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-10-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 DotNet程序园 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 安装JDK
  • 安装 Tomcat
    • 首先,我们需要指定 Tomcat.PID 进程文件,进入 /usr/local/tomcat/bin,编辑文件
      • 增加 tomcat 账户并赋予权限
        • 防止Jeknins报错,先打个预防针,创建 .jenkins 目录
          • 编写系统服务文件
            • tomcat.service 输入以下内容
              • 系统服务文件创建完成,输入命令3连
              • 部署并运行jenkins
                • 设置账号密码
                  • Jenkins已就绪
                  • 安装 .NET Core 环境
                  • 创建一个.NET Core 的解决方案,包含单元测试
                  • jenkins配置邮件通知
                    • 配置系统管理员邮件地址
                      • 配置 Smtp 服务器
                      • 创建第一个 CI/CD 项目
                        • 创建任务
                          • 源码管理,选择 git
                            • 编写构建脚本
                              • 编写测试脚本
                              • 安装 jenkins 必须插件
                              • 发送测试报告配置
                                • 配置邮件接收人
                                  • 构建成功,获得报表
                                    • 收到邮件通知
                                    • 一个小细节
                                      • 结束语
                                      相关产品与服务
                                      持续集成
                                      CODING 持续集成(CODING Continuous Integration,CODING-CI)全面兼容 Jenkins 的持续集成服务,支持 Java、Python、NodeJS 等所有主流语言,并且支持 Docker 镜像的构建。图形化编排,高配集群多 Job 并行构建全面提速您的构建任务。支持主流的 Git 代码仓库,包括 CODING 代码托管、GitHub、GitLab 等。
                                      领券
                                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档