持续集成 (Continuous integration,简称 CI)
持续集成是一种开发实践,它倡导团队成员需要频繁的集成他们的工作,每次集成都通过自动化构建(包括编译、构建、自动化测试)来验证,从而尽快地发现集成中的错误。让正在开发的软件始终处于可工作状态,让产品可以快速迭代,同时还能保持高质量。
Jenkins 是基于 Java 开发的持续集成工具,开源免费,官网:https://jenkins.io/
App 自动化测试执行策略
自动化测试主要用于回归测试,我们可以制定执行策略:比如每天固定、开发代码更新后定时执行,这就需要与 Jenkins 进行集成。
Jenkins 集成 App 自动化测试问题点:
App 自动化需要用到真机或模拟器,而 Jenkins 一般是部署在服务器上面的,将真机或模拟器接入到服务器上显然是不可能。
解决方案:
-
申请一台专门用于做自动化测试的本地电脑,部署自动化测试环境,连接本地的真机/模拟器
-
在公司服务器(内部服务器 or 阿里云/腾讯云服务器)上部署 Jenkins
-
利用 Jenkins master-slave 模式将任务下发给对应的本地电脑,在本地电脑上执行任务
具体步骤
需要注意的是:本地执行电脑需要配置好 JDK+Maven+Android SDK+Git 的环境,并且需要通过 adb 链接上设备。
Jenkins 主从模式(master-slave)使用:
添加 Node 节点
Manage Jenkins -> Manage Nodes and Clouds -> New Node
需要注意 Launch method 一定要开启 jenkins 的远程连接端口,否则 slave 从机无法连接上 Jenkins 服务。这种连接用的是 JNLP4 协议, 这种协议是在 WebSocket + TLS 的基础上封装而成的长连接协议。可以在 jenkins 的安全设置面板中开启:进入 Jenkins 首页-> 安全面板
连接 slave 从机
两种方式都可以连接 slave 从机
任务配置中选择对应 slave 从机构建
可能碰到的问题 1:
D:\jenkins-slave\workspace\jenkins_maven_demo>mvn clean test The JAVA_HOME environment variable is not defined correctly This environment variable is needed to run this program NB: JAVA_HOME should point to a JDK not a JRE
ERROR: Error cloning remote repo ‘origin’ hudson.plugins.git.GitException: Could not init D:\jenkins-slave\workspace\jenkins_maven_demo
解决方案:在 slave 节点配置工具路径:
可能碰到的问题 2:
mvn not found
Jenkins slave 节点的环境变量中没有 maven 的导致的,解决方案:将 slave 机器上面的 PATH 环境变量复制到此处:
今日的知识你学会了么?
作为一名软件测试工程师,该怎样努力才能快速成为一名优秀的测试开发大佬,或者性能测试大佬,或者说作为一名软件测试工程师需要掌握哪些知识体系。这不仅是一个刚刚踏入职场的软件测试工程师,也是工作三五年之后开始迷茫的工程师,都必须要面对和想明白的问题。
一、软件测试基础理论知识:
-
软件测试理论知识是开展测试工作的理论依据和支撑,是测试很重要的阶段必须掌握的技能。
-
软件的质量模型:软件测试过程保障软件的质量,从哪些方面保障可以从质量模型出发思考
-
测试分类:软件测试过程可以按照不同角度进行分类,基础测试到高级测试递进过程
-
开发流程:告诉测试人员一个软件完整的生命周期,软件从无到有到消亡的过程
-
测试流程:掌握并指导测试人员在实际项目中如何开展测试工作。这要求测试人员对常见的主流测试流程有较为透彻的理解。遇到不同的软件项目,知道从何处着实能最有效率的测试软件缺陷
-
测试计划与方案:如何规划在项目中开展测试活动,确保测试活动有序进行
-
设计用例方法:黑盒测试阶段必须掌握的一些测试用例的设计方法。比如黑盒测试用例的设计方法、测试用例元素等等
-
软件缺陷:在测试执行过程中应该确定缺陷并提交缺陷报告
-
缺陷管理:提交缺陷后在实际工作中如何和开发协助处理验证提交的问题。例如:bug的等级优先级分类、bug的描述、bug的生命周期、缺陷管理工具使用,如禅道等。
-
测试报告:测试过程的回顾和结果确认,生成系统性的专业软件测试评估报告。
二、软件测试功底技术——Linux系统
linux系统是主要的服务端操作系统,也是从事IT岗位的大部分人员必须具备的基本技术之一。
-
linux系统基本知识:多用户,多任务,发行版本等
-
常见 linux操作命令:日志查看,文件压缩、解压,用户管理,文件权限等
-
会部署和配置基本的应用jdk、 mysql、 tomcat
-
docker安装使用
-
编写基本的 shell RAD本
-
远程终端工具使用: shell, xftps等
三、软件测试功底技术——Sql数据库
数据库作为软件系统必备的应用系统,在诸如接口测试、性能测试等等过程中往往需要操作数据库,验证数据正确性完整性,都离不开数据库的增删改查操作,在项目部署阶段数据库还需要配合项目部署。在性能测试、接口自动化测试中都需要数据库的支撑。
-
数据库基本概念
-
关系型数据库
-
MYSQL基本的增改查语句,存储过程
-
MYSQL复杂查询、多表查询
-
MYSQL索引及事务相关概念
-
数据库客户端工具使用:如 Navicat
四、软件测试功底技术——编程语言
编程语言推荐大家以Python为首,Java语言为辅学习,查看各大招聘网站,基本上也是以这两种语言为主的。没有编程基础的朋友可以先学习Python语言
Python语言的学习内容包含以下知识点:
-
Python基础:Python语言特点、运行环境、基本语法、代码风格、示例程序
-
数据结构:基本数据结构:数字、字符串、类型判断、类型转换、切片、字符串格式化、数值运算、位置参数和关键字参数;组合数据结构:列表、元组、范围、字典、集合、不可hash对象、解包、内存地数据结构址、不可变数据
-
程序控制:顺序结构、循环结构、判断结构、异常处理、逻辑运算符
-
函数:定义函数、函数的参数、返回值、变量作用域、匿名函数、常用内置函数
-
模块和库:模块和包、import关键字、常用标准库、常用第三方库、包管理工具pip
-
面向对象:面向对象起源和优势、面向对象的特性类和对象的联系、对象的特殊方法
-
日志记录:baseConfig、文件日志、邮件日志、定制格式、内置占位符、等级过滤、分级传播、配置文件
-
测试框架:unitest、pytest等
-
并发编程:多进程、多线程、协程、线程池、同步控制、线程通信、分布式、猴子补丁、 async语法、生成器
-
网络编程:socket编程基础、TCP服务端和客户端、并行请求处理、HTTP服务端和客户端
五、软件测试自动化进阶——接口测试
接口测试本质也是功能测试的一种,通过脚本或者工具,模拟客户端对服务端接口进行调用。因为是从接口层测试,所以能更早的发现问题,从而提高测试效率,降低修复成本。
-
http/httpst协议学习
-
常见请求方法学习:GET、POST
-
cookie和 session学习
-
接口的基本概念
-
接口文档认识
-
接口测试用例编写
-
接口测试工具使用:postman、Jmeter、SoapUl
六、软件测试自动化进阶——性能测试
性能测试的技术要求很高,不仅仅要对性能测试的指标、测试分类、测试设计有很深刻的理解。还要学习系统业务和架构相关知识,这样才能更好的设计性能场景。
-
性能基本概念:性能测试意义、常见性能指标理解、性能测试的分类
-
性能测试流程:性能需求分析、性能场景设计、测试脚本编写、测试执行资源监控、性能调优、回归测试
-
Jmeter及 roadrunner使用
-
性能测试报告输出
七、软件测试自动化进阶——web自动化
了解自动化的目的,熟练掌握TestNG&unittest自动化框架,以及断言与日志处理;做测试的同学们都了解,做Web自动化,我们主要用Selenium或者是QTP,这里我们需要掌握Selenium的web自动化环境搭建,正确的浏览器配置。
八、软件测试自动化进阶——app自动化
越来越多的项目和系统通过移动端来提供服务,移动端的软件质量越来越重要,App自动化测试已经成为自动化测试的重要内容。借助Appium,使得App自动化测试和Web自动化测试有很多相通之处,不过作为测试工程师,依然需要掌握移动端应用的工具和特性。
-
Appium移动测试环境搭建:Appium ServerAppium和 Desktop、 Android运行环境搭建、模拟器安装和连接、真机设备调试模式、adb、 weditor、 – – UiAutomator22、 Monkey
-
Appium元素定位:原生应用元素定位、纯web应用元素定位、混合应用元素定位
-
Appium元素交互:等待元素加载,元素的基本属性和方法、滑动、拖动、缩放操作、下拉选择操作、 toast消息处理、常见控件分析、常见布局分析
-
封装测试框架:集成Appium、adb等工具、预定义异常处理、记录Appium日志、屏幕截图、打造多用途测试框架
九、软件测试自动化进阶——持续集成和持续测试
持续集成和持续测试是一个在迭代中构建、测试产品并修复Bug的过程。它有助于团队在开发阶段的初期发现缺陷,这时的缺陷通常相对不那么复杂,并且更容易被解决。通过持续集成和持续测试,可以尽早地将错误风险降至最低,并加快交付更好质量的软件。
-
版本控制Git:背景介绍、环境部署、工作区、暂存区和提交区、分支创建与合并、解决冲突、标签、 config与别名、本地仓与远程仓、 GitHub与码云
-
持续集成 Jenkins:背景介绍、环境部署、文件结构、远程仓库与私服、ja包依赖、插件管理
-
容器Docker:了解 Dockers的镜像、仓库、容器、 Docker Engine和架构图、网络设置、数据持久化