基于Avocado 的 QData MySQL自动化测试.md
qdata-mysql 自动化测试概要设计
```
│ ├── 1. 依赖环境
│ │ ├
│ │ └─────
│ ├── 2. 配置文件
│ │ ├
│ │ └─────
│ ├
│ ├── 3. 测试流程
│ │ ├
│ │ └─────
│ ├
│ ├── 4. 输出格式
│ │ ├
│ │ └─────
│ │
│ ├── 5. 命令行参数
│ │ ├
│ │ └─────
```
#### 依赖环境
python2.7.9
avocado-framework (52.0)
ssh
avocado需要插件:
avocado-framework-plugin-result-html (52.0)
avocado-framework-plugin-runner-remote (52.0)
avocado-framework-plugin-varianter-yaml-to-mux (52.0)
```
前提条件
- qdata_mysql 版本 1.2.2
- 集群正常
- sysbench 压测工具
- ntp 服务正常(ntp.conf 配置正常 pool.ntp.org)
- ssh 长连接
- master 配置数据库sbtest的权限
- 配置文件 qdata.conf, qdata_for_mysql.conf, qdata_conf_default, 需要备份一份,在恢复集群时,恢复配置文件,再gen_conf
grant all on sbtest.* to sbtest identified by 'sbtest';
flush privileges;
配置文件
用户配置
- yaml参数配置文件,配置集群master_ip
#cat data/cluster1.yaml
master_ip: '10.10.30.101'
测试流程
集群测试
- 支持多套集群测试
- 在data目录下新建参数配置文件,配置每套集群的master_ip,配置方法如下:
配置文件名称依照cluster1,cluster2,cluster3.....等以此类推
参数配置集群的master_ip即可,例如master_ip: '10.10.30.101'
指定第一套配置文件执行集群测试后,可新开窗口,再次指定其他配置文件进行测试
- 通过指定配置文件来进行集群测试:
avocado run --mux-yaml data/cluster1.yaml -- cls.py ha.py lb.py db.py - 若测试中断,可以从中断的案例开始执行(指定中断任务的job id)
avocado run --replay 56b4aab --replay-test-status INTERRUPTED - 支持只执行测试失败的案例,会跳过执行成功的案例(指定刚执行过的任务job id)
avocado run --replay 56b4aab --replay-test-status FAIL - 测试cancel的案例
avocado run --replay 56b4aab --replay-test-status CANCEL
屏幕输出
#avocado run --mux-yaml data/cluster2.yaml -- ha.py db.py lb.py
JOB ID : eec9fe46c4aee730ee0e4433967244d7781e5c8e
JOB LOG : /root/avocado/job-results/job-2017-07-27T15.19-eec9fe4/job.log
(1/9) ha.py:HATest.test_qmcls_start;run-7599: PASS (0.00 s)
(2/9) ha.py:HATest.test_qmcls_stop;run-7599: FAIL (0.04 s)
(3/9) ha.py:HATest.test_qmcls_show;run-7599: PASS (0.00 s)
(4/9) db.py:DBTest.test_db_stop;run-7599: PASS (0.00 s)
(5/9) db.py:DBTest.test_db_start;run-7599: FAIL (0.04 s)
(6/9) db.py:DBTest.test_db_backup;run-7599: PASS (0.00 s)
(7/9) lb.py:LBTest.test_lb_join;run-7599: PASS (0.00 s)
(8/9) lb.py:LBTest.test_lb_kickout;run-7599: PASS (15.02 s)
(9/9) lb.py:LBTest.test_set_kickout_time;run-7599: PASS (0.00 s)
RESULTS : PASS 7 | ERROR 0 | FAIL 2 | SKIP 0 | WARN 0 | INTERRUPT 0 | CANCEL 0
JOB TIME : 16.65 s
JOB HTML : /root/avocado/job-results/job-2017-07-27T15.19-eec9fe4/results.html




- 定位FAIL案例的具体失败信息
- 打开/root/avocado/job-results/job-2017-07-27T15.19-eec9fe4/results.json,根据id,2和5是FAIL,找到对应信息如下:
{
"end": 1501139986.080578,
"fail_reason": "qmcls stop failed in 10.10.30.102",
"id": "2-ha.py:HATest.test_qmcls_stop;run-7599",
"logdir": "/root/avocado/job-results/job-2017-07-27T15.19-eec9fe4/test-results/2-ha.py:HATest.test_qmcls_stop;run-7599",
"logfile": "/root/avocado/job-results/job-2017-07-27T15.19-eec9fe4/test-results/2-ha.py:HATest.test_qmcls_stop;run-7599/debug.log",
"start": 1501139986.039281,
"status": "FAIL",
"test": "2-ha.py:HATest.test_qmcls_stop;run-7599",
"time": 0.041297197341918945,
"url": "2-ha.py:HATest.test_qmcls_stop;run-7599",
"whiteboard": ""
},
{
"end": 1501139986.487331,
"fail_reason": "qmcls db start all failed 10.10.30.102",
"id": "5-db.py:DBTest.test_db_start;run-7599",
"logdir": "/root/avocado/job-results/job-2017-07-27T15.19-eec9fe4/test-results/5-db.py:DBTest.test_db_start;run-7599",
"logfile": "/root/avocado/job-results/job-2017-07-27T15.19-eec9fe4/test-results/5-db.py:DBTest.test_db_start;run-7599/debug.log",
"start": 1501139986.447326,
"status": "FAIL",
"test": "5-db.py:DBTest.test_db_start;run-7599",
"time": 0.04000496864318848,
"url": "5-db.py:DBTest.test_db_start;run-7599",
"whiteboard": ""
},
输出格式
- 屏幕打印格式
#avocado run --mux-yaml data/cluster2.yaml -- ha.py db.py lb.py
JOB ID : eec9fe46c4aee730ee0e4433967244d7781e5c8e
JOB LOG : /root/avocado/job-results/job-2017-07-27T15.19-eec9fe4/job.log
(1/9) ha.py:HATest.test_qmcls_start;run-7599: PASS (0.00 s)
(2/9) ha.py:HATest.test_qmcls_stop;run-7599: FAIL (0.04 s)
(3/9) ha.py:HATest.test_qmcls_show;run-7599: PASS (0.00 s)
(4/9) db.py:DBTest.test_db_stop;run-7599: PASS (0.00 s)
(5/9) db.py:DBTest.test_db_start;run-7599: FAIL (0.04 s)
(6/9) db.py:DBTest.test_db_backup;run-7599: PASS (0.00 s)
(7/9) lb.py:LBTest.test_lb_join;run-7599: PASS (0.00 s)
(8/9) lb.py:LBTest.test_lb_kickout;run-7599: PASS (15.02 s)
(9/9) lb.py:LBTest.test_set_kickout_time;run-7599: PASS (0.00 s)
RESULTS : PASS 7 | ERROR 0 | FAIL 2 | SKIP 0 | WARN 0 | INTERRUPT 0 | CANCEL 0
JOB TIME : 16.65 s
JOB HTML : /root/avocado/job-results/job-2017-07-27T15.19-eec9fe4/results.html
结果导出文件格式:
- 查看详细测试结果:
/root/avocado/job-results/job-2017-07-25T09.14-56b4aab/results.json

- 查看日志信息:
/root/avocado/job-results/job-2017-07-25T09.14-56b4aab/job.log

- HTML格式结果:
/root/avocado/job-results/job-2017-07-26T14.49-020f341/results.html

- 查看详细测试结果:
命令行参数
avocado run/list / variants / config
- run 执行测试
- list 列出函数包含的测试案例
- variants 查看参数配置信息
- config 查看配置路径信息
avocado run --mux-yaml
- --mux-yaml 指定参数配置文件
执行命令可指定测试案例函数,即可执行测试案例,例如:
avocado run --mux-yaml data/cluster1.yaml -- ha.py lb.py db.py或
avocado run ha.py lb.py db.py --mux-yaml data/cluster1.yaml查看配置文件参数详细信息
avocado variants -m --mux-yaml data/cluster1.yaml --summary 2 --variants 2查看日志和结果文件位置
avocado config --datadir#avocado config --datadir
Config files read (in order):
/usr/local/pyenv/product/etc/avocado/avocado.conf
/usr/local/pyenv/product/etc/avocado/conf.d/gdb.conf
/root/.config/avocado/avocado.conf Avocado replaces config dirs that can't be accessed
with sensible defaults. Please edit your local config
file to customize values Avocado Data Directories:
base /var/lib/avocado
tests /usr/share/avocado/tests
data /var/lib/avocado/data
logs /root/avocado/job-results
avocado list nvmtest.py 列出具体的测试用例函数有哪些
avocado list -V/--verbose nvmtest.py查看详细信息
oravocado list nvmtest.py -V/--verbose#avocado list ha.py --verbose
Type Test Tag(s)
INSTRUMENTED ha.py:HATest.test_qmcls_start
INSTRUMENTED ha.py:HATest.test_qmcls_stop
INSTRUMENTED ha.py:HATest.test_qmcls_show TEST TYPES SUMMARY
==================
ACCESS_DENIED: 0
BROKEN_SYMLINK: 0
EXTERNAL: 0
INSTRUMENTED: 3
MISSING: 0
NOT_A_TEST: 0
SIMPLE: 0
基于Avocado 的 QData MySQL自动化测试.md的更多相关文章
- 《零成本实现Web自动化测试--基于Selenium》第一章 自动化测试基础
第一篇 Selenium 和WebDriver工具篇 第一章 自动化测试基础 1.1 初识自动化测试 自动化测试有两种常见方式 1.1.1 代码驱动测试,又叫测试驱动开发(TDD) 1.1.2 ...
- 基于 SWTBot 进行 Eclipse GUI 自动化测试
背景简介 在软件开发领域,持续集成和部署对于软件测试自动化提出了越来越高的要求,基于 Eclipse 应用在这一需求中仍然占据重要的组成部分.目前主流的测试自动化工具主要以录制回放的功能为主,辅助以脚 ...
- nightwatchjs 基于nodejs&& webdriver 协议的自动化测试&&持续集成框架
nightwatchjs 是基于nodejs&& webdriver 协议的自动化测试&&持续集成框架 参考架构 参考资料 http://nightwatchjs.or ...
- 技术实战:基于 MHA 方式实现 MySQL 的高可用(转)
转自:http://os.51cto.com/art/201307/401702_all.htm MHA故障转移可以很好的帮我们解决从库数据的一致性问题,同时最大化挽回故障发生后的数据.本文分享了基于 ...
- 基于Appium、Python的自动化测试
基于Appium.Python的自动化测试环境部署和实践 第一章 导言 1.1 编制目的 该文档为选用Appium作为移动设备原生(Native).混合(Hybrid).移动Web(Mobile ...
- 基于Selenium+Python的web自动化测试框架
一.什么是Selenium? Selenium是一个基于浏览器的自动化测试工具,它提供了一种跨平台.跨浏览器的端到端的web自动化解决方案.Selenium主要包括三部分:Selenium IDE.S ...
- 基于GTID搭建主从MySQL
目录 基于gtid搭建主从MySQL 一.GTID的使用 二.GTID的简介 三.GTID的构成 四.查看GTID的执行情况 4.1 gtid_executed 4.2 gtid_own 4.3 gt ...
- 基于Python的HTTP接口自动化测试框架实现
今天我们来讲一下基于Python的HTTP接口自动化测试框架的实现,范例如下: 一.测试需求描述 对服务后台一系列的http接口功能测试. 输入:根据接口描述构造不同的参数输入值 输出:XML文件 e ...
- 如何基于Azure平台实现MySQL HA(方法论篇)
我们都知道,相较于传统的数据中心,Pulic cloud也有劣势,比如说数据库的HA,很多熟悉公有云平台的读者都知道,因为出于安全性性考虑以及一些技术条件的限制,很多本地数据中心的mysql HA方法 ...
随机推荐
- python调用百度语音(语音识别-斗地主语音记牌器)
一.概述 本篇简要介绍百度语音语音识别的基本使用(其实是斗地主时想弄个记牌器又没money,抓包什么的又不会,只好搞语音识别的了) 二.创建应用 打开百度语音官网,产品与使用->语音识别-> ...
- J2ee的13个规范
以下来自于网络. 1.JDBC(java Database Connectivity): JDBC API为访问不同的数据库提供了一种统一的途径,就像ODBC一样,JDBC对开发者屏蔽了一些细节问题, ...
- 重温基础之-css盒模型
所有html元素都可以看作盒子. css盒模型本质上是一个盒子,封装周围的html元素,它包括:外边距,边框,内边距和实际内容. 默认情况下,一个元素的总宽度计算方式: 总宽度=左外边距+左边框+左内 ...
- Eclipse 安装 SVN 插件的两种方法
eclipse里安装SVN插件,一般来说,有两种方式: 直接下载SVN插件,将其解压到eclipse的对应目录里 使用eclipse 里Help菜单的“Install New Software”,通过 ...
- java的mac自动化-自动运行java程序
本文旨在帮助读者介绍,如果一个测试工程师拿到了mac本,该如何在本地自动运行java代码 首先如图所示写下如下一段代码 package zlr;import org.junit.Test;public ...
- elasticsearch分词器Jcseg安装手册
Jcseg是什么? Jcseg是基于mmseg算法的一个轻量级中文分词器,同时集成了关键字提取,关键短语提取,关键句子提取和文章自动摘要等功能,并且提供了一个基于Jetty的web服务器,方便各大语言 ...
- ul 和 ol 标签的相关设置
初学者不喜欢 ul 标签的最重要一点莫过于其前面的黑点了,每次写个无序列表其前面总有一个黑点是个很讨厌的事,去掉黑点的话自然是要用到 list-style:none:这条css 属性设置了. p.p1 ...
- Redis多服务器负载均衡的实现
集群是一组相互独立的.通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理.一个客户与集群相互作用时,集群像是一个独立的服务器.集群配置是用于提高可用性和可缩放性. 上图是三个主服务 ...
- 一个可以自由定制外观、支持拖拽消除的MaterialDesign风格Android BadgeView
为了尊重作者,先放上链接:https://github.com/qstumn/BadgeView BadgeView 一个可以自由定制外观.支持拖拽消除的MaterialDesign风格Android ...
- mysql学习笔记02 CRUD操作
添加数据insert into 表名(字段列表) values(对应字段的列表值) 查询数据 select *from 表名 where 条件select *from 表名 where 1条件 1表示 ...