Jenkins持续集成(上篇)—新手

Posted 软件测试自动化测试

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jenkins持续集成(上篇)—新手相关的知识,希望对你有一定的参考价值。

目录

 

(一)持续集成与 Jenkins 介绍

(二)Jenkins 环境搭建

(三)Jenkins 创建构建任务

(四)Jenkins 配置构建执行状态

总结


(一)持续集成与 Jenkins 介绍

持续集成


持续集成(Continuous integration,简称 CI),随着近几年的发展,持续集成在项目中得到了广泛的推广和应用。本章将带领读者一起了解持续集成工具 Jenkins 的安装与使用。

1.什么是持续集成?

软件集成就是用一种较好的方式,使多种软件的功能集成到一个软件里,或是把软件的各部分组合在一起。如果项目开发的规模较小,且对外部系统的依赖很小,那么软件集成不是问题,例如一个人的项目。但是随着软件项目复杂度的增加,会对集成和确保软件组件能够在一起工作提出了更多的要求-->要早集成、常集成。早集成、频繁的集成能够帮助项目开发者在早期发现项目风险和质量问题,越到后期发现的问题,解决的成本越高,从而有可能导致项目延期或者项目失败。

2.定义

大师 Martin Fowler 对持续集成是这样定义的:持续集成是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译、发布、自动化测试)来验证,从而尽快地发现集成错误。许多团队发现这个过程可以大大减少集成的问题,让团队能够更快地开发内聚的软件。

 

Jenkins


Jenkins 官方网站:https://jenkins.io/

提到 Jenkins 就不得不提另一个持续集成工具——Hudson , Hudson 由 Sun 公司开发,2010 年 Sun 公司被 Oracle 公司收购, oracle 公司声称对 hudson 拥有商标所有权。 Jenkins是从 Hudson 中分离出来的一个版本,并将继续走 Open Source 的道路。二者现在由不同的团队在维护。

Jenkins 主要用于监视执行重复工作,如建立一个软件项目或工作运行的计划任务。当前 Jenkins 关注以下两个工作。

不断地进行项目的构建/测试软件: 就像 CruiseControl 或 DamageControl。概括地说,Jenkins 提供了一个易于使用的所谓的持续集成系统,使开发人员更容易修改整合到项目中,并使它更容易为用户获得一个新的版本。自动连续生成提高了生产效率。

监控外部运行的作业: 如计划任务作业和 Qrocmail 的工作,即使是那些在远程机器上运行的计划任务。 Jenkins 生成这些日志并且很容易让你注意到错误的出现。

(二)Jenkins 环境搭建

Jenkins 是基于Java开发的一种持续集成工具,所以,Jenkins需要Java环境。关于Java环境的配置我们在第9章使用Selenium Grid 时已经作了介绍,这里不在讲解。

安装 Tomcat


Tomcat是针对Java的一个开源中间件服务器(容器),基于Java Web的项目需要借助Tomcat 才能运行起来。

Tomcat官方网站:http://tomcat.apache.org/ ,打开后首页如图2.1所示

 图2.1 下载Tomcat

单击页面左侧Tomcat 版本进行下载,对下载的压缩包进行解压,目录结构如图2.2所示。  图2.2 webapps目录用于web项目 通常将需要运行的应用放到webapps/目录下,进入bin/目录下,双击startup.bat,启动Tomcat服务器。

安装 Jenkins


Jenkins官方网站:https://jenkins.io/ ,打开后首页如图2.3所示。

 图2.3 下载Jenkins

点击“Download” 链接进入下载页面,根据自己的系统选择对应的 Jenkins 版本进行下载。

下载完成,双击进行安装,如图2.4所示。

 图2.4 双击Jenkins安装

单击“next”按钮,我们直接将其安装到Tomcat的 webapps 目录下,如图2.5所示。一定要选择TomCat 的 webapps 目录。

 图2.5 选择Tomcat的webapps目录

配置 Jenkins


Jenkins 安装完成会自动启动 TomCat , 并通过默认浏览器打开:http://localhost:8080/。

