Docker+selenium实现自动化健康报备的方法

本文以某高校的健康报备系统为例,完成该web端的自动化操作,用到的技术栈如下所述:
Docker \ Selenium \ Python \ yagmail \ ssh等

基本思路:
1、本地编写代码并进行测试
2、新建docker容器并配置环境
3、代码上传到服务器并复制到docker容器内
4、解压、调试代码,确认代码没有问题后删除代码
6、退出容器,并将容器制作成镜像
7、用镜像实例化容器并挂载代码

一、本地编写代码并调试

先看一下我们需要进行操作的目标web:
登录页面:

表单页面:

操作非常简单,只需要登录后点击勾选你要的选项后点击提交即可

源码附上:

主文件:

yagmail发送邮件:

注意:这里用的是邮箱的【授权码】,而不是密码 QQ邮箱可以在设置=>账号 进行操作:

selenium自动化:

这里用到的是Xpath定位,浏览器可以直接抓取,非常方便:

记得后面一定要加quit和stop,否则会造成进程堆积 无法关闭而崩溃
在本地运行没有问题后就可以进行下一步操作了

二、配置Docker容器环境

环境配置由以下步骤进行
1、拉取python镜像
2、用python镜像新建一个容器
3、安装运行所需的第三方库
4、安装chrome浏览器以及chromedriver
5、上传测试文件进行调试

拉取python镜像
进行这步操作需要先确保你的docker已经正确安装,通过以下命令进行镜像拉取:

docker image pull python

通过以下命令查看是否已经拉取到本地:

docker image ls

用python镜像新建一个容器

使用以下命令即可新建容器并进入容器内:

docker run -it python /bin/bash

安装运行所需的第三方库
通过简单的pip命令就可以实现库的安装,如:

pip install selenium
pip install yagmail
pip install pytz

安装好后调试确认即可,这里不展开详说

安装chrome浏览器以及chromedriver
ubuntu系统用以下命令即可,其他系统请自行百度:

# 下载
wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb
# 安装
dpkg -i google-chrome-stable_current_amd64.deb

安装chromedriver前需要先查看chrome的版本号,根据版本号下载对应的driver:

# 查看chrome版本
google-chrome --version

关于chromedriver,我是在本地下载解压好了用ssh传到服务器:
下载地址:http://chromedriver.storage.googleapis.com/index.html
下载解压完毕后用ssh命令上传:

scp 你的driver地址/chromedriver root@服务器IP:服务器目录

然后从宿主机复制到容器内:

docker cp chromwdriver 容器名:容器目录

代码也是以此方式上传,后面的相关操作不再重复
输入python命令进行简单调试:

上传测试文件进去确认:

如果能够正确输出和发送邮件,就可以进行下一步操作

将容器制作成镜像

删除测试文件后输入exit退出容器,用以下命令即可创建镜像:

sudo docker commit eafd9111ada6 docker/sele_heath

commit后面的是刚刚容器的ID或容器名,不清楚的可以输入 docker ps -a 进行查看
docker/sele_heath是新建镜像的名称

完成后可以输入以下命令查看新建的镜像:

docker images docker/sele_heath

用镜像实例化容器并挂载代码

镜像建好以后就可以进行这最后一步的操作了,命令如下:

docker run -d -v /home/admin/heath2:/usr/src -w /usr/src docker/sele_heath python main.py

命令解析:
-d: 阻塞进程
-v: 地址映射
/home/admin/heath2:代码文件的目录
/usr/src: 映射到容器对应的目录
-w /usr/src: 执行容器内部文件的目录,一般和映射目录相同即可
docker/sele_heath: 镜像名
python main.py:用python去运行main.py文件

输入以下命令查看容器是否正常运行:

docker ps

至此,所有的操作已经执行完毕,我需要的做,就是起床后拿起手机查看邮件

