Maven + TestNG + Jenkins搭建自动化测试框架

这里没有概念,只有一步一步的实践。
对于什么是Maven,什么是TestNG,什么是Jenkins,请自学~~

创建Maven项目

新建一个Maven项目:
File -> New -> Project -> Maven -> Check "Create from archetype" -> Choose "mave-archetype-quickstart"。


1.png

填写"Name","Location","GroupId","ArtifactId","Version"(都是自定义的)。


2.png

"User settings file"和"Local repository"的路径都可以自定义,它们各自是用来干啥的,请自学。


3.png

创建完成后,可以看到这样的一个example的maven project。


4.png

写测试的过程中,必然会用到很多依赖,比如selenium。
添加依赖:
Code -> Generate -> Dependency


5.png

选择"Dependency"。


6.png

在"Search for artifact"输入所需依赖的名称,选中相应的版本进行添加。


7.png

"selenium-java"的依赖就被添进了pom.xml中。


8.png

添加完成后,需要点击右上角带"m"字样的图标,相应的依赖才会被下载到本地。


9.png

同步完成后,可以看到相应的Libraries被添加到本地。


10.png

相应的文件可以在前边步骤设置的"Local repository"路径里找到,如果没有改,默认是在".m2/repository/"路径下。


11.png

TestNG例子

这里给出一个简单的通过百度进行搜索的例子,里边用到了TestNG的注解、参数化配置、自带的Report,更多其他应用,需要根据实际项目进行有针对性地学习和应用。

代码:


testng_example.png

TestNG的配置文件例子。


testng_xml_example.png

Enable TestNG report的方法。


Edit Configurations for testng.xml file.png

勾选"Use default reporters"选项。


Use default reporters.png

执行测试之后,可以看到自动生成了"test-output"文件夹。
需要特别注意的是,由于用到了TestNG的参数化配置,执行测试的时候,需要右键testng.xml(也就是你自定义的TestNG的配置文件,这里只是我的例子中将配置文件命名为testng.xml)来执行测试。

testng-report_1.png

通过访问"index.html"文件,可以看到测试执行结果。


testng-report_2.png

由于后面需要与Jenkins结合,所以,需要在pom.xml中"maven-surefire-plugin"下添加testng配置文件的信息。


testng-configuration.png

Jenkins

1. Jenkins安装和配置

下载"jenkins.war"文件。
https://www.jenkins.io/download/

在命令行输入"java -jar jenkins.war"命令,启动Jenkins。


1.png

当在terminal里看到"Jenkins is fully up and running",就可以在浏览器通过localhost:8080来访问Jenkins。
页面打开之后,需要你输入管理员密码(Administrator password),这个密码从页面上显示的文件里获得。


2.png

安装Plugin。(如果不确定安装什么plugin,选择"Install suggested plugins"先安装一些它建议的plugin就好。)


3.png
4.png

Plugin安装好之后,会弹出创建管理员用户的的界面,以后可以使用这个用户进行登录。


5.png

可以使用默认URL。


6.png
7.png

2. Jenkins安装和配置

点"Manage Jenkins"对Jenkins进行配置。


8.png

选择"Global Tool Configuration"。


9.png

添加Java和Maven的Home路径。


10.png

选择"Manage Plugins",安装"Maven Integration plugin"。


11.png

安装完毕会跳出等待页面,稍等一会儿。


安装完plugin后.png

3.Jenkins与Maven项目集成

GitHub上生成新token。
"Settings -> Developer settings -> Personal access token -> Generate new token"。


GitHub上生成一个新token.png

勾选"repo"和"admin:repo_hook"。


2.png

把生成的token保存到本地,因为再次进到这里,就看不见了,后边会用到这个token。


3.png

到指定的项目中。
"Settings -> Webhooks -> Add webhook"。


4_指定的项目上Add webhook.png

输入Payload URL。
http://:8080/github-webhook/


5_Jenkins服务器IP.png

回到Jenkins。
"Manage Jenkins -> Configuration System"。


6_ConfigureSystem.png

添加GitHub server。


7.png

Name自定义,API URL默认,点击"Add"添加Credential。


8.png

"Kind"选成"Secret text","Secret"部分将之前在GitHub上生成的token填写进去。


9.png

将"Credentials"部分选成添加的Credential,然后点击"Test connection"测试一下Jenkins跟GitHub的是否连接成功。
注意:默认Credentials部分选中的是"None",一定要手动改成自己创建的Credential。

10.png

新建构建项目。
"New item"。


11.png

自定义项目名称,然后选择"Maven project"。


12.png

"General"部分:

  1. 可以写一些描述。
  2. 勾选"GitHub project",填写项目所在的GitHub的URL。


    13.png

"Source Code Management"部分:

  1. 选择"Git"。
  2. "Repository URL"填写项目的git地址。
  3. "Credentials"添加登录GitHub的用户名和密码,并选择所添加的Credential(默认选中的是"None")。
  4. "Repository browser"部分选择"githubweb"。
  5. "URL"部分填写项目所在的GitHub的URL。


    14.png

"Build Triggers"部分选择在什么情况下进行trigger。


15.png

也可以通过规则,周期性地进行trigger。


16.png

"Build Environment"部分勾选"Use secret text(s) or file(s)"。


17.png

"Binding"部分:
"Add -> Secret text"。


18.png

"Credentials"部分选择之前的secret text。


19.png

"Build"部分填写pom.xml。


20.png

保存以上配置之后,进入所创建的构建项目,点击"Build Now"。


21.png

相应的测试会在Build成功之后自动运行。
可以从"Console Output"看到整个过程的日志。


22.png

你可能感兴趣的:(Maven + TestNG + Jenkins搭建自动化测试框架)