1. 源码下载
github: https://github.com/HttpRunner/HttpRunnerManager
下载后放入项目目录,结构如下:
2.依赖环境 根据根目录requirements.txt文件安装依赖,可以使用pip安装,pip install -r requirements.txt
Django == 2.0.3
PyYAML == 3.12
requests == 2.18.4
eventlet == 0.22.1
mysqlclient == 1.3.12
django-celery == 3.2.2
flower == 0.9.2
dwebsocket == 0.4.2
paramiko == 2.4.1
HttpRunner == 1.5.8
3.数据库安装,我安装的是MYSQL 57版本,设置为utf-8编码,创建相应HttpRunner数据库,设置好相应用户名、密码,启动mysql
4.修改源码中settings.py的配置文件
5. rabbitmq消息中间件的安装
可以参考博友的安装文章:https://www.cnblogs.com/tiechui2015/p/10016106.html
启动和关闭命令需要记住:打开sbin目录,双击rabbitmq-server.bat
访问http://localhost:15672
username:guest、Password:guest, 成功登陆即可
如下图:
6.修改配置路径目录如下:修改:HttpRunnerManager/HttpRunnerManager/settings.py里BROKER_URL
7.到这里我们基本都安装完成了。然后我们生成数据库迁移脚本,这里如果之前未使用连接过数据库,可能需要安装pymysql库,同样采用pip安装。
python manage.py makemigrations
然后执行python manage.py migrate 对应HttpRunner数据库生成相应表结构
8.执行python manage.py createsuperuser 根据提示创建输入用户名,邮箱,密码,用于admin后台管理,暂时不用可以先不创建。
9.执行python manage.py runserver启动服务,后面可以接ip和端口号,如0.0.0.0:8000
注意点:以上这些python操作请切换到项目目录下执行。
然后打开web:http://127.0.0.1:8000/api/register/ 注册账号后登录平台
这里我已经添加了project module testcase,截图如上,很漂亮有没有。
10. 然后就是定时任务(也就是异步执行的task),我们需要使用celery,执行脚本:python manage.py celery -A HttpRunnerManager worker --loglevel=info 启动worker
这里遇到了坑。总是会出现报错。我是各种检查,最后终于发现是tornado这个下面的web模块中缺少asynchronous装饰方法,这个是用来执行异步的关键。我各种百度都未查到此类问题,后面想到是不是这个模块升级后改版了,然后我用pip给这个模块降级,安装4.x的版本,重试后问题解决。先前默认安装了最新的版本6.0.1。
解决后启动截图:
[2019-03-20 18:55:02,383: WARNING/Worker-1] ?[32m?[47mINFO ?[0m ?[32mGenerated Html report: D:\Python36\Scripts\HttpRunnerManager-master\reports\1553079300.h
tml?[0m
[2019-03-20 18:55:02,385: WARNING/Worker-1] ?[32m?[47mINFO ?[0m ?[32mGenerated Html report: D:\Python36\Scripts\HttpRunnerManager-master\reports\1553079300.h
tml?[0m
[2019-03-20 18:55:02,399: WARNING/Worker-1] ?[32m?[47mINFO ?[0m ?[32mGenerated Html report: D:\Python36\Scripts\HttpRunnerManager-master\reports\1553079300.h
tml?[0m
[2019-03-20 18:55:02,399: WARNING/Worker-1] ?[32m?[47mINFO ?[0m ?[32mGenerated Html report: D:\Python36\Scripts\HttpRunnerManager-master\reports\1553079300.h
tml?[0m
[2019-03-20 18:55:04,603: INFO/MainProcess] Task ApiManager.tasks.module_hrun[5a3b0c27-a930-4777-98dd-c4f7683c8ac6] succeeded in 4.5939999999973224s: None
直到我启动work,RabbitMQ中间件才有数据,因为定时任务给到中间件后,中间件找不到work服务,阻塞在那里。
11. python manage.py celery beat --loglevel=info 开启定时任务配置
D:\Python36\Scripts\HttpRunnerManager-master>python36 manage.py celery beat --loglevel=info
celery beat v3.1.26.post2 (Cipater) is starting.
__ - ... __ - _
Configuration ->
. broker -> amqp://guest:**@localhost:5672//
. loader -> celery.loaders.app.AppLoader
. scheduler -> djcelery.schedulers.DatabaseScheduler . logfile -> [stderr]@%INFO
. maxinterval -> now (0s)
[2019-03-20 18:23:20,603: INFO/MainProcess] Writing entries (0)...
[2019-03-20 18:23:25,951: INFO/MainProcess] Writing entries (0)...
[2019-03-20 18:26:29,964: INFO/MainProcess] Writing entries (1)... 12. 执行:celery flower 访问:http://localhost:5555/dashboard 即可查看任务列表和状态 这一步可能还有点问题,暂时不能打开。后续再研究更新。 附上定时任务的报告截图:
直至现在,平台基本已经完全通畅,可以开始自动化接口测试。后续将平台搭建到server上去,教程再更新。