到此这篇关于Docker+selenium实现自动化健康报备的方法的文章就介绍到这了,更多相关Docker selenium自动化内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • docker利用selenium+testng实现web自动化的方法

    前言 经历了漫长的各种资料,终于把selenium+testng参数化的问题搞定了!可能网上能找到一些,但是这些都是自己的经历.本文主要介绍了关于docker利用selenium+testng实现web自动化的相关内容,下面话不多说了,来一起看看详细的介绍吧 Windows下selenium+testng的web自动化环境搭建 做过自动化的人,肯定对selenium web环境的搭建非常熟悉了,特别是selenium在java中的使用. 先搭建好安装好JDK,配置好java开发环境(这个如果还是

  • Docker+selenium实现自动化健康报备的方法

    本文以某高校的健康报备系统为例,完成该web端的自动化操作,用到的技术栈如下所述: Docker \ Selenium \ Python \ yagmail \ ssh等 基本思路: 1.本地编写代码并进行测试 2.新建docker容器并配置环境 3.代码上传到服务器并复制到docker容器内 4.解压.调试代码,确认代码没有问题后删除代码 6.退出容器,并将容器制作成镜像 7.用镜像实例化容器并挂载代码 一.本地编写代码并调试 先看一下我们需要进行操作的目标web: 登录页面: 表单页面: 操

  • java+selenium实现自动化打开页面的方法

    闲聊一下: 毕业后的第一份工作很重要,我2015年6月985硕士毕业,7月参加工作,由于自己对职业生涯的迷茫,再加上对offer选择错误的后果(考虑太多也是错),导致自己现在并未从事自己一直愿意从事的自动化测试工作,今年想换工作了,还是特别想从事自动化测试的工作,可是目前的有一个offer也不是测试的(伤!),还有一个测试的offer在等结果,估计这两天就能有通知(好希望能够被录用!!).用我的经历,提醒大家,在毕业之前一定要想好自己想从事的方向,并且在选择offer时一定毫不犹豫的选择对自己发

  • python selenium UI自动化解决验证码的4种方法

    本文介绍了python selenium UI自动化解决验证码的4种方法,分享给大家,具体如下: 测试环境 windows7+ firefox50+ geckodriver # firefox浏览器驱动 python3 selenium3 selenium UI自动化解决验证码的4种方法:去掉验证码.设置万能码.验证码识别技术-tesseract.添加cookie登录,本次主要讲解验证码识别技术-tesseract和添加cookie登录. 1. 去掉验证码 去掉验证码,直接通过用户名和密码登陆网

  • python+selenium自动化框架搭建的方法步骤

    环境及使用软件信息 python 3 selenium 3.13.0 xlrd 1.1.0 chromedriver HTMLTestRunner 说明: selenium/xlrd只需要再python环境下使用pip install 名称即可进行对应的安装. 安装完成后可使用pip list查看自己的安装列表信息. chromedriver:版本需和自己的chrome浏览器对应,百度下载. 作用:对chrome浏览器进行驱动. HTMLTestRunner:HTMLTestRunner是Pyt

  • Gogs+Jenkins+Docker 自动化部署.NetCore的方法步骤

    环境说明 腾讯云轻量服务器, 配置 1c 2g 6mb ,系统是 ubuntu 20.14,Docker 和 Jenkins 都在这台服务器上面, 群晖218+一台,Gogs 在这台服务器上. Docker安装 卸载旧的 Docker sudo apt-get remove docker docker-engine docker.io containerd runc 更新 apt 包索引并安装包以允许 apt 通过 HTTPS 使用存储库 sudo apt-get update sudo apt

  • 基于Docker+Jenkins实现自动化部署的方法

    使用码云搭建Git代码存储仓库 https://gitee.com/login 使用码云创建私有私有git仓库 将本地springboot项目上传到git仓库中 基于Docker安装Jenkins环境 1.使用docker 安装jenkins docker run -p 8080:8080 -p 50000:50000 -v jenkins_data:/var/jenkins_home jenkinsci/blueocean 2.访问jenkins地址 8080 注意:第一次启动的时候正在加载j

  • Selenium+Python 自动化操控登录界面实例(有简单验证码图片校验)

    从最简单的Web浏览器的登录界面开始,登录界面如下: 进行Web页面自动化测试,对页面上的元素进行定位和操作是核心.而操作又是以定位为前提的,因此,对页面元素的定位是进行自动化测试的基础. 页面上的元素就像人一样,有各种属性,比如元素名字,元素id,元素属性(class属性,name属性)等等.webdriver就是利用元素的这些属性来进行定位的. 可以用于定位的常用的元素属性: id name class name tag name link text partial link text xp

  • Selenium 配置启动项参数的方法

    一.常用参数 参数 说明 --headless 开启无界面模式(服务器中不加此配置会报错) --user-agent=请求头 配置对象添加User-Agent --window-size=1000,500 设置浏览器窗口大小 --start-maximized 全屏窗口 --disable-infobars 禁用浏览器正在被自动化程序控制的提示 --incognito 无痕模式 --disable-javascript 禁用javascript --disable-gpu 禁用gpu 二.代码示

  • selenium+python自动化78-autoit参数化与批量上传功能的实现

    前言 前一篇autoit实现文件上传打包成.exe可执行文件后,每次只能传固定的那个图片,我们实际测试时候希望传不同的图片. 这样每次调用的时候,在命令行里面加一个文件路径的参数就行. 一.命令行参数 1.参数化传入的参数,可以通过autoit的命令行参数: myProg.exe param1 "This is a string parameter" 99 在脚本中,可用以下变量获取命令行参数: $CmdLine[0] ; = 3 $CmdLine[1] ; = param1 $Cmd

  • 基于Docker+Selenium Grid的测试技术应用示例代码

    Selenium Grid介绍 尽管在未来将会推出的Selenium 4.0版本中对Selenium Grid的一些新特性进行了说明,但是目前来看官方并没有太多详细文档供大家参考,所以本书中仍结合目前被广泛使用的Selenium Grid 版本进行讲解. 正如其官网对Selenium Grid的描述,它是一个智能代理服务器,允许Selenium测试将命令路由到远程Web浏览器实例.其目的是提供一种在多台计算机上并行运行测试的简便方法.使用Selenium Grid,一台服务器充当将JSON格式的

随机推荐