(你也可以手动进Tomcat的bin/目录下启动startup.bat ,通过浏览器访问:http://localhost:8080/) 如图2.6所示。

 图2.6 开如Jenkins

根据提示,打开: D:\\Java\\apache-tomcat-9.0.0.M26\\webapps\\Jenkins\\secrets\\initialAdminPassword 文件查看密码。将密码填写到输入框中,点击 “Continue” 按钮。

接下来根据提示进行安装。

上图,运行需要一些时间,Jenkins 正在帮我们安装各种主流插件。

最后一步配置,创建 管理员账号。

整个 Jenkins 安装配置完成。操作界面如下。

Jenkins 的安装比以前复杂了些,但功能也变得更为强大了。

(三)Jenkins 创建构建任务

构建项目类型


点击 Jenkins 首页 “创建一个新任务” 的链接,弹出如图3.1所示页面。

图3.1 选择Jenkins任务类型

Jenkins 提供了六种类型的任务。

  • 构建一个自由风格的软件项目

这是Jenkins的主要功能。Jenkins 会结合任何 SCM 和任何构建系统来构建你的项目, 甚至可以构建软件以外的系统。

  • Pipeline

Orchestrates long-running activities that can span multiple build slaves. Suitable for building pipelines (formerly known as workflows) and/or organizing complex activities that do not easily fit in free-style job type. -- 很难用一两句话说清 Pipeline, 参考 , 后面另起一文来介绍。

  • 构建一个多配置项目

适用于多配置项目,例如多环境测试、平台指定构建,等等。

  • GitHub Organization

Scans a GitHub organization (or user account) for all repositories matching some defined markers. --这个主要针对由 Github 托管的项目。

  • Multibranch Pipeline

Creates a set of Pipeline projects according to detected branches in one SCM repository. 根据一个SCM存储库中检测到的分支创建一组 Pipeline 项目。

  • 文件夹

创建一个可以嵌套存储的容器。利用它可以进行分组。 视图仅仅是一个过滤器,而文件夹则是一个独立的命名空间, 因此你可以有多个相同名称的的内容,只要它们在不同的文件 夹里即可。

这里选择第一个:构建一个自由风格的软件项目, 输入项目名称:python test project ,点击 “OK”按钮。

构建 Windows 测试任务


假设,我们有一个 Python 编写的测试脚本 py_tests.py ,位于电脑 D盘 根目录,内容如下:

import unittest, time
from selenium import webdriver


class TestClass(unittest.TestCase):

    def setUp(self):
        self.driver = webdriver.Chrome()
        self.base_url = "http://www.testclass.net"

    def tearDown(self):
        time.sleep(2)
        self.driver.quit()

    def test_case(self):
        self.driver.get(self.base_url)
        search_input = self.driver.find_element_by_name("q")
        search_input.send_keys("selenium")
        search_input.submit()

    def test_case2(self):
        self.driver.get(self.base_url)
        search_input = self.driver.find_element_by_name("q")
        search_input.send_keys("jenkins")
        search_input.submit()


if __name__ == '__main__':
    unittest.main()

如果是在 Windows 下应该如何执行这个测试用例呢? 打开 Windows 命令提示符(CMD)。

Microsoft Windows [版本 10.0.15063]
(c) 2017 Microsoft Corporation。保留所有权利。

C:\\Users\\name> python d:/py_tests.py
..
----------------------------------------------------------------------
Ran 2 tests in 22.371s

OK

D:\\>

不明白什么意思? 那么你记清我上面运行 python 程序时所敲的一行 dos 命令。

下接来回到 Jenkins 的配置过程中,

添加项目的描述:selenium 自动化测试项目。

剩下的选项都不要管,拖到页面底部,构建 选项。

选择 “Execute Windows batch command” 选项,执行Windows批处理命令。

如上图,输入你在 windows 命令提示符下所输的命令(python d:/py_tests.py)。 点击 “保存”

一个极简的,基于 Windows 系统的,Python 脚本测试的 持续集成项目就创建完成了。

(四)Jenkins 配置构建执行状态

运行构建


在项目 左侧列表点击 “立即构建” ,在 “Build History” 列表,你会得到一个红色的小圆点,表示构建失败。

点击 构建失败的任务(红色的小圆点)。然后点击“Console Output” 就可以查看失败的 log 了。

提示:'python' 不是内部或外部命令,也不是可运行的程序或批处理文件。

我们明明在 Windows 提示符下运行是没有问题的。这是因为 Jenkins 缺少环境配置。

配置构建执行状态


回到 Jenkins 首页,点击 “构建执行状态” ,右则会列出本机信息,点击本机信息,配置 Python 的 path 环境变量。同时还需要添加浏览器驱动文件所在目录,参考 。

如果你明白这块的话,说明你不懂 Python 语言,或不熟悉 Python 运行环境的配置。(不同技术的之间的配合使用存在一定的依赖关系!我们无法做到零基础。)

配置完成,点击 “保存” , 再来运行 “立即构建” ,这次看到 py_tests.py 自动化脚本被执行了。

查看控制台输出:

好了!一个简单的 selenium + python 自动化测试的构建任务就创建完成了。

但对于 Jenkins 的学习,我们才刚刚开始。

总结


最后总结一下学习最重要的知识圈
如果你对此文有任何疑问,如果你对软件测试、接口测试、自动化测试、面试经验交流感兴趣点击加入Python自动化测试技术群(备注“csdn111”)群里的免费资料都是笔者十多年测试生涯的精华。还有同行大神一起交流技术哦。

 

以上是关于Jenkins持续集成(上篇)—新手的主要内容,如果未能解决你的问题,请参考以下文章

jenkins持续集成工作原理

Gitlab+jenkins持续集成+自动化部署

如何使用Jenkins进行持续集成测试

Jenkins持续集成使用指南

CI/CD持续集成与持续交付(下)-------- jenkins的节点管理,用户管理,结合ansible和k8s

CI/CD持续集成与持续交付(下)-------- jenkins的节点管理,用户管理,结合ansible和k8s